token.go 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. package dao
  2. import (
  3. "context"
  4. "database/sql"
  5. "encoding/hex"
  6. "fmt"
  7. "time"
  8. "go-common/app/job/main/passport-auth/model"
  9. "go-common/library/log"
  10. )
  11. const (
  12. _addTokenSQL = "INSERT IGNORE INTO user_token_%s (mid,appid,token,expires,type) VALUES (?,?,?,?,?)"
  13. _delTokenSQL = "DELETE FROM user_token_%s where token = ?"
  14. _addTokenDeletedSQL = "INSERT IGNORE INTO user_token_deleted_%s (mid,appid,token,expires,type,ctime) VALUES (?,?,?,?,?,?)"
  15. )
  16. // AddToken save token
  17. func (d *Dao) AddToken(c context.Context, t *model.Token, token []byte, ct time.Time) (affected int64, err error) {
  18. var row sql.Result
  19. if row, err = d.db.Exec(c, fmt.Sprintf(_addTokenSQL, formatSuffix(ct)), t.Mid, t.AppID, token, t.Expires, t.Type); err != nil {
  20. log.Error("d.AddToken(%v) err(%v)", t, err)
  21. return
  22. }
  23. return row.RowsAffected()
  24. }
  25. // DelToken del token
  26. func (d *Dao) DelToken(c context.Context, token []byte, ct time.Time) (affected int64, err error) {
  27. var res sql.Result
  28. if res, err = d.db.Exec(c, fmt.Sprintf(_delTokenSQL, formatSuffix(ct)), token); err != nil {
  29. log.Error("del token failed, dao.db.Exec(%s) error(%v)", hex.EncodeToString(token), err)
  30. return
  31. }
  32. return res.RowsAffected()
  33. }
  34. // AddTokenDeleted save token deleted
  35. func (d *Dao) AddTokenDeleted(c context.Context, t *model.Token, token []byte, ct time.Time) (affected int64, err error) {
  36. row, err := d.db.Exec(c, fmt.Sprintf(_addTokenDeletedSQL, formatSuffix(ct)), t.Mid, t.AppID, token, t.Expires, t.Type, t.Ctime)
  37. if err != nil {
  38. log.Error("fail to add token deleted, token(%+v), tx.Exec() error(%+v)", t, err)
  39. return
  40. }
  41. return row.RowsAffected()
  42. }
  43. func formatSuffix(t time.Time) string {
  44. return t.Format("200601")
  45. }