wechat.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. package gowechat
  2. import (
  3. "net/http"
  4. "sync"
  5. "github.com/astaxie/beego/cache"
  6. "github.com/yaotian/gowechat/mp/jssdk"
  7. "github.com/yaotian/gowechat/mp/material"
  8. "github.com/yaotian/gowechat/mp/menu"
  9. "github.com/yaotian/gowechat/mp/template"
  10. "github.com/yaotian/gowechat/mp/user"
  11. "github.com/yaotian/gowechat/server"
  12. "github.com/yaotian/gowechat/server/context"
  13. "github.com/yaotian/gowechat/server/oauth"
  14. "github.com/yaotian/gowechat/util"
  15. )
  16. // Wechat struct
  17. type Wechat struct {
  18. Context *context.Context
  19. }
  20. // Config for user
  21. type Config struct {
  22. AppID string
  23. AppSecret string
  24. Token string
  25. EncodingAESKey string
  26. Cache cache.Cache
  27. //证书
  28. SslCertFilePath string //证书文件的路径
  29. SslKeyFilePath string
  30. SslCertContent string //证书的内容
  31. SslKeyContent string
  32. }
  33. // NewWechat init
  34. func NewWechat(cfg *Config) *Wechat {
  35. context := new(context.Context)
  36. initContext(cfg, context)
  37. return &Wechat{context}
  38. }
  39. func initContext(cfg *Config, context *context.Context) {
  40. context.AppID = cfg.AppID
  41. context.AppSecret = cfg.AppSecret
  42. context.Token = cfg.Token
  43. context.EncodingAESKey = cfg.EncodingAESKey
  44. if cfg.Cache == nil {
  45. cfg.Cache, _ = cache.NewCache("memory", `{"interval":60}`)
  46. }
  47. context.SetAccessTokenLock(new(sync.RWMutex))
  48. context.SetJsAPITicketLock(new(sync.RWMutex))
  49. //create http client
  50. if cfg.SslCertFilePath != "" && cfg.SslKeyFilePath != "" {
  51. if client, err := util.NewTLSHttpClient(cfg.SslCertFilePath, cfg.SslKeyFilePath); err == nil {
  52. context.SHTTPClient = client
  53. }
  54. }
  55. if cfg.SslCertContent != "" && cfg.SslKeyContent != "" {
  56. if client, err := util.NewTLSHttpClientFromContent(cfg.SslCertContent, cfg.SslKeyContent); err == nil {
  57. context.SHTTPClient = client
  58. }
  59. }
  60. }
  61. // GetServer 消息管理
  62. func (wc *Wechat) GetServer(req *http.Request, writer http.ResponseWriter) *server.Server {
  63. wc.Context.Request = req
  64. wc.Context.Writer = writer
  65. return server.NewServer(wc.Context)
  66. }
  67. //GetAccessToken 获取access_token
  68. func (wc *Wechat) GetAccessToken() (string, error) {
  69. return wc.Context.GetAccessToken()
  70. }
  71. // GetOauth oauth2网页授权
  72. func (wc *Wechat) GetOauth() *oauth.Oauth {
  73. return oauth.NewOauth(wc.Context)
  74. }
  75. // GetMaterial 素材管理
  76. func (wc *Wechat) GetMaterial() *material.Material {
  77. return material.NewMaterial(wc.Context)
  78. }
  79. // GetJs js-sdk配置
  80. func (wc *Wechat) GetJs() *jssdk.Js {
  81. return jssdk.NewJs(wc.Context)
  82. }
  83. // GetMenu 菜单管理接口
  84. func (wc *Wechat) GetMenu() *menu.Menu {
  85. return menu.NewMenu(wc.Context)
  86. }
  87. // GetUser 用户管理接口
  88. func (wc *Wechat) GetUser() *user.User {
  89. return user.NewUser(wc.Context)
  90. }
  91. // GetTemplate 模板消息接口
  92. func (wc *Wechat) GetTemplate() *template.Template {
  93. return template.NewTemplate(wc.Context)
  94. }