check_token.go 1.7 KB
package middleware

import (
	"github.com/astaxie/beego/context"
	"gitlab.fjmaimaimai.com/mmm-go/partner/pkg/application/userAuth"
	"gitlab.fjmaimaimai.com/mmm-go/partner/pkg/constant"
	"gitlab.fjmaimaimai.com/mmm-go/partner/pkg/infrastructure/utils"
	"gitlab.fjmaimaimai.com/mmm-go/partner/pkg/protocol"
	"strconv"
	"strings"
)

//检查access_token
func CheckJWTToken(ctx *context.Context) {
	var (
		msg *protocol.ResponseMessage
	)
	token := ctx.Input.Header("x-mmm-accesstoken")
	if strings.HasSuffix(ctx.Request.RequestURI, "login") ||
		strings.HasSuffix(ctx.Request.RequestURI, "accessToken") ||
		strings.HasSuffix(ctx.Request.RequestURI, "refreshToken") ||
		strings.HasSuffix(ctx.Request.RequestURI, "smsCode") ||
		strings.HasSuffix(ctx.Request.RequestURI, "centerCompanys") ||
		strings.HasSuffix(ctx.Request.RequestURI, "companys") ||
		strings.HasSuffix(ctx.Request.RequestURI, "loginV2") ||
		strings.HasSuffix(ctx.Request.RequestURI, "checkSmsCode") ||
		strings.HasSuffix(ctx.Request.RequestURI, "changePhone") ||
		strings.HasSuffix(ctx.Request.RequestURI, "resetPassword") ||
		strings.HasSuffix(ctx.Request.RequestURI, "changePassword") {
		return
	}
	defer func() {
		if msg != nil {
			ctx.Output.JSON(msg, false, false)
		}
	}()
	if u, err := utils.ParseJWTToken(token); err != nil {
		msg = protocol.NewMesage(4141)
		return
	} else {
		ctx.Input.SetData("UserId", u.UserId)

		if constant.DISENABLE_MULTI_DEVICE_LOGIN {
			// valid token
			userPhone, _ := strconv.Atoi(u.Phone)
			tokenAuth := userAuth.NewRedisUserAuth(userAuth.WithUserId(int64(userPhone)))
			err := tokenAuth.Check(
				userAuth.NewOptions(userAuth.WithAccessToken(token)),
			)
			if err != nil {
				msg = protocol.NewMesage(4141)
				return
			}
		}
	}
	return
}