package accountlogic import ( "app-cloudep-member-server/internal/utils" "context" "fmt" ers "code.30cm.net/digimon/library-go/errors" "app-cloudep-member-server/gen_result/pb/member" "app-cloudep-member-server/internal/svc" "github.com/zeromicro/go-zero/core/logx" ) type UpdateUserTokenLogic struct { ctx context.Context svcCtx *svc.ServiceContext logx.Logger } func NewUpdateUserTokenLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateUserTokenLogic { return &UpdateUserTokenLogic{ ctx: ctx, svcCtx: svcCtx, Logger: logx.WithContext(ctx), } } type updateUserTokenReq struct { LoginId string `json:"login_id" validate:"account"` Platform int64 `json:"platform" validate:"required,oneof=1"` // '平台類型 1. ark 只有我們自己平台才可以改密碼 Token string `json:"token" validate:"required"` } // UpdateUserToken 更新密碼 func (l *UpdateUserTokenLogic) UpdateUserToken(in *member.UpdateTokenReq) (*member.OKResp, error) { // 驗證資料 if err := l.svcCtx.Validate.ValidateAll(&updateUserTokenReq{ LoginId: in.GetAccount(), Token: in.GetToken(), Platform: in.GetPlatform(), }); err != nil { return nil, ers.InvalidFormat(err.Error()) } token, err := utils.HashPassword(in.GetToken(), l.svcCtx.Config.Bcrypt.Cost) if err != nil { return nil, ers.ArkInternal(fmt.Sprintf("failed to encrypt err: %v", err.Error())) } err = l.svcCtx.AccountModel.UpdateTokenByLoginID(l.ctx, in.GetAccount(), token) if err != nil { return nil, ers.DBError(err.Error()) } return &member.OKResp{}, nil }