mirror of
https://github.com/usememos/memos.git
synced 2025-01-10 06:14:48 +08:00
2b2792de73
* fix: fix logic of email validation * update
145 lines
3.4 KiB
Go
145 lines
3.4 KiB
Go
package api
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/usememos/memos/common"
|
|
)
|
|
|
|
// Role is the type of a role.
|
|
type Role string
|
|
|
|
const (
|
|
// Host is the HOST role.
|
|
Host Role = "HOST"
|
|
// Admin is the ADMIN role.
|
|
Admin Role = "ADMIN"
|
|
// NormalUser is the USER role.
|
|
NormalUser Role = "USER"
|
|
)
|
|
|
|
func (e Role) String() string {
|
|
switch e {
|
|
case Host:
|
|
return "HOST"
|
|
case Admin:
|
|
return "ADMIN"
|
|
case NormalUser:
|
|
return "USER"
|
|
}
|
|
return "USER"
|
|
}
|
|
|
|
type User struct {
|
|
ID int `json:"id"`
|
|
|
|
// Standard fields
|
|
RowStatus RowStatus `json:"rowStatus"`
|
|
CreatedTs int64 `json:"createdTs"`
|
|
UpdatedTs int64 `json:"updatedTs"`
|
|
|
|
// Domain specific fields
|
|
Username string `json:"username"`
|
|
Role Role `json:"role"`
|
|
Email string `json:"email"`
|
|
Nickname string `json:"nickname"`
|
|
PasswordHash string `json:"-"`
|
|
OpenID string `json:"openId"`
|
|
UserSettingList []*UserSetting `json:"userSettingList"`
|
|
}
|
|
|
|
type UserCreate struct {
|
|
// Domain specific fields
|
|
Username string `json:"username"`
|
|
Role Role `json:"role"`
|
|
Email string `json:"email"`
|
|
Nickname string `json:"nickname"`
|
|
Password string `json:"password"`
|
|
PasswordHash string
|
|
OpenID string
|
|
}
|
|
|
|
func (create UserCreate) Validate() error {
|
|
if len(create.Username) < 4 {
|
|
return fmt.Errorf("username is too short, minimum length is 4")
|
|
}
|
|
if len(create.Username) > 32 {
|
|
return fmt.Errorf("username is too long, maximum length is 32")
|
|
}
|
|
if len(create.Password) < 4 {
|
|
return fmt.Errorf("password is too short, minimum length is 4")
|
|
}
|
|
if len(create.Nickname) > 64 {
|
|
return fmt.Errorf("nickname is too long, maximum length is 64")
|
|
}
|
|
if create.Email != "" {
|
|
if len(create.Email) > 256 {
|
|
return fmt.Errorf("email is too long, maximum length is 256")
|
|
}
|
|
if !common.ValidateEmail(create.Email) {
|
|
return fmt.Errorf("invalid email format")
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
type UserPatch struct {
|
|
ID int `json:"-"`
|
|
|
|
// Standard fields
|
|
UpdatedTs *int64
|
|
RowStatus *RowStatus `json:"rowStatus"`
|
|
|
|
// Domain specific fields
|
|
Username *string `json:"username"`
|
|
Email *string `json:"email"`
|
|
Nickname *string `json:"nickname"`
|
|
Password *string `json:"password"`
|
|
ResetOpenID *bool `json:"resetOpenId"`
|
|
PasswordHash *string
|
|
OpenID *string
|
|
}
|
|
|
|
func (patch UserPatch) Validate() error {
|
|
if patch.Username != nil && len(*patch.Username) < 4 {
|
|
return fmt.Errorf("username is too short, minimum length is 4")
|
|
}
|
|
if patch.Username != nil && len(*patch.Username) > 32 {
|
|
return fmt.Errorf("username is too long, maximum length is 32")
|
|
}
|
|
if patch.Password != nil && len(*patch.Password) < 4 {
|
|
return fmt.Errorf("password is too short, minimum length is 4")
|
|
}
|
|
if patch.Nickname != nil && len(*patch.Nickname) > 64 {
|
|
return fmt.Errorf("nickname is too long, maximum length is 64")
|
|
}
|
|
if patch.Email != nil {
|
|
if len(*patch.Email) > 256 {
|
|
return fmt.Errorf("email is too long, maximum length is 256")
|
|
}
|
|
if !common.ValidateEmail(*patch.Email) {
|
|
return fmt.Errorf("invalid email format")
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
type UserFind struct {
|
|
ID *int `json:"id"`
|
|
|
|
// Standard fields
|
|
RowStatus *RowStatus `json:"rowStatus"`
|
|
|
|
// Domain specific fields
|
|
Username *string `json:"username"`
|
|
Role *Role
|
|
Email *string `json:"email"`
|
|
Nickname *string `json:"nickname"`
|
|
OpenID *string
|
|
}
|
|
|
|
type UserDelete struct {
|
|
ID int
|
|
}
|