session.go 1.4 KB

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