package mw import ( "applet/app/e" "applet/app/svc" "errors" "github.com/gin-gonic/gin" ) // Auth 检查权限, 签名等等 func Auth(c *gin.Context) { user, newToken, err := svc.CheckUser(c) if err != nil { var e1 e.E switch { case errors.As(err, &e1): e.OutErr(c, e1.Code, e1.Error()) return default: e.OutErr(c, e.ERR_UNAUTHORIZED, err.Error()) return } } if user == nil { e.OutErr(c, e.ERR_NOT_AUTH, "当前用户信息失效") return } // 将当前请求的用户信息保存到请求的上下文c上 c.Set("user", user) if len(newToken) > 0 { c.Header("new-token", newToken) // TODO::将新Token添加到返回的Header里,方便前端使用 } c.Next() }