api_transfer_batch.go 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. // Copyright 2021 Tencent Inc. All rights reserved.
  2. //
  3. // 商家转账对外API
  4. //
  5. // * 场景及业务流程: 商户可通过该产品实现同时向多个用户微信零钱进行转账的操作,可用于发放奖金补贴、佣金货款结算、员工报销等场景。 [https://pay.weixin.qq.com/index.php/public/product/detail?pid=108&productType=0](https://pay.weixin.qq.com/index.php/public/product/detail?pid=108&productType=0) * 接入步骤: * 商户在微信支付商户平台开通“批量转账到零钱”产品权限,并勾选“使用API方式发起转账”。 * 调用批量转账接口,对多个用户微信零钱发起转账。 * 调用查询批次接口,可获取到转账批次详情及当前状态。 * 调用查询明细接口,可获取到单条转账明细详情及当前状态。
  6. //
  7. // API version: 1.0.5
  8. // Code generated by WechatPay APIv3 Generator based on [OpenAPI Generator](https://openapi-generator.tech); DO NOT EDIT.
  9. package transferbatch
  10. import (
  11. "context"
  12. "fmt"
  13. nethttp "net/http"
  14. neturl "net/url"
  15. "strings"
  16. "github.com/wechatpay-apiv3/wechatpay-go/core"
  17. "github.com/wechatpay-apiv3/wechatpay-go/core/consts"
  18. "github.com/wechatpay-apiv3/wechatpay-go/services"
  19. )
  20. type TransferBatchApiService services.Service
  21. // GetTransferBatchByNo 通过微信批次单号查询批次单
  22. //
  23. // 微信批次单号查单接口。商户可以通过该接口查询转账批次单以及指定状态的转账明细单。返回消息中包含微信批次单号、批次状态、批次类型、转账总金额、转账总笔数、成功金额、失败金额等信息。
  24. func (a *TransferBatchApiService) GetTransferBatchByNo(ctx context.Context, req GetTransferBatchByNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error) {
  25. var (
  26. localVarHTTPMethod = nethttp.MethodGet
  27. localVarPostBody interface{}
  28. localVarQueryParams neturl.Values
  29. localVarHeaderParams = nethttp.Header{}
  30. )
  31. // Make sure Path Params are properly set
  32. if req.BatchId == nil {
  33. return nil, nil, fmt.Errorf("field `BatchId` is required and must be specified in GetTransferBatchByNoRequest")
  34. }
  35. localVarPath := consts.WechatPayAPIServer + "/v3/transfer/batches/batch-id/{batch_id}"
  36. // Build Path with Path Params
  37. localVarPath = strings.Replace(localVarPath, "{"+"batch_id"+"}", neturl.PathEscape(core.ParameterToString(*req.BatchId, "")), -1)
  38. // Make sure All Required Params are properly set
  39. if req.NeedQueryDetail == nil {
  40. return nil, nil, fmt.Errorf("field `NeedQueryDetail` is required and must be specified in GetTransferBatchByNoRequest")
  41. }
  42. // Setup Query Params
  43. localVarQueryParams = neturl.Values{}
  44. localVarQueryParams.Add("need_query_detail", core.ParameterToString(*req.NeedQueryDetail, ""))
  45. if req.Offset != nil {
  46. localVarQueryParams.Add("offset", core.ParameterToString(*req.Offset, ""))
  47. }
  48. if req.Limit != nil {
  49. localVarQueryParams.Add("limit", core.ParameterToString(*req.Limit, ""))
  50. }
  51. if req.DetailStatus != nil {
  52. localVarQueryParams.Add("detail_status", core.ParameterToString(*req.DetailStatus, ""))
  53. }
  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 TransferBatchEntity from Http Response
  64. resp = new(TransferBatchEntity)
  65. err = core.UnMarshalResponse(result.Response, resp)
  66. if err != nil {
  67. return nil, result, err
  68. }
  69. return resp, result, nil
  70. }
  71. // GetTransferBatchByOutNo 通过商家批次单号查询批次单
  72. //
  73. // 商家明细单号查单接口。商户可以通过该接口查询转账批次单以及指定状态的转账明细单。返回消息中包含微信批次单号、批次状态、批次类型、转账总金额、转账总笔数、成功金额、失败金额等信息。
  74. func (a *TransferBatchApiService) GetTransferBatchByOutNo(ctx context.Context, req GetTransferBatchByOutNoRequest) (resp *TransferBatchEntity, result *core.APIResult, err error) {
  75. var (
  76. localVarHTTPMethod = nethttp.MethodGet
  77. localVarPostBody interface{}
  78. localVarQueryParams neturl.Values
  79. localVarHeaderParams = nethttp.Header{}
  80. )
  81. // Make sure Path Params are properly set
  82. if req.OutBatchNo == nil {
  83. return nil, nil, fmt.Errorf("field `OutBatchNo` is required and must be specified in GetTransferBatchByOutNoRequest")
  84. }
  85. localVarPath := consts.WechatPayAPIServer + "/v3/transfer/batches/out-batch-no/{out_batch_no}"
  86. // Build Path with Path Params
  87. localVarPath = strings.Replace(localVarPath, "{"+"out_batch_no"+"}", neturl.PathEscape(core.ParameterToString(*req.OutBatchNo, "")), -1)
  88. // Make sure All Required Params are properly set
  89. if req.NeedQueryDetail == nil {
  90. return nil, nil, fmt.Errorf("field `NeedQueryDetail` is required and must be specified in GetTransferBatchByOutNoRequest")
  91. }
  92. // Setup Query Params
  93. localVarQueryParams = neturl.Values{}
  94. localVarQueryParams.Add("need_query_detail", core.ParameterToString(*req.NeedQueryDetail, ""))
  95. if req.Offset != nil {
  96. localVarQueryParams.Add("offset", core.ParameterToString(*req.Offset, ""))
  97. }
  98. if req.Limit != nil {
  99. localVarQueryParams.Add("limit", core.ParameterToString(*req.Limit, ""))
  100. }
  101. if req.DetailStatus != nil {
  102. localVarQueryParams.Add("detail_status", core.ParameterToString(*req.DetailStatus, ""))
  103. }
  104. // Determine the Content-Type Header
  105. localVarHTTPContentTypes := []string{}
  106. // Setup Content-Type
  107. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  108. // Perform Http Request
  109. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  110. if err != nil {
  111. return nil, result, err
  112. }
  113. // Extract TransferBatchEntity from Http Response
  114. resp = new(TransferBatchEntity)
  115. err = core.UnMarshalResponse(result.Response, resp)
  116. if err != nil {
  117. return nil, result, err
  118. }
  119. return resp, result, nil
  120. }
  121. // InitiateBatchTransfer 发起商家转账
  122. //
  123. // 发起商家转账接口。商户可以通过该接口同时向多个用户微信零钱进行转账操作。请求消息中应包含商家批次单号、转账名称、appid、转账总金额、转账总笔数、转账openid、收款用户姓名等信息。注意受理成功将返回批次单号,此时并不代表转账成功,请通过查单接口查询单据的付款状态。
  124. func (a *TransferBatchApiService) InitiateBatchTransfer(ctx context.Context, req InitiateBatchTransferRequest) (resp *InitiateBatchTransferResponse, result *core.APIResult, err error) {
  125. var (
  126. localVarHTTPMethod = nethttp.MethodPost
  127. localVarPostBody interface{}
  128. localVarQueryParams neturl.Values
  129. localVarHeaderParams = nethttp.Header{}
  130. )
  131. // 对请求中敏感字段进行加密
  132. encReq := req.Clone()
  133. encryptCertificate, err := a.Client.EncryptRequest(ctx, encReq)
  134. if err != nil {
  135. return nil, nil, fmt.Errorf("encrypt request failed: %v", err)
  136. }
  137. if encryptCertificate != "" {
  138. localVarHeaderParams.Set(consts.WechatPaySerial, encryptCertificate)
  139. }
  140. req = *encReq
  141. localVarPath := consts.WechatPayAPIServer + "/v3/transfer/batches"
  142. // Make sure All Required Params are properly set
  143. // Setup Body Params
  144. localVarPostBody = req
  145. // Determine the Content-Type Header
  146. localVarHTTPContentTypes := []string{"application/json"}
  147. // Setup Content-Type
  148. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  149. // Perform Http Request
  150. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  151. if err != nil {
  152. return nil, result, err
  153. }
  154. // Extract InitiateBatchTransferResponse from Http Response
  155. resp = new(InitiateBatchTransferResponse)
  156. err = core.UnMarshalResponse(result.Response, resp)
  157. if err != nil {
  158. return nil, result, err
  159. }
  160. return resp, result, nil
  161. }