/
use_passkey.go
95 lines (77 loc) · 2.4 KB
/
use_passkey.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
package webapp
import (
"net/http"
"github.com/authgear/authgear-server/pkg/auth/handler/webapp/viewmodels"
"github.com/authgear/authgear-server/pkg/auth/webapp"
"github.com/authgear/authgear-server/pkg/lib/interaction"
"github.com/authgear/authgear-server/pkg/util/httproute"
"github.com/authgear/authgear-server/pkg/util/template"
)
var TemplateWebUsePasskeyHTML = template.RegisterHTML(
"web/use_passkey.html",
Components...,
)
func ConfigureUsePasskeyRoute(route httproute.Route) httproute.Route {
return route.
WithMethods("OPTIONS", "POST", "GET").
WithPathPattern("/flows/use_passkey")
}
type UsePasskeyHandler struct {
ControllerFactory ControllerFactory
BaseViewModel *viewmodels.BaseViewModeler
AlternativeStepsViewModel *viewmodels.AlternativeStepsViewModeler
Renderer Renderer
}
func (h *UsePasskeyHandler) GetData(r *http.Request, rw http.ResponseWriter, session *webapp.Session, graph *interaction.Graph) (map[string]interface{}, error) {
data := map[string]interface{}{}
baseViewModel := h.BaseViewModel.ViewModel(r, rw)
alternatives, err := h.AlternativeStepsViewModel.AuthenticationAlternatives(graph, webapp.SessionStepUsePasskey)
if err != nil {
return nil, err
}
viewmodels.Embed(data, baseViewModel)
viewmodels.Embed(data, *alternatives)
return data, nil
}
func (h *UsePasskeyHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
ctrl, err := h.ControllerFactory.New(r, w)
if err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
return
}
defer ctrl.Serve()
ctrl.Get(func() error {
session, err := ctrl.InteractionSession()
if err != nil {
return err
}
graph, err := ctrl.InteractionGet()
if err != nil {
return err
}
data, err := h.GetData(r, w, session, graph)
if err != nil {
return err
}
h.Renderer.RenderHTML(w, r, TemplateWebUsePasskeyHTML, data)
return nil
})
ctrl.PostAction("", func() error {
result, err := ctrl.InteractionPost(func() (input interface{}, err error) {
assertionResponseStr := ctrl.request.Form.Get("x_assertion_response")
assertionResponse := []byte(assertionResponseStr)
stage := ctrl.request.Form.Get("x_stage")
input = &InputPasskeyAssertionResponse{
Stage: stage,
AssertionResponse: assertionResponse,
}
return
})
if err != nil {
return err
}
result.WriteResponse(w, r)
return nil
})
handleAlternativeSteps(ctrl)
}