h5_admin_session.go 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package h5_admin_session
  2. import (
  3. "rdluck_tools/orm"
  4. "time"
  5. )
  6. type H5AdminSession struct {
  7. SessionId int `orm:"column(session_id);pk";json:"session_id"`
  8. AdminId int `orm:"column(admin_id);" json:"admin_id"` // 后台管理员id
  9. OpenId string `orm:"column(open_id);" json:"open_id"` // 第三方openid(微信等)
  10. AccessToken string `orm:"column(access_token);" json:"access_token"`
  11. ExpireTime time.Time `orm:"column(expire_time);" json:"expire_time"` // 过期时间
  12. CreatedTime time.Time `orm:"column(created_time);" json:"created_time"` // 创建时间
  13. LastUpdatedTime time.Time `orm:"column(last_updated_time);" json:"last_updated_time"`
  14. }
  15. func GetSessionByToken(token string) (item *H5AdminSession, err error) {
  16. sql := `SELECT * FROM h5_admin_session WHERE access_token=? AND expire_time> NOW() ORDER BY session_id DESC LIMIT 1 `
  17. o := orm.NewOrm()
  18. o.Using("rddp")
  19. err = o.Raw(sql, token).QueryRow(&item)
  20. return
  21. }
  22. func GetSessionCountByToken(token string) (count int, err error) {
  23. sql := `SELECT COUNT(1) AS count FROM h5_admin_session WHERE access_token=? AND expire_time> NOW() ORDER BY session_id DESC LIMIT 1 `
  24. o := orm.NewOrm()
  25. o.Using("rddp")
  26. err = o.Raw(sql, token).QueryRow(&count)
  27. return
  28. }
  29. //添加用户session信息
  30. func AddSession(item *H5AdminSession) (err error) {
  31. o := orm.NewOrm()
  32. o.Using("rddp")
  33. _, err = o.Insert(item)
  34. return
  35. }
  36. func GetTokenByUid(adminId int) (item *H5AdminSession, err error) {
  37. sql := `SELECT * FROM h5_admin_session WHERE admin_id=? AND expire_time> NOW() ORDER BY session_id DESC LIMIT 1 `
  38. o := orm.NewOrm()
  39. o.Using("rddp")
  40. err = o.Raw(sql, adminId).QueryRow(&item)
  41. return
  42. }
  43. //根据用户id获取token
  44. func GetTokenByOpenId(openId string) (item *H5AdminSession, err error) {
  45. sql := `SELECT * FROM h5_admin_session WHERE open_id=? AND expire_time> NOW() ORDER BY session_id DESC LIMIT 1 `
  46. o := orm.NewOrm()
  47. o.Using("rddp")
  48. err = o.Raw(sql, openId).QueryRow(&item)
  49. return
  50. }
  51. //更新session
  52. func UpdateSession(sessionId, adminId int, expireTime time.Time) (err error) {
  53. sql := `update h5_admin_session set admin_id=?,expire_time=? where session_id = ? `
  54. o := orm.NewOrm()
  55. _, err = o.Raw(sql, adminId, expireTime, sessionId).Exec()
  56. return
  57. }