
1package main
2
3import (
4 "demo/wxpay_utility"
5 "encoding/json"
6 "fmt"
7 "net/http"
8 "net/url"
9 "strings"
10 "time"
11)
12
13func main() {
14
15 config, err := wxpay_utility.CreateMchConfig(
16 "19xxxxxxxx",
17 "1DDE55AD98Exxxxxxxxxx",
18 "/path/to/apiclient_key.pem",
19 "PUB_KEY_ID_xxxxxxxxxxxxx",
20 "/path/to/wxp_pub.pem",
21 )
22 if err != nil {
23 fmt.Println(err)
24 return
25 }
26
27 request := &GetRequest{
28 OutAuthorizationNo: wxpay_utility.String("plfk2020042013"),
29 IsDisplayAuthorization: wxpay_utility.Bool(true),
30 }
31
32 response, err := Get(config, request)
33 if err != nil {
34 fmt.Printf("请求失败: %+v\n", err)
35
36 return
37 }
38
39
40 fmt.Printf("请求成功: %+v\n", response)
41}
42
43func Get(config *wxpay_utility.MchConfig, request *GetRequest) (response *UserConfirmAuthorizationEntity, err error) {
44 const (
45 host = "https://api.mch.weixin.qq.com"
46 method = "GET"
47 path = "/v3/fund-app/mch-transfer/user-confirm-authorization/out-authorization-no/{out_authorization_no}"
48 )
49
50 reqUrl, err := url.Parse(fmt.Sprintf("%s%s", host, path))
51 if err != nil {
52 return nil, err
53 }
54 reqUrl.Path = strings.Replace(reqUrl.Path, "{out_authorization_no}", url.PathEscape(*request.OutAuthorizationNo), -1)
55 query := reqUrl.Query()
56 if request.IsDisplayAuthorization != nil {
57 query.Add("is_display_authorization", fmt.Sprintf("%v", *request.IsDisplayAuthorization))
58 }
59 reqUrl.RawQuery = query.Encode()
60 httpRequest, err := http.NewRequest(method, reqUrl.String(), nil)
61 if err != nil {
62 return nil, err
63 }
64 httpRequest.Header.Set("Accept", "application/json")
65 httpRequest.Header.Set("Wechatpay-Serial", config.WechatPayPublicKeyId())
66 authorization, err := wxpay_utility.BuildAuthorization(config.MchId(), config.CertificateSerialNo(), config.PrivateKey(), method, reqUrl.RequestURI(), nil)
67 if err != nil {
68 return nil, err
69 }
70 httpRequest.Header.Set("Authorization", authorization)
71
72 client := &http.Client{}
73 httpResponse, err := client.Do(httpRequest)
74 if err != nil {
75 return nil, err
76 }
77 respBody, err := wxpay_utility.ExtractResponseBody(httpResponse)
78 if err != nil {
79 return nil, err
80 }
81 if httpResponse.StatusCode >= 200 && httpResponse.StatusCode < 300 {
82
83 err = wxpay_utility.ValidateResponse(
84 config.WechatPayPublicKeyId(),
85 config.WechatPayPublicKey(),
86 &httpResponse.Header,
87 respBody,
88 )
89 if err != nil {
90 return nil, err
91 }
92 response := &UserConfirmAuthorizationEntity{}
93 if err := json.Unmarshal(respBody, response); err != nil {
94 return nil, err
95 }
96
97 return response, nil
98 } else {
99 return nil, wxpay_utility.NewApiException(
100 httpResponse.StatusCode,
101 httpResponse.Header,
102 respBody,
103 )
104 }
105}
106
107type GetRequest struct {
108 OutAuthorizationNo *string `json:"out_authorization_no,omitempty"`
109 IsDisplayAuthorization *bool `json:"is_display_authorization,omitempty"`
110}
111
112func (o *GetRequest) MarshalJSON() ([]byte, error) {
113 type Alias GetRequest
114 a := &struct {
115 OutAuthorizationNo *string `json:"out_authorization_no,omitempty"`
116 IsDisplayAuthorization *bool `json:"is_display_authorization,omitempty"`
117 *Alias
118 }{
119
120 OutAuthorizationNo: nil,
121 IsDisplayAuthorization: nil,
122 Alias: (*Alias)(o),
123 }
124 return json.Marshal(a)
125}
126
127type UserConfirmAuthorizationEntity struct {
128 OutAuthorizationNo *string `json:"out_authorization_no,omitempty"`
129 Appid *string `json:"appid,omitempty"`
130 Openid *string `json:"openid,omitempty"`
131 UserDisplayName *string `json:"user_display_name,omitempty"`
132 AuthorizationId *string `json:"authorization_id,omitempty"`
133 State *AuthorizationState `json:"state,omitempty"`
134 AuthorizeTime *string `json:"authorize_time,omitempty"`
135 CloseInfo *UserConfirmAuthorizationCloseInfo `json:"close_info,omitempty"`
136 TransferSceneId *string `json:"transfer_scene_id,omitempty"`
137 UserRecvPerception *string `json:"user_recv_perception,omitempty"`
138 CreateTime *time.Time `json:"create_time,omitempty"`
139 PackageInfo *string `json:"package_info,omitempty"`
140}
141
142type AuthorizationState string
143
144func (e AuthorizationState) Ptr() *AuthorizationState {
145 return &e
146}
147
148const (
149 AUTHORIZATIONSTATE_TAKING_EFFECT AuthorizationState = "TAKING_EFFECT"
150 AUTHORIZATIONSTATE_CLOSED AuthorizationState = "CLOSED"
151 AUTHORIZATIONSTATE_WAIT_USER_CONFIRM AuthorizationState = "WAIT_USER_CONFIRM"
152)
153
154type UserConfirmAuthorizationCloseInfo struct {
155 CloseTime *string `json:"close_time,omitempty"`
156 CloseReason *CloseReason `json:"close_reason,omitempty"`
157}
158
159type CloseReason string
160
161func (e CloseReason) Ptr() *CloseReason {
162 return &e
163}
164
165const (
166 CLOSEREASON_CLOSE_VIA_MCH_API CloseReason = "CLOSE_VIA_MCH_API"
167 CLOSEREASON_USER_CLOSE CloseReason = "USER_CLOSE"
168 CLOSEREASON_USER_OVERDUE_UNCONFIRMED CloseReason = "USER_OVERDUE_UNCONFIRMED"
169 CLOSEREASON_TRANSFER_RISK CloseReason = "TRANSFER_RISK"
170 CLOSEREASON_USER_ACCOUNT_ABNORMAL CloseReason = "USER_ACCOUNT_ABNORMAL"
171)
172