123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- package auth
-
- import (
- "fmt"
- "net/http"
-
- "github.com/dgrijalva/jwt-go"
- "github.com/gin-gonic/gin"
- )
-
- const (
- CtxRequestHeaderUserId = "user_id"
- CtxRequestHeaderTeamId = "team_id"
- CtxRequestHeaderRoleId = "role_id"
- ctxRequestHeaderAuthorization = "Authorization"
- ctxRequestCookieAuthorization = "ak"
- ctxRequestTokenExpired = "expired"
- )
-
- func Auth(authKey string, session Session) gin.HandlerFunc {
- return func(ctx *gin.Context) {
- var tokenFromCookie, tokenFromHeader string
-
- tokenFromCookie, err := ctx.Cookie(ctxRequestCookieAuthorization)
- if err == http.ErrNoCookie {
- tokenFromHeader = ctx.Request.Header.Get(ctxRequestHeaderAuthorization)
- }
-
- if tokenFromHeader == "" {
- tokenFromHeader = "Bearer " + tokenFromCookie
- }
-
- if len(tokenFromHeader) < 8 {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed"})
- return
- }
-
- token, err := jwt.Parse(tokenFromHeader[7:], func(token *jwt.Token) (interface{}, error) {
- if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok {
- return nil, fmt.Errorf("unexpected signing method: %v", token.Header["alg"])
- }
-
- return []byte(authKey), nil
- })
-
- if err != nil || !token.Valid {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed"})
- return
- }
-
- if !session.IsExistsJwtToken(token.Raw) {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, token expired by server"})
- return
- }
-
- if mapClaims, ok := token.Claims.(jwt.MapClaims); ok {
- if uid, ok := mapClaims[CtxRequestHeaderUserId].(float64); ok {
- ctx.Set(CtxRequestHeaderUserId, int64(uid))
- } else {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, mapClaims[CtxRequestHeaderUserId].(float64) error"})
- return
- }
- } else {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, token.Claims.(jwt.MapClaims) error"})
- return
- }
- }
- }
-
- func CloudTeamAuth(authKey string, session Session) gin.HandlerFunc {
- return func(ctx *gin.Context) {
- var tokenFromCookie, tokenFromHeader string
-
- tokenFromCookie, err := ctx.Cookie(ctxRequestCookieAuthorization)
- if err == http.ErrNoCookie {
- tokenFromHeader = ctx.Request.Header.Get(ctxRequestHeaderAuthorization)
- }
-
- if tokenFromHeader == "" {
- tokenFromHeader = "Bearer " + tokenFromCookie
- }
-
- if len(tokenFromHeader) < 8 {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed"})
- return
- }
-
- token, err := jwt.Parse(tokenFromHeader[7:], func(token *jwt.Token) (interface{}, error) {
- if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok {
- return nil, fmt.Errorf("unexpected signing method: %v", token.Header["alg"])
- }
-
- return []byte(authKey), nil
- })
-
- if err != nil || !token.Valid {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed"})
- return
- }
-
- if !session.IsExistsJwtToken(token.Raw) {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, token expired by server"})
- return
- }
-
- if mapClaims, ok := token.Claims.(jwt.MapClaims); ok {
- if uid, ok := mapClaims[CtxRequestHeaderUserId].(float64); ok {
- ctx.Set(CtxRequestHeaderUserId, int64(uid))
- } else {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, mapClaims[CtxRequestHeaderUserId].(float64) error"})
- return
- }
-
- if tid, ok := mapClaims[CtxRequestHeaderTeamId].(float64); ok {
- ctx.Set(CtxRequestHeaderTeamId, int64(tid))
- } else {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, mapClaims[CtxRequestHeaderTeamId].(float64) error"})
- return
- }
-
- if rid, ok := mapClaims[CtxRequestHeaderRoleId].(float64); ok {
- ctx.Set(CtxRequestHeaderRoleId, int64(rid))
- } else {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, mapClaims[CtxRequestHeaderRoleId].(float64) error"})
- return
- }
- } else {
- ctx.AbortWithStatusJSON(http.StatusUnauthorized, gin.H{"msg": "auth failed, token.Claims.(jwt.MapClaims) error"})
- return
- }
- }
- }
|