forked from supertokens/supertokens-golang
-
Notifications
You must be signed in to change notification settings - Fork 0
/
userEmailVerifyPut.go
95 lines (77 loc) · 2.88 KB
/
userEmailVerifyPut.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
/* Copyright (c) 2022, VRAI Labs and/or its affiliates. All rights reserved.
*
* This software is licensed under the Apache License, Version 2.0 (the
* "License") as published by the Apache Software Foundation.
*
* You may not use this file except in compliance with the License. You may
* obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
package userdetails
import (
"encoding/json"
"errors"
"github.com/supertokens/supertokens-golang/recipe/dashboard/dashboardmodels"
"github.com/supertokens/supertokens-golang/recipe/emailverification"
"github.com/supertokens/supertokens-golang/supertokens"
)
type userEmailVerifyPutResponse struct {
Status string `json:"status"`
}
type userEmailVerifyPutRequestBody struct {
UserID *string `json:"userId"`
Verified *bool `json:"verified"`
}
func UserEmailVerifyPut(apiInterface dashboardmodels.APIInterface, tenantId string, options dashboardmodels.APIOptions, userContext supertokens.UserContext) (userEmailVerifyPutResponse, error) {
body, err := supertokens.ReadFromRequest(options.Req)
if err != nil {
return userEmailVerifyPutResponse{}, err
}
var readBody userEmailVerifyPutRequestBody
err = json.Unmarshal(body, &readBody)
if err != nil {
return userEmailVerifyPutResponse{}, err
}
if readBody.UserID == nil {
return userEmailVerifyPutResponse{}, supertokens.BadInputError{
Msg: "Required parameter 'userId' is missing",
}
}
if readBody.Verified == nil {
return userEmailVerifyPutResponse{}, supertokens.BadInputError{
Msg: "Required parameter 'verified' is missing",
}
}
if *readBody.Verified {
tokenResponse, tokenErr := emailverification.CreateEmailVerificationToken(tenantId, *readBody.UserID, nil, userContext)
if tokenErr != nil {
return userEmailVerifyPutResponse{}, tokenErr
}
if tokenResponse.EmailAlreadyVerifiedError != nil {
return userEmailVerifyPutResponse{
Status: "OK",
}, nil
}
verifyResponse, verifyErr := emailverification.VerifyEmailUsingToken(tenantId, tokenResponse.OK.Token, userContext)
if verifyErr != nil {
return userEmailVerifyPutResponse{}, verifyErr
}
// It should never come here because we generate the token immediately before this step
if verifyResponse.EmailVerificationInvalidTokenError != nil {
return userEmailVerifyPutResponse{}, errors.New("Should never come here")
}
} else {
_, unverifyErr := emailverification.UnverifyEmail(*readBody.UserID, nil, userContext)
if unverifyErr != nil {
return userEmailVerifyPutResponse{}, unverifyErr
}
}
return userEmailVerifyPutResponse{
Status: "OK",
}, nil
}