session.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. package models
  2. import (
  3. "github.com/beego/beego/v2/client/orm"
  4. "time"
  5. )
  6. func GetSessionByToken(token string) (item *CygxXzsSession, err error) {
  7. sql := `SELECT * FROM cygx_xzs_session WHERE access_token=? AND expire_time> NOW() ORDER BY session_id DESC LIMIT 1 `
  8. o := orm.NewOrm()
  9. err = o.Raw(sql, token).QueryRow(&item)
  10. return
  11. }
  12. type CygxXzsSession struct {
  13. SessionId int `orm:"column(session_id);pk"`
  14. UnionId string
  15. UserId int
  16. OpenId string
  17. AccessToken string
  18. ExpireTime time.Time
  19. CreatedTime time.Time
  20. LastUpdatedTime time.Time
  21. }
  22. //添加用户session信息
  23. func AddCygxXzsSession(item *CygxXzsSession) (err error) {
  24. o := orm.NewOrm()
  25. _, err = o.Insert(item)
  26. return
  27. }
  28. func GetXzsSessionCountByToken(token string) (count int, err error) {
  29. sql := `SELECT COUNT(1) AS count FROM cygx_xzs_session WHERE access_token=? LIMIT 1 `
  30. o := orm.NewOrm()
  31. err = o.Raw(sql, token).QueryRow(&count)
  32. return
  33. }
  34. //获取用户token详情
  35. func GetUnionidByToken(token string) (item *CygxXzsSession, err error) {
  36. sql := `SELECT * FROM cygx_xzs_session WHERE access_token=? LIMIT 1 `
  37. o := orm.NewOrm()
  38. err = o.Raw(sql, token).QueryRow(&item)
  39. return
  40. }
  41. //根据用户openid获取token
  42. func GetTokenByOpenId(openId string) (item *CygxXzsSession, err error) {
  43. sql := `SELECT * FROM cygx_xzs_session WHERE open_id=? AND expire_time> NOW() ORDER BY session_id DESC LIMIT 1 `
  44. o := orm.NewOrm()
  45. err = o.Raw(sql, openId).QueryRow(&item)
  46. return
  47. }