api_transfer_detail.go 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. // Copyright 2021 Tencent Inc. All rights reserved.
  2. //
  3. // 服务商批量转账API
  4. //
  5. // No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
  6. //
  7. // API version: 0.0.2
  8. // Code generated by WechatPay APIv3 Generator based on [OpenAPI Generator](https://openapi-generator.tech); DO NOT EDIT.
  9. package partnertransferbatch
  10. import (
  11. "context"
  12. "fmt"
  13. nethttp "net/http"
  14. neturl "net/url"
  15. "strings"
  16. "git.nanodreamtech.com/sg/wechatpay-go/core"
  17. "git.nanodreamtech.com/sg/wechatpay-go/core/consts"
  18. "git.nanodreamtech.com/sg/wechatpay-go/services"
  19. )
  20. type TransferDetailApiService services.Service
  21. // GetTransferDetailByNo 微信支付明细单号查询明细单
  22. //
  23. // ## 查询接口说明
  24. // 微信支付明细单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询单笔转账明细单。返回消息中包含微信支付明细单号、明细状态、转账金额、失败原因、收款用户姓名、用户OpenID等信息。
  25. //
  26. // 接口限频:
  27. // 单个服务商(查询转账明细单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
  28. //
  29. // 注意事项:
  30. // - API只支持查询最近30天内的转账明细单,30天之前的转账明细单请登录商户平台查询。
  31. // - 转账明细单中涉及金额的字段单位为“分”。
  32. // - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)转账还在处理中;(2)转账批次单受理失败或还未开始处理导致转账明细单没有落地。在上述情况下,服务商首先需要检查该微信支付明细单号是否确实是自己发起,以及是否是该批次下的,如果服务商确认是自己发起且是该批次下的,则请服务商不要直接当做转账失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理)。如果服务商误把还在转账处理中的明细单直接当转账失败处理,服务商应当自行承担因此产生的所有损失和责任。
  33. // - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。
  34. // - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
  35. func (a *TransferDetailApiService) GetTransferDetailByNo(ctx context.Context, req GetTransferDetailByNoRequest) (resp *TransferDetailEntity, result *core.APIResult, err error) {
  36. var (
  37. localVarHTTPMethod = nethttp.MethodGet
  38. localVarPostBody interface{}
  39. localVarQueryParams neturl.Values
  40. localVarHeaderParams = nethttp.Header{}
  41. )
  42. // Make sure Path Params are properly set
  43. if req.BatchId == nil {
  44. return nil, nil, fmt.Errorf("field `BatchId` is required and must be specified in GetTransferDetailByNoRequest")
  45. }
  46. if req.DetailId == nil {
  47. return nil, nil, fmt.Errorf("field `DetailId` is required and must be specified in GetTransferDetailByNoRequest")
  48. }
  49. localVarPath := consts.WechatPayAPIServer + "/v3/partner-transfer/batches/batch-id/{batch_id}/details/detail-id/{detail_id}"
  50. // Build Path with Path Params
  51. localVarPath = strings.Replace(localVarPath, "{"+"batch_id"+"}", neturl.PathEscape(core.ParameterToString(*req.BatchId, "")), -1)
  52. localVarPath = strings.Replace(localVarPath, "{"+"detail_id"+"}", neturl.PathEscape(core.ParameterToString(*req.DetailId, "")), -1)
  53. // Make sure All Required Params are properly set
  54. // Determine the Content-Type Header
  55. localVarHTTPContentTypes := []string{}
  56. // Setup Content-Type
  57. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  58. // Perform Http Request
  59. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  60. if err != nil {
  61. return nil, result, err
  62. }
  63. // Extract TransferDetailEntity from Http Response
  64. resp = new(TransferDetailEntity)
  65. err = core.UnMarshalResponse(result.Response, resp)
  66. if err != nil {
  67. return nil, result, err
  68. }
  69. // 对应答中隐私字段进行解密
  70. err = a.Client.DecryptResponse(ctx, resp)
  71. if err != nil {
  72. return resp, result, err
  73. }
  74. return resp, result, nil
  75. }
  76. // GetTransferDetailByOutNo 商家明细单号查询明细单
  77. //
  78. // ## 查询接口说明
  79. // 商户明细单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询单笔转账明细单。返回消息中包含微信明细单号、明细状态、转账金额、失败原因、收款用户姓名、用户OpenID等信息。
  80. //
  81. // 接口限频:
  82. // 单个服务商(查询转账明细单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
  83. //
  84. // 注意事项:
  85. // - API只支持查询最近30天内的转账明细单,30天之前的转账明细单请登录商户平台查询。
  86. // - 转账明细单中涉及金额的字段单位为“分”。
  87. // - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)转账还在处理中;(2)转账批次单受理失败或还未开始处理导致转账明细单没有落地。在上述情况下,服务商首先需要检查该商家明细单号是否确实是自己发起,以及是否是该批次下的,如果服务商确认是自己发起且是该批次下的,则请服务商不要直接当做转账失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理)。如果服务商误把还在转账处理中的明细单直接当转账失败处理,服务商应当自行承担因此产生的所有损失和责任。
  88. // - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。
  89. // - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
  90. func (a *TransferDetailApiService) GetTransferDetailByOutNo(ctx context.Context, req GetTransferDetailByOutNoRequest) (resp *TransferDetailEntity, result *core.APIResult, err error) {
  91. var (
  92. localVarHTTPMethod = nethttp.MethodGet
  93. localVarPostBody interface{}
  94. localVarQueryParams neturl.Values
  95. localVarHeaderParams = nethttp.Header{}
  96. )
  97. // Make sure Path Params are properly set
  98. if req.OutBatchNo == nil {
  99. return nil, nil, fmt.Errorf("field `OutBatchNo` is required and must be specified in GetTransferDetailByOutNoRequest")
  100. }
  101. if req.OutDetailNo == nil {
  102. return nil, nil, fmt.Errorf("field `OutDetailNo` is required and must be specified in GetTransferDetailByOutNoRequest")
  103. }
  104. localVarPath := consts.WechatPayAPIServer + "/v3/partner-transfer/batches/out-batch-no/{out_batch_no}/details/out-detail-no/{out_detail_no}"
  105. // Build Path with Path Params
  106. localVarPath = strings.Replace(localVarPath, "{"+"out_batch_no"+"}", neturl.PathEscape(core.ParameterToString(*req.OutBatchNo, "")), -1)
  107. localVarPath = strings.Replace(localVarPath, "{"+"out_detail_no"+"}", neturl.PathEscape(core.ParameterToString(*req.OutDetailNo, "")), -1)
  108. // Make sure All Required Params are properly set
  109. // Determine the Content-Type Header
  110. localVarHTTPContentTypes := []string{}
  111. // Setup Content-Type
  112. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  113. // Perform Http Request
  114. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  115. if err != nil {
  116. return nil, result, err
  117. }
  118. // Extract TransferDetailEntity from Http Response
  119. resp = new(TransferDetailEntity)
  120. err = core.UnMarshalResponse(result.Response, resp)
  121. if err != nil {
  122. return nil, result, err
  123. }
  124. // 对应答中隐私字段进行解密
  125. err = a.Client.DecryptResponse(ctx, resp)
  126. if err != nil {
  127. return resp, result, err
  128. }
  129. return resp, result, nil
  130. }