wechat.go 3.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. package models
  2. import (
  3. "time"
  4. "wechat-conf/models/model"
  5. "wechat-conf/utils"
  6. "github.com/astaxie/beego"
  7. )
  8. // ComponentInit 初始化第三方
  9. func ComponentInit() {
  10. var conf = model.SysComponentConf{}
  11. _, err := DBEngine.Get(&conf)
  12. if err != nil {
  13. utils.LogError("初始化第三方失败:", err)
  14. return
  15. }
  16. utils.LogError("获取第三方信息:", conf)
  17. if conf.Appid == "" {
  18. utils.LogError("初始化第三方数据失败,数据为空")
  19. return
  20. }
  21. d := "0"
  22. if !conf.ExpiresDate.IsZero() {
  23. now := time.Now()
  24. subd := conf.ExpiresDate.Sub(now)
  25. beego.Error(d)
  26. d = string(subd)
  27. }
  28. beego.Error("过期时间:", d)
  29. var cert = map[string]string{
  30. "appid": conf.Appid,
  31. "aeskey": conf.Aeskey,
  32. "secret": conf.Secret,
  33. "componentVerifyTicket": conf.Ticket,
  34. "token": conf.Token,
  35. "expires_in": d,
  36. }
  37. utils.ComponentInit(cert, UpdateComponentToken)
  38. }
  39. // UpdateComponentToken 更新第三方token
  40. func UpdateComponentToken(token map[string]interface{}) {
  41. beego.Error("更新第三方token:", token)
  42. if token["accessToken"].(string) == "" {
  43. return
  44. }
  45. var conf = model.SysComponentConf{
  46. Token: token["accessToken"].(string),
  47. }
  48. expire := token["expire_in"].(int64)
  49. if expire > 0 {
  50. beego.Error(time.Now())
  51. expriesTime := time.Now().Local().Add(time.Duration(expire) * time.Second)
  52. beego.Error(expriesTime)
  53. conf.ExpiresDate = expriesTime
  54. sql := `update sys_component_conf set token=?,expires_date=?`
  55. _, err := DBEngine.Exec(sql, conf.Token, conf.ExpiresDate)
  56. if err != nil {
  57. utils.LogError("更新第三方token失败:", err)
  58. }
  59. } else {
  60. sql := `update sys_component_conf set token=?`
  61. _, err := DBEngine.Exec(sql, conf.Token, conf.ExpiresDate)
  62. if err != nil {
  63. utils.LogError("更新第三方token失败:", err)
  64. }
  65. }
  66. }
  67. // InitWechat 初始化微信
  68. func InitWechat() {
  69. var wxconfs []model.SysWechatConf
  70. err := DBEngine.Where("status=1").Find(&wxconfs)
  71. if err != nil {
  72. utils.LogError("初始化微信失败:", err)
  73. return
  74. }
  75. for _, conf := range wxconfs {
  76. var cert = map[string]string{
  77. "authorizer_access_token": conf.Token,
  78. "authorizer_refresh_token": conf.RefreshToken,
  79. "authorization_code": conf.AuthorizationCode,
  80. "appid": conf.Appid,
  81. }
  82. client := utils.WechatInit(cert, UpdateToken)
  83. utils.AppendWxClient(client)
  84. }
  85. }
  86. // UpdateToken 更新微信token
  87. func UpdateToken(token map[string]interface{}) {
  88. var conf = model.SysWechatConf{
  89. Token: token["token"].(string),
  90. RefreshToken: token["refreshToken"].(string),
  91. Appid: token["appid"].(string),
  92. }
  93. expire := token["expire_in"].(int64)
  94. if expire > 0 {
  95. beego.Error(time.Now())
  96. expriesTime := time.Now().Local().Add(time.Duration(expire) * time.Second)
  97. beego.Error(expriesTime)
  98. conf.ExpiresDate = expriesTime
  99. sql := `update sys_wechat_conf set token=?,refresh_token=?,expires_date=? where appid=?`
  100. _, err := DBEngine.Exec(sql, conf.Token, conf.RefreshToken, expriesTime, conf.Appid)
  101. if err != nil {
  102. utils.LogError("更新微信token失败:", err)
  103. }
  104. } else {
  105. sql := `update sys_wechat_conf set token=?,refresh_token=? where appid=?`
  106. _, err := DBEngine.Exec(sql, conf.Token, conf.RefreshToken, conf.Appid)
  107. if err != nil {
  108. utils.LogError("更新微信token失败:", err)
  109. }
  110. }
  111. }