/
auth_types.go
98 lines (85 loc) · 2.78 KB
/
auth_types.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
96
97
98
package structs
import (
"github.com/imtiaz246/codera_oj/models"
"github.com/imtiaz246/codera_oj/modules/token"
"time"
)
var (
UserSuccessfulRegistrationResponse = struct {
Message string `json:"message"`
}{
Message: "Account registered successfully. Please verify your email to add the email to your profile.",
}
EmailSuccessfulVerificationResponse = struct {
Message string `json:"message"`
}{
Message: "Email verified successfully.",
}
)
type UserRegisterRequest struct {
Username string `json:"username" validate:"required"`
Email string `json:"email" validate:"email"`
Password string `json:"password" validate:"required,min=6"`
}
type UserLoginRequest struct {
Username string `json:"username"`
Email string `json:"email" validate:"email"`
Password string `json:"password" validate:"required,min=6"`
}
type UserLoginResponse struct {
User *UserResponse `json:"User"`
AccessToken string `json:"AccessToken"`
AccessTokenExpiresAt time.Time `json:"AccessTokenExpiresAt"`
RefreshToken string `json:"RefreshToken"`
RefreshTokenExpiresAt time.Time `json:"RefreshTokenExpiresAt"`
}
type RequestedUser struct {
Username string `json:"username"`
Email string `json:"email"`
}
type RenewTokenResponse struct {
User *UserResponse `json:"user"`
AccessToken string `json:"accessToken"`
AccessTokenExpiresAt time.Time `json:"accessTokenExpiresAt"`
}
type UserResponse struct {
ID uint `json:"id"`
Username string `json:"username"`
Email string `json:"email"`
DisplayName string `json:"displayName"`
Organization string `json:"organization"`
Country string `json:"country"`
City string `json:"city"`
Image string `json:"image"`
}
func NewUserResponse(u *models.User) *UserResponse {
r := &UserResponse{
ID: u.ID,
City: u.City,
Image: u.Image,
Country: u.Country,
Username: u.Username,
DisplayName: u.DisplayName,
Organization: u.Organization,
}
if u.KeepEmailPrivate == false {
r.Email = u.Email
}
return r
}
func NewLoginResponse(u *models.User, accessTokenInfo, refreshTokenInfo *token.TokenInfo) *UserLoginResponse {
return &UserLoginResponse{
User: NewUserResponse(u),
AccessToken: accessTokenInfo.Token,
AccessTokenExpiresAt: accessTokenInfo.Payload.Expiration,
RefreshToken: refreshTokenInfo.Token,
RefreshTokenExpiresAt: refreshTokenInfo.Payload.Expiration,
}
}
func NewRenewTokenResponse(u *models.User, accessTokenInfo *token.TokenInfo) *RenewTokenResponse {
return &RenewTokenResponse{
User: NewUserResponse(u),
AccessToken: accessTokenInfo.Token,
AccessTokenExpiresAt: accessTokenInfo.Payload.Expiration,
}
}