-
Notifications
You must be signed in to change notification settings - Fork 27
/
create_authenticator_login_link_otp.go
73 lines (62 loc) · 2.29 KB
/
create_authenticator_login_link_otp.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
package nodes
import (
"github.com/authgear/authgear-server/pkg/api/apierrors"
"github.com/authgear/authgear-server/pkg/api/model"
"github.com/authgear/authgear-server/pkg/lib/authn"
"github.com/authgear/authgear-server/pkg/lib/authn/authenticator"
"github.com/authgear/authgear-server/pkg/lib/authn/otp"
"github.com/authgear/authgear-server/pkg/lib/feature/verification"
"github.com/authgear/authgear-server/pkg/lib/interaction"
)
func init() {
interaction.RegisterNode(&NodeCreateAuthenticatorLoginLinkOTP{})
}
type InputCreateAuthenticatorLoginLinkOTP interface {
VerifyLoginLink()
}
type EdgeCreateAuthenticatorLoginLinkOTP struct {
Stage authn.AuthenticationStage
Authenticator *authenticator.Info
}
func (e *EdgeCreateAuthenticatorLoginLinkOTP) Instantiate(ctx *interaction.Context, graph *interaction.Graph, rawInput interface{}) (interaction.Node, error) {
var input InputCreateAuthenticatorLoginLinkOTP
if !interaction.Input(rawInput, &input) {
return nil, interaction.ErrIncompatibleInput
}
email := e.Authenticator.OOBOTP.Email
err := ctx.OTPCodeService.VerifyOTP(
otp.KindOOBOTP(ctx.Config, model.AuthenticatorOOBChannelEmail),
email,
"",
&otp.VerifyOptions{
UseSubmittedCode: true,
UserID: e.Authenticator.UserID,
},
)
if apierrors.IsKind(err, otp.InvalidOTPCode) {
return nil, verification.ErrInvalidVerificationCode
} else if err != nil {
return nil, err
}
return &NodeCreateAuthenticatorLoginLinkOTP{Stage: e.Stage, Authenticator: e.Authenticator}, nil
}
type NodeCreateAuthenticatorLoginLinkOTP struct {
Stage authn.AuthenticationStage `json:"stage"`
Authenticator *authenticator.Info `json:"authenticator"`
Target string `json:"target"`
Channel string `json:"channel"`
}
func (n *NodeCreateAuthenticatorLoginLinkOTP) Prepare(ctx *interaction.Context, graph *interaction.Graph) error {
return nil
}
func (n *NodeCreateAuthenticatorLoginLinkOTP) GetEffects() ([]interaction.Effect, error) {
return nil, nil
}
func (n *NodeCreateAuthenticatorLoginLinkOTP) DeriveEdges(graph *interaction.Graph) ([]interaction.Edge, error) {
return []interaction.Edge{
&EdgeCreateAuthenticatorEnd{
Stage: n.Stage,
Authenticators: []*authenticator.Info{n.Authenticator},
},
}, nil
}