api_transfer_batch.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230
  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 TransferBatchApiService services.Service
  21. // GetTransferBatchByNo 微信支付批次单号查询批次单
  22. //
  23. // ## 查询接口说明
  24. // 微信支付批次单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询转账批次单以及指定状态的转账明细单。返回消息中包含微信支付批次单号、批次状态、批次类型、转账总金额、转账总笔数、成功金额、失败金额等信息。
  25. //
  26. // 接口限频:
  27. // 单个服务商(查询转账批次单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
  28. //
  29. // 注意事项:
  30. // - API只支持查询最近30天内的转账批次单,30天之前的转账批次单请登录商户平台查询。
  31. // - 转账明细单只会在批次单完成的情况下返回,如果需要在批次处理过程中查询转账明细单,请通过转账明细单查询接口来查询。
  32. // - 转账批次单和明细单中涉及金额的字段单位为“分”。
  33. // - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)批次还在受理中;(2)批次受理失败导致转账批次单没有落地。在上述情况下,服务商首先需要检查该微信支付批次单号是否确实是自己发起的,如果服务商确认是自己发起的,则请服务商不要直接当做受理失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理),或者服务商可以通过相同的商家批次单号再次发起转账。如果服务商误把还在受理中的批次单直接当受理失败处理,服务商应当自行承担因此产生的所有损失和责任。
  34. // - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。
  35. // - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
  36. func (a *TransferBatchApiService) GetTransferBatchByNo(ctx context.Context, req GetTransferBatchByNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error) {
  37. var (
  38. localVarHTTPMethod = nethttp.MethodGet
  39. localVarPostBody interface{}
  40. localVarQueryParams neturl.Values
  41. localVarHeaderParams = nethttp.Header{}
  42. )
  43. // Make sure Path Params are properly set
  44. if req.BatchId == nil {
  45. return nil, nil, fmt.Errorf("field `BatchId` is required and must be specified in GetTransferBatchByNoRequest")
  46. }
  47. localVarPath := consts.WechatPayAPIServer + "/v3/partner-transfer/batches/batch-id/{batch_id}"
  48. // Build Path with Path Params
  49. localVarPath = strings.Replace(localVarPath, "{"+"batch_id"+"}", neturl.PathEscape(core.ParameterToString(*req.BatchId, "")), -1)
  50. // Make sure All Required Params are properly set
  51. if req.NeedQueryDetail == nil {
  52. return nil, nil, fmt.Errorf("field `NeedQueryDetail` is required and must be specified in GetTransferBatchByNoRequest")
  53. }
  54. // Setup Query Params
  55. localVarQueryParams = neturl.Values{}
  56. localVarQueryParams.Add("need_query_detail", core.ParameterToString(*req.NeedQueryDetail, ""))
  57. if req.Offset != nil {
  58. localVarQueryParams.Add("offset", core.ParameterToString(*req.Offset, ""))
  59. }
  60. if req.Limit != nil {
  61. localVarQueryParams.Add("limit", core.ParameterToString(*req.Limit, ""))
  62. }
  63. if req.DetailStatus != nil {
  64. localVarQueryParams.Add("detail_status", core.ParameterToString(*req.DetailStatus, ""))
  65. }
  66. // Determine the Content-Type Header
  67. localVarHTTPContentTypes := []string{}
  68. // Setup Content-Type
  69. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  70. // Perform Http Request
  71. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  72. if err != nil {
  73. return nil, result, err
  74. }
  75. // Extract TransferBatchEntity from Http Response
  76. resp = new(TransferBatchEntity)
  77. err = core.UnMarshalResponse(result.Response, resp)
  78. if err != nil {
  79. return nil, result, err
  80. }
  81. return resp, result, nil
  82. }
  83. // GetTransferBatchByOutNo 商家批次单号查询批次单
  84. //
  85. // ## 查询接口说明
  86. // 商家批次单号查单接口。转账处理后延迟一段时间(异步进行转账),服务商可以通过该接口查询转账批次单以及指定状态的转账明细单。返回消息中包含微信支付批次单号、批次状态、批次类型、转账总金额、转账总笔数、成功金额、失败金额等信息。
  87. //
  88. // 接口限频:
  89. // 单个服务商(查询转账批次单)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
  90. //
  91. // 注意事项:
  92. // - API只支持查询最近30天内的转账批次单,30天之前的转账批次单请登录商户平台查询。
  93. // - 转账明细单只会在批次单完成的情况下返回,如果需要在批次处理过程中查询转账明细单,请通过转账明细单查询接口来查询。
  94. // - 转账批次单和明细单中涉及金额的字段单位为“分”。
  95. // - 如果查询单号对应的数据不存在,那么数据不存在的原因可能是:(1)批次还在受理中;(2)批次受理失败导致转账批次单没有落地。在上述情况下,服务商首先需要检查该商家批次单号是否确实是自己发起的,如果服务商确认是自己发起的,则请服务商不要直接当做受理失败处理,请服务商隔几分钟再尝试查询(请勿转账和查询并发处理),或者服务商可以通过相同的商家批次单号再次发起转账。如果服务商误把还在受理中的批次单直接当受理失败处理,服务商应当自行承担因此产生的所有损失和责任。
  96. // - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。
  97. // - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
  98. func (a *TransferBatchApiService) GetTransferBatchByOutNo(ctx context.Context, req GetTransferBatchByOutNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error) {
  99. var (
  100. localVarHTTPMethod = nethttp.MethodGet
  101. localVarPostBody interface{}
  102. localVarQueryParams neturl.Values
  103. localVarHeaderParams = nethttp.Header{}
  104. )
  105. // Make sure Path Params are properly set
  106. if req.OutBatchNo == nil {
  107. return nil, nil, fmt.Errorf("field `OutBatchNo` is required and must be specified in GetTransferBatchByOutNoRequest")
  108. }
  109. localVarPath := consts.WechatPayAPIServer + "/v3/partner-transfer/batches/out-batch-no/{out_batch_no}"
  110. // Build Path with Path Params
  111. localVarPath = strings.Replace(localVarPath, "{"+"out_batch_no"+"}", neturl.PathEscape(core.ParameterToString(*req.OutBatchNo, "")), -1)
  112. // Make sure All Required Params are properly set
  113. if req.NeedQueryDetail == nil {
  114. return nil, nil, fmt.Errorf("field `NeedQueryDetail` is required and must be specified in GetTransferBatchByOutNoRequest")
  115. }
  116. // Setup Query Params
  117. localVarQueryParams = neturl.Values{}
  118. localVarQueryParams.Add("need_query_detail", core.ParameterToString(*req.NeedQueryDetail, ""))
  119. if req.Offset != nil {
  120. localVarQueryParams.Add("offset", core.ParameterToString(*req.Offset, ""))
  121. }
  122. if req.Limit != nil {
  123. localVarQueryParams.Add("limit", core.ParameterToString(*req.Limit, ""))
  124. }
  125. if req.DetailStatus != nil {
  126. localVarQueryParams.Add("detail_status", core.ParameterToString(*req.DetailStatus, ""))
  127. }
  128. // Determine the Content-Type Header
  129. localVarHTTPContentTypes := []string{}
  130. // Setup Content-Type
  131. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  132. // Perform Http Request
  133. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  134. if err != nil {
  135. return nil, result, err
  136. }
  137. // Extract TransferBatchEntity from Http Response
  138. resp = new(TransferBatchEntity)
  139. err = core.UnMarshalResponse(result.Response, resp)
  140. if err != nil {
  141. return nil, result, err
  142. }
  143. return resp, result, nil
  144. }
  145. // InitiateTransferBatch 发起批量转账
  146. //
  147. // ## 发起批量转账
  148. // 服务商可以通过该接口,批量向用户零钱进行转账操作。请求消息中应包含特约商户号、特约商户授权的appid、授权类型、商家批次单号、转账名称、转账总金额、转账总笔数、转账openid、收款用户姓名、服务商appid、转账用途等信息
  149. // 1、当特约商户授权类型为INFORMATION_AUTHORIZATION_TYPE(特约商户信息授权),需要填特约商户的公众号appid,特约商户公众号appid的用户的openid
  150. // 2、当特约商户授权类型为FUND_AUTHORIZATION_TYPE(特约商户资金授权),需要填服务商的公众号appid,服务商公众号appid的用户的openid
  151. //
  152. // 接口限频:
  153. // 单个服务商(发起批量转账接口)50QPS,如果超过频率限制,会报错FREQUENCY_LIMITED,请降低频率请求。
  154. //
  155. // 注意事项:
  156. // - 因服务商自身系统设置存在问题导致的资金损失,由服务商自行承担。
  157. // - 批量转账一旦发起后,不允许撤销。
  158. // - 转账批次单和明细单中涉及金额的字段单位为“分”。
  159. // - 微信支付视任何不同“发起的服务商商户号+商家批次单号(out_batch_no)”的请求为一个全新的批次。在未查询到明确的转账批次单处理结果之前,请勿修改商家批次单号重新提交!如有发生,服务商应当自行承担因此产生的所有损失和责任。
  160. // - 当返回错误时,请不要更换商家批次单号,一定要使用原商家批次单号重试,否则可能造成重复转账等资金风险。
  161. // - 如果遇到回包返回新的错误码,请务必不要换单重试,请联系客服确认转账情况。如果有新的错误码,会更新到此API文档中。
  162. // - 错误码描述字段message只供人工定位问题时做参考,系统实现时请不要依赖这个字段来做自动化处理。
  163. // - 请服务商在自身的系统中合理设置转账频次并做好并发控制,防范错付风险。
  164. func (a *TransferBatchApiService) InitiateTransferBatch(ctx context.Context, req InitiateTransferBatchRequest) (resp *InitiateTransferBatchResponse, result *core.APIResult, err error) {
  165. var (
  166. localVarHTTPMethod = nethttp.MethodPost
  167. localVarPostBody interface{}
  168. localVarQueryParams neturl.Values
  169. localVarHeaderParams = nethttp.Header{}
  170. )
  171. // 对请求中敏感字段进行加密
  172. encReq := req.Clone()
  173. encryptCertificate, err := a.Client.EncryptRequest(ctx, encReq)
  174. if err != nil {
  175. return nil, nil, fmt.Errorf("encrypt request failed: %v", err)
  176. }
  177. if encryptCertificate != "" {
  178. localVarHeaderParams.Set(consts.WechatPaySerial, encryptCertificate)
  179. }
  180. req = *encReq
  181. localVarPath := consts.WechatPayAPIServer + "/v3/partner-transfer/batches"
  182. // Make sure All Required Params are properly set
  183. // Setup Body Params
  184. localVarPostBody = req
  185. // Determine the Content-Type Header
  186. localVarHTTPContentTypes := []string{"application/json"}
  187. // Setup Content-Type
  188. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  189. // Perform Http Request
  190. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  191. if err != nil {
  192. return nil, result, err
  193. }
  194. // Extract InitiateTransferBatchResponse from Http Response
  195. resp = new(InitiateTransferBatchResponse)
  196. err = core.UnMarshalResponse(result.Response, resp)
  197. if err != nil {
  198. return nil, result, err
  199. }
  200. return resp, result, nil
  201. }