api_subsidy.go 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  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.11
  8. // Code generated by WechatPay APIv3 Generator based on [OpenAPI Generator](https://openapi-generator.tech); DO NOT EDIT.
  9. package merchantexclusivecoupon
  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 SubsidyApiService services.Service
  21. // PayReceiptInfo 查询商家券营销补差付款单详情
  22. //
  23. // 查询商家券营销补差付款单详情
  24. func (a *SubsidyApiService) PayReceiptInfo(ctx context.Context, req PayReceiptInfoRequest) (resp *SubsidyPayReceipt, 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.SubsidyReceiptId == nil {
  33. return nil, nil, fmt.Errorf("field `SubsidyReceiptId` is required and must be specified in PayReceiptInfoRequest")
  34. }
  35. localVarPath := consts.WechatPayAPIServer + "/v3/marketing/busifavor/subsidy/pay-receipts/{subsidy_receipt_id}"
  36. // Build Path with Path Params
  37. localVarPath = strings.Replace(localVarPath, "{"+"subsidy_receipt_id"+"}", neturl.PathEscape(core.ParameterToString(*req.SubsidyReceiptId, "")), -1)
  38. // Make sure All Required Params are properly set
  39. // Determine the Content-Type Header
  40. localVarHTTPContentTypes := []string{}
  41. // Setup Content-Type
  42. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  43. // Perform Http Request
  44. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  45. if err != nil {
  46. return nil, result, err
  47. }
  48. // Extract SubsidyPayReceipt from Http Response
  49. resp = new(SubsidyPayReceipt)
  50. err = core.UnMarshalResponse(result.Response, resp)
  51. if err != nil {
  52. return nil, result, err
  53. }
  54. return resp, result, nil
  55. }
  56. // PayReceiptList 查询商家券营销补差付款单列表
  57. //
  58. // 查询商家券营销补差付款单列表
  59. func (a *SubsidyApiService) PayReceiptList(ctx context.Context, req PayReceiptListRequest) (resp *SubsidyPayReceiptListResponse, result *core.APIResult, err error) {
  60. var (
  61. localVarHTTPMethod = nethttp.MethodGet
  62. localVarPostBody interface{}
  63. localVarQueryParams neturl.Values
  64. localVarHeaderParams = nethttp.Header{}
  65. )
  66. localVarPath := consts.WechatPayAPIServer + "/v3/marketing/busifavor/subsidy/pay-receipts"
  67. // Make sure All Required Params are properly set
  68. if req.StockId == nil {
  69. return nil, nil, fmt.Errorf("field `StockId` is required and must be specified in PayReceiptListRequest")
  70. }
  71. if req.CouponCode == nil {
  72. return nil, nil, fmt.Errorf("field `CouponCode` is required and must be specified in PayReceiptListRequest")
  73. }
  74. // Setup Query Params
  75. localVarQueryParams = neturl.Values{}
  76. localVarQueryParams.Add("stock_id", core.ParameterToString(*req.StockId, ""))
  77. localVarQueryParams.Add("coupon_code", core.ParameterToString(*req.CouponCode, ""))
  78. if req.OutSubsidyNo != nil {
  79. localVarQueryParams.Add("out_subsidy_no", core.ParameterToString(*req.OutSubsidyNo, ""))
  80. }
  81. // Determine the Content-Type Header
  82. localVarHTTPContentTypes := []string{}
  83. // Setup Content-Type
  84. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  85. // Perform Http Request
  86. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  87. if err != nil {
  88. return nil, result, err
  89. }
  90. // Extract SubsidyPayReceiptListResponse from Http Response
  91. resp = new(SubsidyPayReceiptListResponse)
  92. err = core.UnMarshalResponse(result.Response, resp)
  93. if err != nil {
  94. return nil, result, err
  95. }
  96. return resp, result, nil
  97. }
  98. // ReturnReceiptInfo 查询商家券营销补差回退单详情
  99. //
  100. // 查询商家券营销补差回退单详情
  101. func (a *SubsidyApiService) ReturnReceiptInfo(ctx context.Context, req ReturnReceiptInfoRequest) (resp *SubsidyReturnReceipt, result *core.APIResult, err error) {
  102. var (
  103. localVarHTTPMethod = nethttp.MethodGet
  104. localVarPostBody interface{}
  105. localVarQueryParams neturl.Values
  106. localVarHeaderParams = nethttp.Header{}
  107. )
  108. // Make sure Path Params are properly set
  109. if req.SubsidyReturnReceiptId == nil {
  110. return nil, nil, fmt.Errorf("field `SubsidyReturnReceiptId` is required and must be specified in ReturnReceiptInfoRequest")
  111. }
  112. localVarPath := consts.WechatPayAPIServer + "/v3/marketing/busifavor/subsidy/return-receipts/{subsidy_return_receipt_id}"
  113. // Build Path with Path Params
  114. localVarPath = strings.Replace(localVarPath, "{"+"subsidy_return_receipt_id"+"}", neturl.PathEscape(core.ParameterToString(*req.SubsidyReturnReceiptId, "")), -1)
  115. // Make sure All Required Params are properly set
  116. // Determine the Content-Type Header
  117. localVarHTTPContentTypes := []string{}
  118. // Setup Content-Type
  119. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  120. // Perform Http Request
  121. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  122. if err != nil {
  123. return nil, result, err
  124. }
  125. // Extract SubsidyReturnReceipt from Http Response
  126. resp = new(SubsidyReturnReceipt)
  127. err = core.UnMarshalResponse(result.Response, resp)
  128. if err != nil {
  129. return nil, result, err
  130. }
  131. return resp, result, nil
  132. }
  133. // SubsidyPay 商家券营销补差付款
  134. //
  135. // 适用接口场景:服务商/商圈给核销了商家券的商户做营销资金补差;
  136. // 接口适用对象:普通服务商、普通直连商户、渠道商;
  137. // 前置条件:商家必须核销了商家券且发起了微信支付收款;
  138. // 是否支持幂等:是;
  139. func (a *SubsidyApiService) SubsidyPay(ctx context.Context, req SubsidyPayRequest) (resp *SubsidyPayReceipt, result *core.APIResult, err error) {
  140. var (
  141. localVarHTTPMethod = nethttp.MethodPost
  142. localVarPostBody interface{}
  143. localVarQueryParams neturl.Values
  144. localVarHeaderParams = nethttp.Header{}
  145. )
  146. localVarPath := consts.WechatPayAPIServer + "/v3/marketing/busifavor/subsidy/pay-receipts"
  147. // Make sure All Required Params are properly set
  148. // Setup Body Params
  149. localVarPostBody = req
  150. // Determine the Content-Type Header
  151. localVarHTTPContentTypes := []string{"application/json"}
  152. // Setup Content-Type
  153. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  154. // Perform Http Request
  155. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  156. if err != nil {
  157. return nil, result, err
  158. }
  159. // Extract SubsidyPayReceipt from Http Response
  160. resp = new(SubsidyPayReceipt)
  161. err = core.UnMarshalResponse(result.Response, resp)
  162. if err != nil {
  163. return nil, result, err
  164. }
  165. return resp, result, nil
  166. }
  167. // SubsidyReturn 商家券营销补差回退
  168. //
  169. // 适用接口场景:服务商通过该接口可回退补差款;
  170. // 接口适用对象:普通服务商、普通直连商户、渠道商;
  171. // 前置条件:进行补差的微信支付订单发起了退款,且回退金额不得超过补差金额;
  172. // 是否支持幂等:是;
  173. func (a *SubsidyApiService) SubsidyReturn(ctx context.Context, req SubsidyReturnRequest) (resp *SubsidyReturnReceipt, result *core.APIResult, err error) {
  174. var (
  175. localVarHTTPMethod = nethttp.MethodPost
  176. localVarPostBody interface{}
  177. localVarQueryParams neturl.Values
  178. localVarHeaderParams = nethttp.Header{}
  179. )
  180. localVarPath := consts.WechatPayAPIServer + "/v3/marketing/busifavor/subsidy/return-receipts"
  181. // Make sure All Required Params are properly set
  182. // Setup Body Params
  183. localVarPostBody = req
  184. // Determine the Content-Type Header
  185. localVarHTTPContentTypes := []string{"application/json"}
  186. // Setup Content-Type
  187. localVarHTTPContentType := core.SelectHeaderContentType(localVarHTTPContentTypes)
  188. // Perform Http Request
  189. result, err = a.Client.Request(ctx, localVarHTTPMethod, localVarPath, localVarHeaderParams, localVarQueryParams, localVarPostBody, localVarHTTPContentType)
  190. if err != nil {
  191. return nil, result, err
  192. }
  193. // Extract SubsidyReturnReceipt from Http Response
  194. resp = new(SubsidyReturnReceipt)
  195. err = core.UnMarshalResponse(result.Response, resp)
  196. if err != nil {
  197. return nil, result, err
  198. }
  199. return resp, result, nil
  200. }