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" + } + ] +}