mini.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. package wechat
  2. import (
  3. "encoding/json"
  4. "net/url"
  5. "time"
  6. "git.chuangxin1.com/cx/myth"
  7. "git.chuangxin1.com/cx/myth/cache"
  8. )
  9. func keyMini(appid string) string {
  10. return "wechat:mini:client:" + appid
  11. }
  12. func keyMiniToken(appid string) string {
  13. return "wechat:mini:client:token:" + appid
  14. }
  15. // NewMiniClient new mini client
  16. func NewMiniClient(appID, appSecret string) *MiniClient {
  17. key := keyMini(appID)
  18. if v, ok := memcache.Load(key); ok {
  19. return v.(*MiniClient)
  20. }
  21. c := &MiniClient{AppID: appID, AppSecret: appSecret}
  22. memcache.Store(key, c)
  23. return c
  24. }
  25. // GetMiniOpenID get openid by code
  26. func (mc *MiniClient) GetMiniOpenID(frm FormCode) (s MiniSession, err error) {
  27. uri := BaseURL + "/sns/jscode2session?"
  28. args := url.Values{}
  29. args.Add("grant_type", "authorization_code")
  30. args.Add("appid", mc.AppID)
  31. args.Add("secret", mc.AppSecret)
  32. args.Add("js_code", frm.Code)
  33. uri += args.Encode()
  34. var jq *myth.JSONQuery
  35. if jq, err = getJSON(uri); err == nil {
  36. s.OpenID, err = jq.String(`openid`)
  37. s.SessionKey, _ = jq.String(`session_key`)
  38. s.UnionID, _ = jq.String(`unionid`)
  39. }
  40. return
  41. }
  42. // getToken get token
  43. func (mc *MiniClient) getToken() (token string, err error) {
  44. /*
  45. now := time.Now().Unix()
  46. if mc.LastTokenTime > 0 {
  47. if now-mc.LastTokenTime < TokenExpires {
  48. token = mc.AccessToken
  49. return
  50. }
  51. }
  52. // */
  53. key := keyMiniToken(mc.AppID)
  54. var ct ClientToken
  55. s := ``
  56. s, err = cache.Get(key)
  57. if err != nil {
  58. return
  59. }
  60. err = json.Unmarshal([]byte(s), &ct)
  61. if err != nil {
  62. return
  63. }
  64. now := time.Now().Unix()
  65. if mc.LastTokenTime > 0 {
  66. if now-mc.LastTokenTime < TokenExpires {
  67. token = mc.AccessToken
  68. return
  69. }
  70. }
  71. uri := BaseURL + "/cgi-bin/token?"
  72. args := url.Values{}
  73. args.Add("grant_type", "client_credential")
  74. args.Add("appid", mc.AppID)
  75. args.Add("secret", mc.AppSecret)
  76. uri += args.Encode()
  77. var jq *myth.JSONQuery
  78. if jq, err = getJSON(uri); err == nil {
  79. mc.LastTokenTime = now
  80. mc.AccessToken, err = jq.String(`access_token`)
  81. token = mc.AccessToken
  82. k := keyMini(mc.AppID)
  83. memcache.Store(k, mc)
  84. ct := ClientToken{AppID: mc.AppID, AccessToken: mc.AccessToken, LastTokenTime: now}
  85. bs, _ := json.Marshal(ct)
  86. cache.Set(key, string(bs), 0)
  87. }
  88. return
  89. }
  90. // TemplateList /cgi-bin/wxopen/template/list
  91. func (mc *MiniClient) TemplateList(offset, count int) (body []byte, err error) {
  92. uri := BaseURL + "/cgi-bin/wxopen/template/list?"
  93. if mc.AccessToken, err = mc.getToken(); err != nil {
  94. return
  95. }
  96. args := url.Values{}
  97. args.Add("access_token", mc.AccessToken)
  98. uri += args.Encode()
  99. params := make(map[string]interface{})
  100. params["offset"] = offset
  101. params["count"] = count
  102. var msg myth.HTTPMessage
  103. msg, err = postJSON(uri, params)
  104. if err == nil {
  105. body = msg.Body
  106. }
  107. /*
  108. data, err := json.Marshal(params)
  109. if err != nil {
  110. return
  111. }
  112. body, err = postJSONBody(uri, data)
  113. // */
  114. return
  115. }
  116. // TemplateSend /cgi-bin/message/wxopen/template/send
  117. func (mc *MiniClient) TemplateSend(template MiniTemplateMessage) (jq *myth.JSONQuery, err error) {
  118. uri := BaseURL + "/cgi-bin/message/wxopen/template/send?"
  119. if mc.AccessToken, err = mc.getToken(); err != nil {
  120. return
  121. }
  122. args := url.Values{}
  123. args.Add("access_token", mc.AccessToken)
  124. uri += args.Encode()
  125. var msg myth.HTTPMessage
  126. msg, err = postJSON(uri, template)
  127. if err == nil {
  128. jq, err = msg.JSONQuery()
  129. }
  130. return
  131. }
  132. // UniformSend /cgi-bin/message/wxopen/template/uniform_send
  133. func (mc *MiniClient) UniformSend(template MiniUniformMessage) (jq *myth.JSONQuery, err error) {
  134. uri := BaseURL + "/cgi-bin/message/wxopen/template/uniform_send?"
  135. if mc.AccessToken, err = mc.getToken(); err != nil {
  136. return
  137. }
  138. args := url.Values{}
  139. args.Add("access_token", mc.AccessToken)
  140. uri += args.Encode()
  141. var msg myth.HTTPMessage
  142. msg, err = postJSON(uri, template)
  143. if err == nil {
  144. jq, err = msg.JSONQuery()
  145. }
  146. return
  147. }