-
Notifications
You must be signed in to change notification settings - Fork 0
/
token.api.go
89 lines (76 loc) · 2.08 KB
/
token.api.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// Code generated by protoc-gen-go_api(github.com/dev-openapi/protoc-gen-go_api version=v1.0.3). DO NOT EDIT.
// source: wx-miniprogram/token.proto
package wx_miniprogram
import (
context "context"
fmt "fmt"
io "io"
json "encoding/json"
bytes "bytes"
http "net/http"
strings "strings"
url "net/url"
multipart "mime/multipart"
)
// Reference imports to suppress errors if they are not otherwise used.
var _ = context.Background
var _ = http.NewRequest
var _ = io.Copy
var _ = bytes.Compare
var _ = json.Marshal
var _ = strings.Compare
var _ = fmt.Errorf
var _ = url.Parse
var _ = multipart.ErrMessageTooLarge
// Client API for Token service
type TokenService interface {
// GetAccessToken 获取接口调用凭据 https://developers.weixin.qq.com/miniprogram/dev/OpenApiDoc/mp-access-token/getAccessToken.html
GetAccessToken(ctx context.Context, in *GetAccessTokenReq, opts ...Option) (*GetAccessTokenRes, error)
}
type tokenService struct {
// opts
opts *Options
}
func NewTokenService(opts ...Option) TokenService {
opt := newOptions(opts...)
if len(opt.addr) <= 0 {
opt.addr = "https://api.weixin.qq.com"
}
return &tokenService {
opts: opt,
}
}
func (c *tokenService) GetAccessToken(ctx context.Context, in *GetAccessTokenReq, opts ...Option) (*GetAccessTokenRes, error) {
var res GetAccessTokenRes
// options
opt := buildOptions(c.opts, opts...)
headers := make(map[string]string)
// route
rawURL := fmt.Sprintf("%s/cgi-bin/token", opt.addr)
// body
req, err := http.NewRequest("GET", rawURL, nil)
if err != nil {
return nil, err
}
params := req.URL.Query()
if in.GetAppid() != "" {
params.Add("appid", fmt.Sprintf("%v", in.GetAppid()))
}
if in.GetGrantType() != "" {
params.Add("grant_type", fmt.Sprintf("%v", in.GetGrantType()))
}
if in.GetSecret() != "" {
params.Add("secret", fmt.Sprintf("%v", in.GetSecret()))
}
req.URL.RawQuery = params.Encode()
// header
for k, v := range headers {
req.Header.Set(k, v)
}
resp, err := opt.DoRequest(ctx, opt.client, req)
if err != nil {
return nil, err
}
err = opt.DoResponse(ctx, resp, &res)
return &res, err
}