api_authentications_example_test.go 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  1. // Copyright 2021 Tencent Inc. All rights reserved.
  2. //
  3. // 微工卡接口文档
  4. //
  5. // 服务商通过本API文档提供的接口,查询商户和微工卡的授权关系、生成预授权的token口令、核身预下单、核身结果的查询等。
  6. //
  7. // API version: 1.5.2
  8. // Code generated by WechatPay APIv3 Generator based on [OpenAPI Generator](https://openapi-generator.tech); DO NOT EDIT.
  9. package payrollcard_test
  10. import (
  11. "context"
  12. "log"
  13. "git.nanodreamtech.com/sg/wechatpay-go/core"
  14. "git.nanodreamtech.com/sg/wechatpay-go/core/option"
  15. "git.nanodreamtech.com/sg/wechatpay-go/services/payrollcard"
  16. "git.nanodreamtech.com/sg/wechatpay-go/utils"
  17. )
  18. func ExampleAuthenticationsApiService_GetAuthentication() {
  19. var (
  20. mchID string = "190000****" // 商户号
  21. mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
  22. mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
  23. )
  24. // 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
  25. mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
  26. if err != nil {
  27. log.Printf("load merchant private key error:%s", err)
  28. return
  29. }
  30. ctx := context.Background()
  31. // 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
  32. opts := []core.ClientOption{
  33. option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
  34. }
  35. client, err := core.NewClient(ctx, opts...)
  36. if err != nil {
  37. log.Printf("new wechat pay client err:%s", err)
  38. return
  39. }
  40. svc := payrollcard.AuthenticationsApiService{Client: client}
  41. resp, result, err := svc.GetAuthentication(ctx,
  42. payrollcard.GetAuthenticationRequest{
  43. SubMchid: core.String("1111111"),
  44. AuthenticateNumber: core.String("mcdhehfgisdhfjghed39384564i83"),
  45. },
  46. )
  47. if err != nil {
  48. // 处理错误
  49. log.Printf("call GetAuthentication err:%s", err)
  50. } else {
  51. // 处理返回结果
  52. log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
  53. }
  54. }
  55. func ExampleAuthenticationsApiService_ListAuthentications() {
  56. var (
  57. mchID string = "190000****" // 商户号
  58. mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
  59. mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
  60. )
  61. // 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
  62. mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
  63. if err != nil {
  64. log.Printf("load merchant private key error:%s", err)
  65. return
  66. }
  67. ctx := context.Background()
  68. // 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
  69. opts := []core.ClientOption{
  70. option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
  71. }
  72. client, err := core.NewClient(ctx, opts...)
  73. if err != nil {
  74. log.Printf("new wechat pay client err:%s", err)
  75. return
  76. }
  77. svc := payrollcard.AuthenticationsApiService{Client: client}
  78. resp, result, err := svc.ListAuthentications(ctx,
  79. payrollcard.ListAuthenticationsRequest{
  80. Openid: core.String("onqOjjmo8wmTOOtSKwXtGjg9Gb58"),
  81. Appid: core.String("wxa1111111"),
  82. SubAppid: core.String("wxa1111111"),
  83. SubMchid: core.String("1111111"),
  84. AuthenticateDate: core.String("2020-12-25"),
  85. AuthenticateState: core.String("AUTHENTICATE_SUCCESS"),
  86. Offset: core.Int64(0),
  87. Limit: core.Int64(10),
  88. },
  89. )
  90. if err != nil {
  91. // 处理错误
  92. log.Printf("call ListAuthentications err:%s", err)
  93. } else {
  94. // 处理返回结果
  95. log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
  96. }
  97. }
  98. func ExampleAuthenticationsApiService_PreOrderAuthentication() {
  99. var (
  100. mchID string = "190000****" // 商户号
  101. mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
  102. mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
  103. )
  104. // 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
  105. mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
  106. if err != nil {
  107. log.Printf("load merchant private key error:%s", err)
  108. return
  109. }
  110. ctx := context.Background()
  111. // 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
  112. opts := []core.ClientOption{
  113. option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
  114. }
  115. client, err := core.NewClient(ctx, opts...)
  116. if err != nil {
  117. log.Printf("new wechat pay client err:%s", err)
  118. return
  119. }
  120. svc := payrollcard.AuthenticationsApiService{Client: client}
  121. resp, result, err := svc.PreOrderAuthentication(ctx,
  122. payrollcard.PreOrderAuthenticationRequest{
  123. Openid: core.String("onqOjjmo8wmTOOtSKwXtGjg9Gb58"),
  124. Appid: core.String("wxa1111111"),
  125. SubMchid: core.String("1111111"),
  126. SubAppid: core.String("wxa1111111"),
  127. AuthenticateNumber: core.String("mcdhehfgisdhfjghed39384564i83"),
  128. ProjectName: core.String("某项目"),
  129. EmployerName: core.String("某用工企业"),
  130. AuthenticateType: payrollcard.AUTHENTICATIONTYPE_NORMAL.Ptr(),
  131. },
  132. )
  133. if err != nil {
  134. // 处理错误
  135. log.Printf("call PreOrderAuthentication err:%s", err)
  136. } else {
  137. // 处理返回结果
  138. log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
  139. }
  140. }
  141. func ExampleAuthenticationsApiService_PreOrderAuthenticationWithAuth() {
  142. var (
  143. mchID string = "190000****" // 商户号
  144. mchCertificateSerialNumber string = "3775************************************" // 商户证书序列号
  145. mchAPIv3Key string = "2ab9****************************" // 商户APIv3密钥
  146. )
  147. // 使用 utils 提供的函数从本地文件中加载商户私钥,商户私钥会用来生成请求的签名
  148. mchPrivateKey, err := utils.LoadPrivateKeyWithPath("/path/to/merchant/apiclient_key.pem")
  149. if err != nil {
  150. log.Printf("load merchant private key error:%s", err)
  151. return
  152. }
  153. ctx := context.Background()
  154. // 使用商户私钥等初始化 client,并使它具有自动定时获取微信支付平台证书的能力
  155. opts := []core.ClientOption{
  156. option.WithWechatPayAutoAuthCipher(mchID, mchCertificateSerialNumber, mchPrivateKey, mchAPIv3Key),
  157. }
  158. client, err := core.NewClient(ctx, opts...)
  159. if err != nil {
  160. log.Printf("new wechat pay client err:%s", err)
  161. return
  162. }
  163. svc := payrollcard.AuthenticationsApiService{Client: client}
  164. resp, result, err := svc.PreOrderAuthenticationWithAuth(ctx,
  165. payrollcard.PreOrderAuthenticationWithAuthRequest{
  166. Openid: core.String("onqOjjmo8wmTOOtSKwXtGjg9Gb58"),
  167. Appid: core.String("wxa1111111"),
  168. SubMchid: core.String("1111111"),
  169. SubAppid: core.String("wxa1111111"),
  170. AuthenticateNumber: core.String("mcdhehfgisdhfjghed39384564i83"),
  171. ProjectName: core.String("某项目"),
  172. EmployerName: core.String("某用工企业"),
  173. UserName: core.String("LP7bT4hQXUsOZCEvK2YrSiqFsnP0oRMfeoLN0vBg"),
  174. IdCardNumber: core.String("7FzH5XksJG3a8HLLsaaUV6K54y1OnPMY5"),
  175. EmploymentType: payrollcard.EMPLOYMENTTYPE_LONG_TERM_EMPLOYMENT.Ptr(),
  176. AuthenticateType: payrollcard.AUTHENTICATIONTYPE_NORMAL.Ptr(),
  177. },
  178. )
  179. if err != nil {
  180. // 处理错误
  181. log.Printf("call PreOrderAuthenticationWithAuth err:%s", err)
  182. } else {
  183. // 处理返回结果
  184. log.Printf("status=%d resp=%s", result.Response.StatusCode, resp)
  185. }
  186. }