check_token_logic.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. package token
  2. import (
  3. "context"
  4. "crypto/md5"
  5. "encoding/hex"
  6. "io"
  7. "strconv"
  8. "time"
  9. "wechat-api/ent"
  10. "wechat-api/ent/agent"
  11. "wechat-api/ent/token"
  12. "wechat-api/internal/utils/dberrorhandler"
  13. "wechat-api/internal/svc"
  14. "wechat-api/internal/types"
  15. "github.com/zeromicro/go-zero/core/logx"
  16. )
  17. type CheckTokenLogic struct {
  18. logx.Logger
  19. ctx context.Context
  20. svcCtx *svc.ServiceContext
  21. }
  22. func NewCheckTokenLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CheckTokenLogic {
  23. return &CheckTokenLogic{
  24. Logger: logx.WithContext(ctx),
  25. ctx: ctx,
  26. svcCtx: svcCtx}
  27. }
  28. func (l *CheckTokenLogic) CheckToken(req *types.CheckTokenReq) (resp *types.CheckTokenResp, err error) {
  29. var (
  30. valid bool
  31. sign string
  32. )
  33. timestamp := time.Now().Unix()
  34. tokenItem, err := l.svcCtx.DB.Token.Query().Where(token.TokenEQ(*req.Token)).Limit(1).Only(l.ctx)
  35. if err != nil && !ent.IsNotFound(err) {
  36. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  37. }
  38. var agentInfo types.AgentInfo
  39. var customAgentBase string
  40. var customAgentKey string
  41. var openaiBase string
  42. var openaiKey string
  43. if tokenItem == nil { // 判断Token是否存在
  44. valid = false
  45. } else if tokenItem.ExpireAt.Unix() > timestamp { // 判断Token是否过期
  46. if tokenItem.MAC == "" { // 判断MAC是否存在,如果不存咋则说明是第一次激活该Token
  47. valid = true
  48. err = l.svcCtx.DB.Token.UpdateOneID(tokenItem.ID).SetNotNilMAC(req.Mac).Exec(l.ctx)
  49. if err != nil {
  50. return nil, dberrorhandler.DefaultEntError(l.Logger, err, req)
  51. }
  52. } else if tokenItem.MAC != *req.Mac { // 如果Mac地址不匹配说明该请求不合法
  53. valid = false
  54. } else { // 这是正常验证,返回OK
  55. valid = true
  56. }
  57. if valid {
  58. sign = generateSign(*req.Token, *req.Mac, strconv.Itoa(int(timestamp)))
  59. }
  60. }
  61. if valid {
  62. customAgentBase = tokenItem.CustomAgentBase
  63. customAgentKey = tokenItem.CustomAgentKey
  64. openaiBase = tokenItem.OpenaiBase
  65. openaiKey = tokenItem.OpenaiKey
  66. if tokenItem.AgentID == 0 {
  67. agentInfo = types.AgentInfo{
  68. BaseIDInfo: types.BaseIDInfo{
  69. Id: &tokenItem.AgentID,
  70. },
  71. }
  72. } else {
  73. data, _ := l.svcCtx.DB.Agent.Query().Where(agent.ID(tokenItem.AgentID)).First(l.ctx)
  74. if data != nil {
  75. agentInfo = types.AgentInfo{
  76. BaseIDInfo: types.BaseIDInfo{
  77. Id: &data.ID,
  78. },
  79. Name: &data.Name,
  80. Role: &data.Role,
  81. Background: &data.Background,
  82. Examples: &data.Examples,
  83. DatasetId: &data.DatasetID,
  84. CollectionId: &data.CollectionID,
  85. }
  86. }
  87. }
  88. }
  89. datasetBase := "https://fastgpt.gkscrm.com/api/core/dataset/searchTest"
  90. datasetKey := "fastgpt-czbAiqKKse65hwwviZhwkgvyDEKE3aeB31Fx18oUsAGojyWQ672HdsWZi1E1C"
  91. return &types.CheckTokenResp{
  92. Valid: &valid,
  93. Sign: &sign,
  94. Timestamp: &timestamp,
  95. AgentInfo: &agentInfo,
  96. CustomAgentBase: &customAgentBase,
  97. CustomAgentKey: &customAgentKey,
  98. OpenaiBase: &openaiBase,
  99. OpenaiKey: &openaiKey,
  100. DatasetBase: &datasetBase,
  101. DatasetKey: &datasetKey,
  102. }, nil
  103. }
  104. // 内部Md5方法
  105. func generateSign(token, mac, timestamp string) string {
  106. md5Token := easyMd5(token)
  107. md5Mac := easyMd5(mac)
  108. md5Ts := easyMd5(timestamp)
  109. return easyMd5(md5Token + md5Mac + md5Ts)
  110. }
  111. // 简易Md5用法
  112. func easyMd5(s string) string {
  113. hash := md5.New()
  114. _, _ = io.WriteString(hash, s)
  115. return hex.EncodeToString(hash.Sum(nil))
  116. }