diff --git a/docs/WechatTenpayV3/Basic_ModelDefinition.md b/docs/WechatTenpayV3/Basic_ModelDefinition.md
index 337244a0..aefa0866 100644
--- a/docs/WechatTenpayV3/Basic_ModelDefinition.md
+++ b/docs/WechatTenpayV3/Basic_ModelDefinition.md
@@ -1431,6 +1431,12 @@
- 处置结果回传:`CreateMerchantRiskManageTradeRiskResult`
+ - 风险订单同步及处理
+
+ - 查询风险订单:`QueryMerchantRiskManagePartnerECTradeRiskTrades`
+
+ - 处置结果回传:`CreateMerchantRiskManagePartnerECTradeRiskResult`
+
- 不活跃商户身份核实
- 发起不活跃商户身份核实:`CreateComplianceInactiveMerchantIdentityVerification`
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Events/MerchantRiskManage/RiskTradeIdentificationResource.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Events/MerchantRiskManage/RiskTradeIdentificationResource.cs
new file mode 100644
index 00000000..f71b3243
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Events/MerchantRiskManage/RiskTradeIdentificationResource.cs
@@ -0,0 +1,41 @@
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Events
+{
+ ///
+ /// 表示 RISKTRADE.IDENTIFICATION 通知的数据。
+ ///
+ /// REF:
+ ///
+ ///
+ ///
+ ///
+ public class RiskTradeIdentificationResource : WechatTenpayEvent.Types.IDecryptedResource
+ {
+ ///
+ /// 获取或设置微信商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("mchid")]
+ public string MerchantId { get; set; } = default!;
+
+ ///
+ /// 获取或设置商户订单号。
+ ///
+ [Newtonsoft.Json.JsonProperty("out_trade_no")]
+ [System.Text.Json.Serialization.JsonPropertyName("out_trade_no")]
+ public string OutTradeNumber { get; set; } = default!;
+
+ ///
+ /// 获取或设置风险类型。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_type")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_type")]
+ public int RiskType { get; set; }
+
+ ///
+ /// 获取或设置风险等级。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_level")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_level")]
+ public int RiskLevel { get; set; }
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Extensions/WechatTenpayClientExecuteMerchantRiskManageExtensions.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Extensions/WechatTenpayClientExecuteMerchantRiskManageExtensions.cs
index 9702e192..9e746714 100644
--- a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Extensions/WechatTenpayClientExecuteMerchantRiskManageExtensions.cs
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Extensions/WechatTenpayClientExecuteMerchantRiskManageExtensions.cs
@@ -8,6 +8,96 @@ namespace SKIT.FlurlHttpClient.Wechat.TenpayV3
{
public static class WechatTenpayClientExecuteMerchantRiskManageExtensions
{
+ #region ECTradeRisk
+ ///
+ /// 异步调用 [POST] /merchant-risk-manage/ec-trade-risk/query-risk-trades 接口。
+ ///
+ /// REF:
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public static async Task ExecuteQueryMerchantRiskManageECTradeRiskTradesAsync(this WechatTenpayClient client, Models.QueryMerchantRiskManageECTradeRiskTradesRequest request, CancellationToken cancellationToken = default)
+ {
+ if (client is null) throw new ArgumentNullException(nameof(client));
+ if (request is null) throw new ArgumentNullException(nameof(request));
+
+ IFlurlRequest flurlReq = client
+ .CreateFlurlRequest(request, HttpMethod.Post, "merchant-risk-manage", "ec-trade-risk", "query-risk-trades");
+
+ return await client.SendFlurlRequestAsJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken).ConfigureAwait(false);
+ }
+
+ ///
+ /// 异步调用 [POST] /merchant-risk-manage/ec-trade-risk/recv-dispose-result 接口。
+ ///
+ /// REF:
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public static async Task ExecuteCreateMerchantRiskManageECTradeRiskResultAsync(this WechatTenpayClient client, Models.CreateMerchantRiskManageECTradeRiskResultRequest request, CancellationToken cancellationToken = default)
+ {
+ if (client is null) throw new ArgumentNullException(nameof(client));
+ if (request is null) throw new ArgumentNullException(nameof(request));
+
+ IFlurlRequest flurlReq = client
+ .CreateFlurlRequest(request, HttpMethod.Post, "merchant-risk-manage", "ec-trade-risk", "recv-dispose-result");
+
+ return await client.SendFlurlRequestAsJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken).ConfigureAwait(false);
+ }
+
+ ///
+ /// 异步调用 [POST] /merchant-risk-manage/ec-trade-risk/query-risk-trades 接口。
+ ///
+ /// REF:
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public static async Task ExecuteQueryMerchantRiskManagePartnerECTradeRiskTradesAsync(this WechatTenpayClient client, Models.QueryMerchantRiskManagePartnerECTradeRiskTradesRequest request, CancellationToken cancellationToken = default)
+ {
+ if (client is null) throw new ArgumentNullException(nameof(client));
+ if (request is null) throw new ArgumentNullException(nameof(request));
+
+ IFlurlRequest flurlReq = client
+ .CreateFlurlRequest(request, HttpMethod.Post, "merchant-risk-manage", "ec-trade-risk", "query-risk-trades");
+
+ return await client.SendFlurlRequestAsJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken).ConfigureAwait(false);
+ }
+
+ ///
+ /// 异步调用 [POST] /merchant-risk-manage/ec-trade-risk/recv-dispose-result 接口。
+ ///
+ /// REF:
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ ///
+ public static async Task ExecuteCreateMerchantRiskManagePartnerECTradeRiskResultAsync(this WechatTenpayClient client, Models.CreateMerchantRiskManagePartnerECTradeRiskResultRequest request, CancellationToken cancellationToken = default)
+ {
+ if (client is null) throw new ArgumentNullException(nameof(client));
+ if (request is null) throw new ArgumentNullException(nameof(request));
+
+ IFlurlRequest flurlReq = client
+ .CreateFlurlRequest(request, HttpMethod.Post, "merchant-risk-manage", "ec-trade-risk", "recv-dispose-result");
+
+ return await client.SendFlurlRequestAsJsonAsync(flurlReq, data: request, cancellationToken: cancellationToken).ConfigureAwait(false);
+ }
+ #endregion
+
#region TradeRisk
///
/// 异步调用 [POST] /merchant-risk-manage/report-trade-union-information 接口。
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultRequest.cs
new file mode 100644
index 00000000..5760e34b
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultRequest.cs
@@ -0,0 +1,66 @@
+using System.Collections.Generic;
+
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/recv-dispose-result 接口的请求。
+ ///
+ public class CreateMerchantRiskManageECTradeRiskResultRequest : WechatTenpayRequest
+ {
+ ///
+ /// 获取或设置微信商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("mchid")]
+ public string? MerchantId { get; set; }
+
+ ///
+ /// 获取或设置商户订单号。
+ ///
+ [Newtonsoft.Json.JsonProperty("out_trade_no")]
+ [System.Text.Json.Serialization.JsonPropertyName("out_trade_no")]
+ public string OutTradeNumber { get; set; } = string.Empty;
+
+ ///
+ /// 获取或设置最终风险结论。
+ ///
+ [Newtonsoft.Json.JsonProperty("final_risk_result")]
+ [System.Text.Json.Serialization.JsonPropertyName("final_risk_result")]
+ public int? FinalRiskResult { get; set; }
+
+ ///
+ /// 获取或设置最终风险类型。
+ ///
+ [Newtonsoft.Json.JsonProperty("final_risk_type")]
+ [System.Text.Json.Serialization.JsonPropertyName("final_risk_type")]
+ public int? FinalRiskType { get; set; }
+
+ ///
+ /// 获取或设置处置结论列表。
+ ///
+ [Newtonsoft.Json.JsonProperty("disp_conclusion")]
+ [System.Text.Json.Serialization.JsonPropertyName("disp_conclusion")]
+ public IList? DisposeConclusionList { get; set; }
+
+ ///
+ /// 获取或设置处置补充。
+ ///
+ [Newtonsoft.Json.JsonProperty("disp_addition")]
+ [System.Text.Json.Serialization.JsonPropertyName("disp_addition")]
+ public string? DisposeAdditional { get; set; }
+
+ ///
+ /// 获取或设置是否有投诉。
+ ///
+ [Newtonsoft.Json.JsonProperty("exist_complaint")]
+ [System.Text.Json.Serialization.JsonPropertyName("exist_complaint")]
+ public bool? IsComplaintExist { get; set; }
+
+ ///
+ /// 获取或设置退款金额(单位:分)。
+ ///
+ [Newtonsoft.Json.JsonProperty("refund_amount")]
+ [System.Text.Json.Serialization.JsonPropertyName("refund_amount")]
+ public int? RefundAmount { get; set; }
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultResponse.cs
new file mode 100644
index 00000000..5e539c5b
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultResponse.cs
@@ -0,0 +1,15 @@
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/recv-dispose-result 接口的响应。
+ ///
+ public class CreateMerchantRiskManageECTradeRiskResultResponse : WechatTenpayResponse
+ {
+ ///
+ /// 获取或设置返回描述。
+ ///
+ [Newtonsoft.Json.JsonProperty("rsp_msg")]
+ [System.Text.Json.Serialization.JsonPropertyName("rsp_msg")]
+ public string? ResponseMessage { get; set; }
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesRequest.cs
new file mode 100644
index 00000000..cd3f8284
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesRequest.cs
@@ -0,0 +1,49 @@
+using System;
+
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/query-risk-trades 接口的请求。
+ ///
+ public class QueryMerchantRiskManageECTradeRiskTradesRequest : WechatTenpayRequest
+ {
+ ///
+ /// 获取或设置微信商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("mchid")]
+ public string? MerchantId { get; set; }
+
+ ///
+ /// 获取或设置开始时间。
+ ///
+ [Newtonsoft.Json.JsonProperty("start_time")]
+ [Newtonsoft.Json.JsonConverter(typeof(Newtonsoft.Json.Converters.Common.Rfc3339DateTimeOffsetConverter))]
+ [System.Text.Json.Serialization.JsonPropertyName("start_time")]
+ [System.Text.Json.Serialization.JsonConverter(typeof(System.Text.Json.Serialization.Common.Rfc3339DateTimeOffsetConverter))]
+ public DateTimeOffset? StartTime { get; set; }
+
+ ///
+ /// 获取或设置结束时间。
+ ///
+ [Newtonsoft.Json.JsonProperty("end_time")]
+ [Newtonsoft.Json.JsonConverter(typeof(Newtonsoft.Json.Converters.Common.Rfc3339DateTimeOffsetConverter))]
+ [System.Text.Json.Serialization.JsonPropertyName("end_time")]
+ [System.Text.Json.Serialization.JsonConverter(typeof(System.Text.Json.Serialization.Common.Rfc3339DateTimeOffsetConverter))]
+ public DateTimeOffset? EndTime { get; set; }
+
+ ///
+ /// 获取或设置分页页数。
+ ///
+ [Newtonsoft.Json.JsonProperty("page_index")]
+ [System.Text.Json.Serialization.JsonPropertyName("page_index")]
+ public int? Page { get; set; }
+
+ ///
+ /// 获取或设置分页大小。
+ ///
+ [Newtonsoft.Json.JsonProperty("page_size")]
+ [System.Text.Json.Serialization.JsonPropertyName("page_size")]
+ public int? Limit { get; set; }
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesResponse.cs
new file mode 100644
index 00000000..7b292bf2
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesResponse.cs
@@ -0,0 +1,67 @@
+using System;
+
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/query-risk-trades 接口的响应。
+ ///
+ public class QueryMerchantRiskManageECTradeRiskTradesResponse : WechatTenpayResponse
+ {
+ public static class Types
+ {
+ public class RiskTrade
+ {
+ ///
+ /// 获取或设置微信商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("mchid")]
+ public string MerchantId { get; set; } = default!;
+
+ ///
+ /// 获取或设置商户订单号。
+ ///
+ [Newtonsoft.Json.JsonProperty("out_trade_no")]
+ [System.Text.Json.Serialization.JsonPropertyName("out_trade_no")]
+ public string OutTradeNumber { get; set; } = default!;
+
+ ///
+ /// 获取或设置风险类型。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_type")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_type")]
+ public int RiskType { get; set; }
+
+ ///
+ /// 获取或设置风险等级。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_level")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_level")]
+ public int RiskLevel { get; set; }
+
+ ///
+ /// 获取或设置风险发现时间。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_discove_time")]
+ [Newtonsoft.Json.JsonConverter(typeof(Newtonsoft.Json.Converters.Common.Rfc3339DateTimeOffsetConverter))]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_discove_time")]
+ [System.Text.Json.Serialization.JsonConverter(typeof(System.Text.Json.Serialization.Common.Rfc3339DateTimeOffsetConverter))]
+ public DateTimeOffset RiskDiscoveTime { get; set; }
+ }
+ }
+
+ ///
+ /// 获取或设置总数量。
+ ///
+ [Newtonsoft.Json.JsonProperty("total_num")]
+ [System.Text.Json.Serialization.JsonPropertyName("total_num")]
+ public int TotalCount { get; set; }
+
+ ///
+ /// 获取或设置风险订单列表。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_trade_list")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_trade_list")]
+ public Types.RiskTrade[] RiskTradeList { get; set; } = default!;
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultRequest.cs
new file mode 100644
index 00000000..bec4f47f
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultRequest.cs
@@ -0,0 +1,73 @@
+using System.Collections.Generic;
+
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/recv-dispose-result 接口的请求。
+ ///
+ public class CreateMerchantRiskManagePartnerECTradeRiskResultRequest : WechatTenpayRequest
+ {
+ ///
+ /// 获取或设置服务商商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("sp_mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("sp_mchid")]
+ public string? MerchantId { get; set; }
+
+ ///
+ /// 获取或设置子商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("sub_mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("sub_mchid")]
+ public string? SubMerchantId { get; set; }
+
+ ///
+ /// 获取或设置商户订单号。
+ ///
+ [Newtonsoft.Json.JsonProperty("out_trade_no")]
+ [System.Text.Json.Serialization.JsonPropertyName("out_trade_no")]
+ public string OutTradeNumber { get; set; } = string.Empty;
+
+ ///
+ /// 获取或设置最终风险结论。
+ ///
+ [Newtonsoft.Json.JsonProperty("final_risk_result")]
+ [System.Text.Json.Serialization.JsonPropertyName("final_risk_result")]
+ public int? FinalRiskResult { get; set; }
+
+ ///
+ /// 获取或设置最终风险类型。
+ ///
+ [Newtonsoft.Json.JsonProperty("final_risk_type")]
+ [System.Text.Json.Serialization.JsonPropertyName("final_risk_type")]
+ public int? FinalRiskType { get; set; }
+
+ ///
+ /// 获取或设置处置结论列表。
+ ///
+ [Newtonsoft.Json.JsonProperty("disp_conclusion")]
+ [System.Text.Json.Serialization.JsonPropertyName("disp_conclusion")]
+ public IList? DisposeConclusionList { get; set; }
+
+ ///
+ /// 获取或设置处置补充。
+ ///
+ [Newtonsoft.Json.JsonProperty("disp_addition")]
+ [System.Text.Json.Serialization.JsonPropertyName("disp_addition")]
+ public string? DisposeAdditional { get; set; }
+
+ ///
+ /// 获取或设置是否有投诉。
+ ///
+ [Newtonsoft.Json.JsonProperty("exist_complaint")]
+ [System.Text.Json.Serialization.JsonPropertyName("exist_complaint")]
+ public bool? IsComplaintExist { get; set; }
+
+ ///
+ /// 获取或设置退款金额(单位:分)。
+ ///
+ [Newtonsoft.Json.JsonProperty("refund_amount")]
+ [System.Text.Json.Serialization.JsonPropertyName("refund_amount")]
+ public int? RefundAmount { get; set; }
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultResponse.cs
new file mode 100644
index 00000000..86aa0190
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultResponse.cs
@@ -0,0 +1,15 @@
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/recv-dispose-result 接口的响应。
+ ///
+ public class CreateMerchantRiskManagePartnerECTradeRiskResultResponse : WechatTenpayResponse
+ {
+ ///
+ /// 获取或设置返回描述。
+ ///
+ [Newtonsoft.Json.JsonProperty("rsp_msg")]
+ [System.Text.Json.Serialization.JsonPropertyName("rsp_msg")]
+ public string? ResponseMessage { get; set; }
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesRequest.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesRequest.cs
new file mode 100644
index 00000000..6615ce80
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesRequest.cs
@@ -0,0 +1,56 @@
+using System;
+
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/query-risk-trades 接口的请求。
+ ///
+ public class QueryMerchantRiskManagePartnerECTradeRiskTradesRequest : WechatTenpayRequest
+ {
+ ///
+ /// 获取或设置服务商商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("sp_mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("sp_mchid")]
+ public string? MerchantId { get; set; }
+
+ ///
+ /// 获取或设置子商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("sub_mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("sub_mchid")]
+ public string? SubMerchantId { get; set; }
+
+ ///
+ /// 获取或设置开始时间。
+ ///
+ [Newtonsoft.Json.JsonProperty("start_time")]
+ [Newtonsoft.Json.JsonConverter(typeof(Newtonsoft.Json.Converters.Common.Rfc3339DateTimeOffsetConverter))]
+ [System.Text.Json.Serialization.JsonPropertyName("start_time")]
+ [System.Text.Json.Serialization.JsonConverter(typeof(System.Text.Json.Serialization.Common.Rfc3339DateTimeOffsetConverter))]
+ public DateTimeOffset? StartTime { get; set; }
+
+ ///
+ /// 获取或设置结束时间。
+ ///
+ [Newtonsoft.Json.JsonProperty("end_time")]
+ [Newtonsoft.Json.JsonConverter(typeof(Newtonsoft.Json.Converters.Common.Rfc3339DateTimeOffsetConverter))]
+ [System.Text.Json.Serialization.JsonPropertyName("end_time")]
+ [System.Text.Json.Serialization.JsonConverter(typeof(System.Text.Json.Serialization.Common.Rfc3339DateTimeOffsetConverter))]
+ public DateTimeOffset? EndTime { get; set; }
+
+ ///
+ /// 获取或设置分页页数。
+ ///
+ [Newtonsoft.Json.JsonProperty("page_index")]
+ [System.Text.Json.Serialization.JsonPropertyName("page_index")]
+ public int? Page { get; set; }
+
+ ///
+ /// 获取或设置分页大小。
+ ///
+ [Newtonsoft.Json.JsonProperty("page_size")]
+ [System.Text.Json.Serialization.JsonPropertyName("page_size")]
+ public int? Limit { get; set; }
+ }
+}
diff --git a/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesResponse.cs b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesResponse.cs
new file mode 100644
index 00000000..867b383c
--- /dev/null
+++ b/src/SKIT.FlurlHttpClient.Wechat.TenpayV3/Models/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesResponse.cs
@@ -0,0 +1,74 @@
+using System;
+
+namespace SKIT.FlurlHttpClient.Wechat.TenpayV3.Models
+{
+ ///
+ /// 表示 [POST] /merchant-risk-manage/ec-trade-risk/query-risk-trades 接口的响应。
+ ///
+ public class QueryMerchantRiskManagePartnerECTradeRiskTradesResponse : WechatTenpayResponse
+ {
+ public static class Types
+ {
+ public class RiskTrade
+ {
+ ///
+ /// 获取或设置服务商商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("sp_mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("sp_mchid")]
+ public string MerchantId { get; set; } = default!;
+
+ ///
+ /// 获取或设置子商户号。
+ ///
+ [Newtonsoft.Json.JsonProperty("mchid")]
+ [System.Text.Json.Serialization.JsonPropertyName("mchid")]
+ public string SubMerchantId { get; set; } = default!;
+
+ ///
+ /// 获取或设置商户订单号。
+ ///
+ [Newtonsoft.Json.JsonProperty("out_trade_no")]
+ [System.Text.Json.Serialization.JsonPropertyName("out_trade_no")]
+ public string OutTradeNumber { get; set; } = default!;
+
+ ///
+ /// 获取或设置风险类型。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_type")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_type")]
+ public int RiskType { get; set; }
+
+ ///
+ /// 获取或设置风险等级。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_level")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_level")]
+ public int RiskLevel { get; set; }
+
+ ///
+ /// 获取或设置风险发现时间。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_discove_time")]
+ [Newtonsoft.Json.JsonConverter(typeof(Newtonsoft.Json.Converters.Common.Rfc3339DateTimeOffsetConverter))]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_discove_time")]
+ [System.Text.Json.Serialization.JsonConverter(typeof(System.Text.Json.Serialization.Common.Rfc3339DateTimeOffsetConverter))]
+ public DateTimeOffset RiskDiscoveTime { get; set; }
+ }
+ }
+
+ ///
+ /// 获取或设置总数量。
+ ///
+ [Newtonsoft.Json.JsonProperty("total_num")]
+ [System.Text.Json.Serialization.JsonPropertyName("total_num")]
+ public int TotalCount { get; set; }
+
+ ///
+ /// 获取或设置风险订单列表。
+ ///
+ [Newtonsoft.Json.JsonProperty("risk_trade_list")]
+ [System.Text.Json.Serialization.JsonPropertyName("risk_trade_list")]
+ public Types.RiskTrade[] RiskTradeList { get; set; } = default!;
+ }
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/EventSamples/_/MerchantRiskManage/RiskTradeIdentificationResource.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/EventSamples/_/MerchantRiskManage/RiskTradeIdentificationResource.json
new file mode 100644
index 00000000..21890923
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/EventSamples/_/MerchantRiskManage/RiskTradeIdentificationResource.json
@@ -0,0 +1,6 @@
+{
+ "mchid": "1900009231",
+ "out_trade_no": "20150806125346",
+ "risk_type": 1,
+ "risk_level": 1
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultRequest.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultRequest.json
new file mode 100644
index 00000000..ca20c5c7
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultRequest.json
@@ -0,0 +1,12 @@
+{
+ "mchid": "1900009231",
+ "out_trade_no": "20150806125346",
+ "final_risk_result": 1,
+ "final_risk_type": 1,
+ "disp_conclusion": [
+ 1
+ ],
+ "disp_addition": "example_disp_addition",
+ "exist_complaint": false,
+ "refund_amount": 100
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultResponse.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultResponse.json
new file mode 100644
index 00000000..3d6612c0
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManageECTradeRiskResultResponse.json
@@ -0,0 +1,3 @@
+{
+ "rsp_msg": "ok"
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesRequest.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesRequest.json
new file mode 100644
index 00000000..efde87ee
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesRequest.json
@@ -0,0 +1,7 @@
+{
+ "mchid": "1900009231",
+ "start_time": "2025-05-20T13:29:35+08:00",
+ "end_time": "2025-05-20T13:29:35+08:00",
+ "page_index": 1,
+ "page_size": 10
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesResponse.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesResponse.json
new file mode 100644
index 00000000..54322e1a
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManageECTradeRiskTradesResponse.json
@@ -0,0 +1,12 @@
+{
+ "total_num": 10,
+ "risk_trade_list": [
+ {
+ "mchid": "1900000109",
+ "out_trade_no": "20150806125346",
+ "risk_type": 1,
+ "risk_level": 1,
+ "risk_discove_time": "2020-12-01T16:18:12+08:00"
+ }
+ ]
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultRequest.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultRequest.json
new file mode 100644
index 00000000..de37f2fe
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultRequest.json
@@ -0,0 +1,13 @@
+{
+ "sp_mchid": "1900000109",
+ "sub_mchid": "1900009231",
+ "out_trade_no": "20150806125346",
+ "final_risk_result": 1,
+ "final_risk_type": 1,
+ "disp_conclusion": [
+ 1
+ ],
+ "disp_addition": "example_disp_addition",
+ "exist_complaint": false,
+ "refund_amount": 100
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultResponse.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultResponse.json
new file mode 100644
index 00000000..3d6612c0
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/CreateMerchantRiskManagePartnerECTradeRiskResultResponse.json
@@ -0,0 +1,3 @@
+{
+ "rsp_msg": "ok"
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesRequest.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesRequest.json
new file mode 100644
index 00000000..eb4fd7d9
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesRequest.json
@@ -0,0 +1,8 @@
+{
+ "sp_mchid": "1900000109",
+ "sub_mchid": "1900009231",
+ "start_time": "2025-05-20T13:29:35+08:00",
+ "end_time": "2025-05-20T13:29:35+08:00",
+ "page_index": 1,
+ "page_size": 10
+}
diff --git a/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesResponse.json b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesResponse.json
new file mode 100644
index 00000000..c88e1a2b
--- /dev/null
+++ b/test/SKIT.FlurlHttpClient.Wechat.TenpayV3.UnitTests/ModelSamples/_/_Partner/MerchantRiskManage/ECTradeRisk/QueryMerchantRiskManagePartnerECTradeRiskTradesResponse.json
@@ -0,0 +1,13 @@
+{
+ "total_num": 10,
+ "risk_trade_list": [
+ {
+ "mchid": "1900000109",
+ "out_trade_no": "20150806125346",
+ "risk_type": 1,
+ "risk_level": 1,
+ "sp_mchid": "1900000109",
+ "risk_discove_time": "2020-12-01T16:18:12+08:00"
+ }
+ ]
+}