64 lines
1.6 KiB
Go
Raw Normal View History

2023-06-01 18:35:09 +08:00
package logic
import (
"context"
2023-06-06 20:08:32 +08:00
"time"
2023-06-01 18:35:09 +08:00
"fusenapi/home-user-auth/internal/svc"
"fusenapi/home-user-auth/internal/types"
"fusenapi/model"
2023-06-05 17:56:55 +08:00
"fusenapi/utils/basic"
2023-06-01 18:35:09 +08:00
2023-06-06 17:25:49 +08:00
"github.com/golang-jwt/jwt"
2023-06-01 18:35:09 +08:00
"github.com/zeromicro/go-zero/core/logx"
)
type UserLoginLogic struct {
logx.Logger
ctx context.Context
svcCtx *svc.ServiceContext
}
func NewUserLoginLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UserLoginLogic {
return &UserLoginLogic{
Logger: logx.WithContext(ctx),
ctx: ctx,
svcCtx: svcCtx,
}
}
2023-06-06 20:08:32 +08:00
func (l *UserLoginLogic) genJwtToken(accessSecret string, accessExpire, nowSec, userid int64) (string, error) {
2023-06-06 17:25:49 +08:00
claims := make(jwt.MapClaims)
2023-06-06 20:08:32 +08:00
claims["exp"] = nowSec + accessExpire
claims["iat"] = nowSec
claims["userid"] = userid
2023-06-06 17:25:49 +08:00
token := jwt.New(jwt.SigningMethodHS256)
token.Claims = claims
2023-06-06 20:08:32 +08:00
return token.SignedString([]byte(accessSecret))
2023-06-06 17:25:49 +08:00
}
2023-06-06 20:08:32 +08:00
func (l *UserLoginLogic) UserLogin(req *types.RequestUserLogin) (resp *types.Response, jwtToken string) {
2023-06-05 17:56:55 +08:00
userModel, err := model.NewFsUserModel(l.svcCtx.MysqlConn).FindOneByEmail(l.ctx, req.Name)
2023-06-06 20:08:32 +08:00
2023-06-01 18:35:09 +08:00
if err == model.ErrNotFound {
2023-06-05 17:56:55 +08:00
logx.Error(err)
2023-06-07 11:57:04 +08:00
return resp.SetStatusWithMessage(basic.CodeServiceErr, err.Error()), jwtToken
2023-06-01 18:35:09 +08:00
}
2023-06-06 20:08:32 +08:00
// jwt 生成
nowSec := time.Now().Unix()
jwtToken, err = l.genJwtToken(l.svcCtx.Config.Auth.AccessSecret, l.svcCtx.Config.Auth.AccessExpire, nowSec, userModel.Id)
if err != nil {
logx.Error(err)
2023-06-07 11:57:04 +08:00
return resp.SetStatus(basic.CodeUnAuth), jwtToken
2023-06-06 20:08:32 +08:00
}
2023-06-05 17:56:55 +08:00
data := &types.DataUserLogin{
2023-06-06 20:08:32 +08:00
Token: userModel.PasswordResetToken.String,
JwtToken: jwtToken,
2023-06-01 18:35:09 +08:00
}
2023-06-06 20:08:32 +08:00
2023-06-07 11:57:04 +08:00
return resp.SetStatus(basic.CodeOK, data), jwtToken
2023-06-01 18:35:09 +08:00
}