67 lines
1.6 KiB
Go
67 lines
1.6 KiB
Go
package auth
|
|
|
|
import (
|
|
"context"
|
|
|
|
dommember "gateway/internal/model/member/domain/usecase"
|
|
"gateway/internal/svc"
|
|
"gateway/internal/types"
|
|
|
|
"github.com/zeromicro/go-zero/core/logx"
|
|
)
|
|
|
|
type RegisterConfirmLogic struct {
|
|
logx.Logger
|
|
ctx context.Context
|
|
svcCtx *svc.ServiceContext
|
|
}
|
|
|
|
func NewRegisterConfirmLogic(ctx context.Context, svcCtx *svc.ServiceContext) *RegisterConfirmLogic {
|
|
return &RegisterConfirmLogic{
|
|
Logger: logx.WithContext(ctx),
|
|
ctx: ctx,
|
|
svcCtx: svcCtx,
|
|
}
|
|
}
|
|
|
|
func (l *RegisterConfirmLogic) RegisterConfirm(req *types.RegisterConfirmReq) (*types.AuthTokenData, error) {
|
|
if l.svcCtx.MemberOTP == nil || l.svcCtx.MemberLifecycle == nil {
|
|
return nil, errb.SysNotImplemented("member module not configured")
|
|
}
|
|
if l.svcCtx.AuthToken == nil {
|
|
return nil, errb.SysNotImplemented("auth token not configured")
|
|
}
|
|
|
|
tenant, err := resolveTenant(l.ctx, l.svcCtx, req.TenantSlug)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
ch, err := l.svcCtx.MemberOTP.MatchChallenge(l.ctx, &dommember.MatchChallengeRequest{
|
|
ChallengeID: req.ChallengeID,
|
|
TenantID: tenant.TenantID,
|
|
Purpose: registrationPurpose(),
|
|
RequireUID: true,
|
|
RequireTarget: false,
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if _, err := l.svcCtx.MemberOTP.Verify(l.ctx, &dommember.VerifyOTPRequest{
|
|
TenantID: tenant.TenantID,
|
|
UID: ch.UID,
|
|
ChallengeID: req.ChallengeID,
|
|
Code: req.Code,
|
|
Purpose: registrationPurpose(),
|
|
}); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if err := l.svcCtx.MemberLifecycle.Activate(l.ctx, tenant.TenantID, ch.UID); err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return issueAuthToken(l.ctx, l.svcCtx, tenant.TenantID, ch.UID)
|
|
}
|