2021-12-08 23:43:14 +08:00
|
|
|
package api
|
|
|
|
|
2022-08-20 21:03:15 +08:00
|
|
|
import (
|
|
|
|
"fmt"
|
2022-12-27 21:51:43 +08:00
|
|
|
|
|
|
|
"github.com/usememos/memos/common"
|
2022-08-20 21:03:15 +08:00
|
|
|
)
|
|
|
|
|
2022-05-15 10:57:54 +08:00
|
|
|
// Role is the type of a role.
|
|
|
|
type Role string
|
|
|
|
|
|
|
|
const (
|
2022-07-08 22:16:18 +08:00
|
|
|
// Host is the HOST role.
|
|
|
|
Host Role = "HOST"
|
2022-11-23 22:27:21 +08:00
|
|
|
// Admin is the ADMIN role.
|
|
|
|
Admin Role = "ADMIN"
|
2022-05-15 10:57:54 +08:00
|
|
|
// NormalUser is the USER role.
|
|
|
|
NormalUser Role = "USER"
|
|
|
|
)
|
|
|
|
|
2022-05-19 18:32:04 +08:00
|
|
|
func (e Role) String() string {
|
|
|
|
switch e {
|
2022-07-08 22:16:18 +08:00
|
|
|
case Host:
|
|
|
|
return "HOST"
|
2022-11-23 22:27:21 +08:00
|
|
|
case Admin:
|
|
|
|
return "ADMIN"
|
2022-05-19 18:32:04 +08:00
|
|
|
case NormalUser:
|
|
|
|
return "USER"
|
|
|
|
}
|
|
|
|
return "USER"
|
|
|
|
}
|
|
|
|
|
2022-02-03 15:32:03 +08:00
|
|
|
type User struct {
|
2022-05-03 11:49:10 +08:00
|
|
|
ID int `json:"id"`
|
|
|
|
|
|
|
|
// Standard fields
|
2022-05-19 18:32:04 +08:00
|
|
|
RowStatus RowStatus `json:"rowStatus"`
|
|
|
|
CreatedTs int64 `json:"createdTs"`
|
|
|
|
UpdatedTs int64 `json:"updatedTs"`
|
2022-02-03 15:32:03 +08:00
|
|
|
|
2022-05-03 11:49:10 +08:00
|
|
|
// Domain specific fields
|
2022-11-23 22:27:21 +08:00
|
|
|
Username string `json:"username"`
|
2022-08-13 14:35:33 +08:00
|
|
|
Role Role `json:"role"`
|
2022-11-23 22:27:21 +08:00
|
|
|
Email string `json:"email"`
|
|
|
|
Nickname string `json:"nickname"`
|
2022-08-13 14:35:33 +08:00
|
|
|
PasswordHash string `json:"-"`
|
|
|
|
OpenID string `json:"openId"`
|
2023-02-17 23:55:56 +08:00
|
|
|
AvatarURL string `json:"avatarUrl"`
|
2022-08-13 14:35:33 +08:00
|
|
|
UserSettingList []*UserSetting `json:"userSettingList"`
|
2021-12-08 23:43:14 +08:00
|
|
|
}
|
|
|
|
|
2022-02-03 15:32:03 +08:00
|
|
|
type UserCreate struct {
|
2022-05-03 11:49:10 +08:00
|
|
|
// Domain specific fields
|
2022-11-23 22:27:21 +08:00
|
|
|
Username string `json:"username"`
|
2022-05-16 22:19:39 +08:00
|
|
|
Role Role `json:"role"`
|
2022-11-23 22:27:21 +08:00
|
|
|
Email string `json:"email"`
|
|
|
|
Nickname string `json:"nickname"`
|
2022-05-16 22:19:39 +08:00
|
|
|
Password string `json:"password"`
|
2022-02-06 16:19:20 +08:00
|
|
|
PasswordHash string
|
2022-05-15 10:57:54 +08:00
|
|
|
OpenID string
|
2021-12-09 22:02:57 +08:00
|
|
|
}
|
|
|
|
|
2022-08-20 21:03:15 +08:00
|
|
|
func (create UserCreate) Validate() error {
|
2023-02-11 15:15:56 +08:00
|
|
|
if len(create.Username) < 3 {
|
|
|
|
return fmt.Errorf("username is too short, minimum length is 3")
|
2022-08-20 21:03:15 +08:00
|
|
|
}
|
2022-12-27 21:51:43 +08:00
|
|
|
if len(create.Username) > 32 {
|
|
|
|
return fmt.Errorf("username is too long, maximum length is 32")
|
|
|
|
}
|
2023-02-25 14:59:29 +08:00
|
|
|
if len(create.Password) < 3 {
|
|
|
|
return fmt.Errorf("password is too short, minimum length is 6")
|
|
|
|
}
|
|
|
|
if len(create.Password) > 512 {
|
|
|
|
return fmt.Errorf("password is too long, maximum length is 512")
|
|
|
|
}
|
2022-12-27 21:51:43 +08:00
|
|
|
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")
|
|
|
|
}
|
2022-12-30 13:10:52 +08:00
|
|
|
if !common.ValidateEmail(create.Email) {
|
2022-12-27 21:51:43 +08:00
|
|
|
return fmt.Errorf("invalid email format")
|
|
|
|
}
|
|
|
|
}
|
2022-08-20 21:03:15 +08:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-02-03 15:32:03 +08:00
|
|
|
type UserPatch struct {
|
2022-12-23 18:38:24 +08:00
|
|
|
ID int `json:"-"`
|
2021-12-14 20:40:24 +08:00
|
|
|
|
2022-05-19 18:32:04 +08:00
|
|
|
// Standard fields
|
2022-10-26 23:00:09 +08:00
|
|
|
UpdatedTs *int64
|
2022-05-19 18:32:04 +08:00
|
|
|
RowStatus *RowStatus `json:"rowStatus"`
|
|
|
|
|
2022-05-03 11:49:10 +08:00
|
|
|
// Domain specific fields
|
2022-11-23 22:27:21 +08:00
|
|
|
Username *string `json:"username"`
|
2022-05-15 10:57:54 +08:00
|
|
|
Email *string `json:"email"`
|
2022-11-23 22:27:21 +08:00
|
|
|
Nickname *string `json:"nickname"`
|
2022-05-03 11:49:10 +08:00
|
|
|
Password *string `json:"password"`
|
|
|
|
ResetOpenID *bool `json:"resetOpenId"`
|
2023-02-17 23:55:56 +08:00
|
|
|
AvatarURL *string `json:"avatarUrl"`
|
2022-05-15 10:57:54 +08:00
|
|
|
PasswordHash *string
|
|
|
|
OpenID *string
|
2021-12-14 20:40:24 +08:00
|
|
|
}
|
|
|
|
|
2022-12-27 21:51:43 +08:00
|
|
|
func (patch UserPatch) Validate() error {
|
2023-02-11 15:15:56 +08:00
|
|
|
if patch.Username != nil && len(*patch.Username) < 3 {
|
|
|
|
return fmt.Errorf("username is too short, minimum length is 3")
|
2022-12-27 21:51:43 +08:00
|
|
|
}
|
|
|
|
if patch.Username != nil && len(*patch.Username) > 32 {
|
|
|
|
return fmt.Errorf("username is too long, maximum length is 32")
|
|
|
|
}
|
2023-03-06 19:13:09 +08:00
|
|
|
if patch.Password != nil && len(*patch.Password) < 3 {
|
2023-02-25 14:59:29 +08:00
|
|
|
return fmt.Errorf("password is too short, minimum length is 6")
|
|
|
|
}
|
2023-03-06 19:13:09 +08:00
|
|
|
if patch.Password != nil && len(*patch.Password) > 512 {
|
2023-02-25 14:59:29 +08:00
|
|
|
return fmt.Errorf("password is too long, maximum length is 512")
|
|
|
|
}
|
2022-12-27 21:51:43 +08:00
|
|
|
if patch.Nickname != nil && len(*patch.Nickname) > 64 {
|
|
|
|
return fmt.Errorf("nickname is too long, maximum length is 64")
|
|
|
|
}
|
2023-02-18 10:48:31 +08:00
|
|
|
if patch.AvatarURL != nil {
|
|
|
|
if len(*patch.AvatarURL) > 2<<20 {
|
|
|
|
return fmt.Errorf("avatar is too large, maximum is 2MB")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if patch.Email != nil && *patch.Email != "" {
|
2022-12-27 21:51:43 +08:00
|
|
|
if len(*patch.Email) > 256 {
|
|
|
|
return fmt.Errorf("email is too long, maximum length is 256")
|
|
|
|
}
|
2022-12-30 13:10:52 +08:00
|
|
|
if !common.ValidateEmail(*patch.Email) {
|
2022-12-27 21:51:43 +08:00
|
|
|
return fmt.Errorf("invalid email format")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2022-02-03 15:32:03 +08:00
|
|
|
type UserFind struct {
|
2022-05-03 02:05:43 +08:00
|
|
|
ID *int `json:"id"`
|
2021-12-09 22:02:57 +08:00
|
|
|
|
2022-05-19 18:32:04 +08:00
|
|
|
// Standard fields
|
|
|
|
RowStatus *RowStatus `json:"rowStatus"`
|
|
|
|
|
2022-05-03 11:49:10 +08:00
|
|
|
// Domain specific fields
|
2022-11-23 22:27:21 +08:00
|
|
|
Username *string `json:"username"`
|
|
|
|
Role *Role
|
|
|
|
Email *string `json:"email"`
|
|
|
|
Nickname *string `json:"nickname"`
|
|
|
|
OpenID *string
|
2021-12-08 23:43:14 +08:00
|
|
|
}
|
2022-07-26 21:41:20 +08:00
|
|
|
|
|
|
|
type UserDelete struct {
|
|
|
|
ID int
|
|
|
|
}
|