fusenapi/home-user-auth/internal/logic/userloginlogic.go

56 lines
1.5 KiB
Go
Raw Normal View History

2023-06-01 10:35:09 +00:00
package logic
import (
"context"
"fusenapi/home-user-auth/internal/svc"
"fusenapi/home-user-auth/internal/types"
"fusenapi/model"
2023-06-05 09:56:55 +00:00
"fusenapi/utils/basic"
2023-06-01 10:35:09 +00:00
2023-06-06 09:25:49 +00:00
"github.com/golang-jwt/jwt"
2023-06-01 10:35:09 +00: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 09:25:49 +00:00
func (l *UserLoginLogic) getJwtToken(secretKey string, iat, seconds, userId int64) (string, error) {
claims := make(jwt.MapClaims)
claims["exp"] = iat + seconds
claims["iat"] = iat
claims["userId"] = userId
token := jwt.New(jwt.SigningMethodHS256)
token.Claims = claims
return token.SignedString([]byte(secretKey))
}
2023-06-05 09:56:55 +00:00
func (l *UserLoginLogic) UserLogin(req *types.RequestUserLogin) (resp *types.Response) {
// 必须返回response, 前端需要的是内部约定的Code码, 处理相关的逻辑. 例子(eg): resp.Set(501, "error")
resp = &types.Response{}
userModel, err := model.NewFsUserModel(l.svcCtx.MysqlConn).FindOneByEmail(l.ctx, req.Name)
// log.Printf("%t %t %v", err, model.ErrNotFound, err == model.ErrNotFound)
2023-06-01 10:35:09 +00:00
if err == model.ErrNotFound {
2023-06-05 09:56:55 +00:00
logx.Error(err)
2023-06-06 09:36:10 +00:00
resp.SetStatusWithMessage(basic.CodeServiceErr, err.Error())
2023-06-05 09:56:55 +00:00
return resp
2023-06-01 10:35:09 +00:00
}
2023-06-05 09:56:55 +00:00
data := &types.DataUserLogin{
Token: userModel.PasswordResetToken.String,
2023-06-01 10:35:09 +00:00
}
2023-06-06 09:36:10 +00:00
resp.SetStatus(basic.CodeOK, data)
2023-06-05 09:56:55 +00:00
return resp
2023-06-01 10:35:09 +00:00
}