/
account.go
71 lines (63 loc) · 2.1 KB
/
account.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
package request
import (
"net/http"
"github.com/gin-gonic/gin"
"github.com/crouse/pms/internal"
"github.com/crouse/pms/internal/errors"
)
// Register contains registration request
type Register struct {
FirstName string `json:"first_name" binding:"required"`
LastName string `json:"last_name" binding:"required"`
Username string `json:"username" binding:"required,min=3,alphanum"`
Password string `json:"password" binding:"required,min=8"`
PasswordConfirm string `json:"password_confirm" binding:"required"`
Email string `json:"email" binding:"required,email"`
CompanyID int `json:"company_id" binding:"required"`
LocationID int `json:"location_id" binding:"required"`
RoleID int `json:"role_id" binding:"required"`
}
// AccountCreate validates account creation request
func AccountCreate(c *gin.Context) (*Register, error) {
var r Register
if err := c.ShouldBindJSON(&r); err != nil {
apperr.Response(c, err)
return nil, err
}
if r.Password != r.PasswordConfirm {
err := apperr.New(http.StatusBadRequest, "passwords do not match")
c.AbortWithStatusJSON(http.StatusBadRequest, err)
return nil, err
}
if r.RoleID < int(model.SuperAdminRole) || r.RoleID > int(model.UserRole) {
c.AbortWithStatus(http.StatusBadRequest)
return nil, apperr.BadRequest
}
return &r, nil
}
// Password contains password change request
type Password struct {
ID int `json:"-"`
OldPassword string `json:"old_password" binding:"required,min=8"`
NewPassword string `json:"new_password" binding:"required,min=8"`
NewPasswordConfirm string `json:"new_password_confirm" binding:"required"`
}
// PasswordChange validates password change request
func PasswordChange(c *gin.Context) (*Password, error) {
var p Password
id, err := ID(c)
if err != nil {
return nil, err
}
if err := c.ShouldBindJSON(&p); err != nil {
apperr.Response(c, err)
return nil, err
}
if p.NewPassword != p.NewPasswordConfirm {
err := apperr.New(http.StatusBadRequest, "passwords do not match")
apperr.Response(c, err)
return nil, err
}
p.ID = id
return &p, nil
}