api_transfer_detail.go 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  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. "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. // 明细单号查单接口。商户可以通过该接口查询单笔转账明细单。返回消息中包含微信明细单号、明细状态、转账金额、失败原因、收款用户姓名、用户OpenID等信息。
  24. func (a *TransferDetailApiService) GetTransferDetailByNo(ctx context.Context, req GetTransferDetailByNoRequest) (resp *TransferDetailEntity, 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 GetTransferDetailByNoRequest")
  34. }
  35. if req.DetailId == nil {
  36. return nil, nil, fmt.Errorf("field `DetailId` is required and must be specified in GetTransferDetailByNoRequest")
  37. }
  38. localVarPath := consts.WechatPayAPIServer + "/v3/transfer/batches/batch-id/{batch_id}/details/detail-id/{detail_id}"
  39. // Build Path with Path Params
  40. localVarPath = strings.Replace(localVarPath, "{"+"batch_id"+"}", neturl.PathEscape(core.ParameterToString(*req.BatchId, "")), -1)
  41. localVarPath = strings.Replace(localVarPath, "{"+"detail_id"+"}", neturl.PathEscape(core.ParameterToString(*req.DetailId, "")), -1)
  42. // Make sure All Required Params are properly set
  43. // Determine the Content-Type Header
  44. localVarHTTPContentTypes := []string{}
  45. // Setup Content-Type
  46. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  47. // Perform Http Request
  48. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  49. if err != nil {
  50. return nil, result, err
  51. }
  52. // Extract TransferDetailEntity from Http Response
  53. resp = new(TransferDetailEntity)
  54. err = core.UnMarshalResponse(result.Response, resp)
  55. if err != nil {
  56. return nil, result, err
  57. }
  58. // 对应答中隐私字段进行解密
  59. err = a.Client.DecryptResponse(ctx, resp)
  60. if err != nil {
  61. return resp, result, err
  62. }
  63. return resp, result, nil
  64. }
  65. // GetTransferDetailByOutNo 通过商家明细单号查询明细单
  66. //
  67. // 商户明细单号查单接口。商户可以通过该接口查询单笔转账明细单。返回消息中包含微信明细单号、明细状态、转账金额、失败原因、收款用户姓名、用户OpenID等信息。
  68. func (a *TransferDetailApiService) GetTransferDetailByOutNo(ctx context.Context, req GetTransferDetailByOutNoRequest) (resp *TransferDetailEntity, result *core.APIResult, err error) {
  69. var (
  70. localVarHTTPMethod = nethttp.MethodGet
  71. localVarPostBody interface{}
  72. localVarQueryParams neturl.Values
  73. localVarHeaderParams = nethttp.Header{}
  74. )
  75. // Make sure Path Params are properly set
  76. if req.OutDetailNo == nil {
  77. return nil, nil, fmt.Errorf("field `OutDetailNo` is required and must be specified in GetTransferDetailByOutNoRequest")
  78. }
  79. if req.OutBatchNo == nil {
  80. return nil, nil, fmt.Errorf("field `OutBatchNo` is required and must be specified in GetTransferDetailByOutNoRequest")
  81. }
  82. localVarPath := consts.WechatPayAPIServer + "/v3/transfer/batches/out-batch-no/{out_batch_no}/details/out-detail-no/{out_detail_no}"
  83. // Build Path with Path Params
  84. localVarPath = strings.Replace(localVarPath, "{"+"out_detail_no"+"}", neturl.PathEscape(core.ParameterToString(*req.OutDetailNo, "")), -1)
  85. localVarPath = strings.Replace(localVarPath, "{"+"out_batch_no"+"}", neturl.PathEscape(core.ParameterToString(*req.OutBatchNo, "")), -1)
  86. // Make sure All Required Params are properly set
  87. // Determine the Content-Type Header
  88. localVarHTTPContentTypes := []string{}
  89. // Setup Content-Type
  90. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  91. // Perform Http Request
  92. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  93. if err != nil {
  94. return nil, result, err
  95. }
  96. // Extract TransferDetailEntity from Http Response
  97. resp = new(TransferDetailEntity)
  98. err = core.UnMarshalResponse(result.Response, resp)
  99. if err != nil {
  100. return nil, result, err
  101. }
  102. // 对应答中隐私字段进行解密
  103. err = a.Client.DecryptResponse(ctx, resp)
  104. if err != nil {
  105. return resp, result, err
  106. }
  107. return resp, result, nil
  108. }