2016-11-07 21:53:13 +08:00
|
|
|
// Copyright 2014 The Gogs Authors. All rights reserved.
|
2024-03-01 16:23:28 +08:00
|
|
|
// Copyright 2023 The Gitea Authors. All rights reserved.
|
2022-11-28 02:20:29 +08:00
|
|
|
// SPDX-License-Identifier: MIT
|
2016-11-07 21:53:13 +08:00
|
|
|
|
2019-05-11 18:21:34 +08:00
|
|
|
package structs
|
2016-11-07 21:53:13 +08:00
|
|
|
|
|
|
|
import (
|
2019-06-16 11:28:32 +08:00
|
|
|
"time"
|
2021-03-02 05:08:10 +08:00
|
|
|
|
2021-07-25 00:03:58 +08:00
|
|
|
"code.gitea.io/gitea/modules/json"
|
2016-11-07 21:53:13 +08:00
|
|
|
)
|
|
|
|
|
2017-11-13 15:02:25 +08:00
|
|
|
// User represents a user
|
|
|
|
// swagger:model
|
2016-11-07 21:53:13 +08:00
|
|
|
type User struct {
|
2017-11-13 15:02:25 +08:00
|
|
|
// the user's id
|
2018-03-06 09:22:16 +08:00
|
|
|
ID int64 `json:"id"`
|
2017-11-13 15:02:25 +08:00
|
|
|
// the user's username
|
2018-03-06 09:22:16 +08:00
|
|
|
UserName string `json:"login"`
|
2022-07-15 16:52:11 +08:00
|
|
|
// the user's authentication sign-in name.
|
|
|
|
// default: empty
|
|
|
|
LoginName string `json:"login_name"`
|
2017-11-13 15:02:25 +08:00
|
|
|
// the user's full name
|
2018-03-06 09:22:16 +08:00
|
|
|
FullName string `json:"full_name"`
|
2017-11-13 15:02:25 +08:00
|
|
|
// swagger:strfmt email
|
2018-03-06 09:22:16 +08:00
|
|
|
Email string `json:"email"`
|
2017-11-13 15:02:25 +08:00
|
|
|
// URL to the user's avatar
|
2016-11-29 16:09:17 +08:00
|
|
|
AvatarURL string `json:"avatar_url"`
|
2018-05-05 08:28:30 +08:00
|
|
|
// User locale
|
|
|
|
Language string `json:"language"`
|
2019-03-04 06:57:24 +08:00
|
|
|
// Is the user an administrator
|
|
|
|
IsAdmin bool `json:"is_admin"`
|
2019-06-16 11:28:32 +08:00
|
|
|
// swagger:strfmt date-time
|
|
|
|
LastLogin time.Time `json:"last_login,omitempty"`
|
|
|
|
// swagger:strfmt date-time
|
|
|
|
Created time.Time `json:"created,omitempty"`
|
2021-02-18 16:25:35 +08:00
|
|
|
// Is user restricted
|
|
|
|
Restricted bool `json:"restricted"`
|
2021-05-11 08:22:29 +08:00
|
|
|
// Is user active
|
|
|
|
IsActive bool `json:"active"`
|
|
|
|
// Is user login prohibited
|
|
|
|
ProhibitLogin bool `json:"prohibit_login"`
|
2021-05-01 17:05:55 +08:00
|
|
|
// the user's location
|
|
|
|
Location string `json:"location"`
|
|
|
|
// the user's website
|
|
|
|
Website string `json:"website"`
|
2021-05-03 03:03:15 +08:00
|
|
|
// the user's description
|
|
|
|
Description string `json:"description"`
|
2021-06-27 03:53:14 +08:00
|
|
|
// User visibility level option: public, limited, private
|
|
|
|
Visibility string `json:"visibility"`
|
2021-06-17 15:17:35 +08:00
|
|
|
|
|
|
|
// user counts
|
|
|
|
Followers int `json:"followers_count"`
|
|
|
|
Following int `json:"following_count"`
|
|
|
|
StarredRepos int `json:"starred_repos_count"`
|
2016-11-07 21:53:13 +08:00
|
|
|
}
|
|
|
|
|
2016-12-16 23:26:35 +08:00
|
|
|
// MarshalJSON implements the json.Marshaler interface for User, adding field(s) for backward compatibility
|
|
|
|
func (u User) MarshalJSON() ([]byte, error) {
|
|
|
|
// Re-declaring User to avoid recursion
|
|
|
|
type shadow User
|
|
|
|
return json.Marshal(struct {
|
|
|
|
shadow
|
|
|
|
CompatUserName string `json:"username"`
|
|
|
|
}{shadow(u), u.UserName})
|
|
|
|
}
|
2021-06-24 03:58:44 +08:00
|
|
|
|
|
|
|
// UserSettings represents user settings
|
|
|
|
// swagger:model
|
|
|
|
type UserSettings struct {
|
|
|
|
FullName string `json:"full_name"`
|
|
|
|
Website string `json:"website"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Location string `json:"location"`
|
|
|
|
Language string `json:"language"`
|
|
|
|
Theme string `json:"theme"`
|
|
|
|
DiffViewStyle string `json:"diff_view_style"`
|
|
|
|
// Privacy
|
|
|
|
HideEmail bool `json:"hide_email"`
|
|
|
|
HideActivity bool `json:"hide_activity"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// UserSettingsOptions represents options to change user settings
|
|
|
|
// swagger:model
|
|
|
|
type UserSettingsOptions struct {
|
|
|
|
FullName *string `json:"full_name" binding:"MaxSize(100)"`
|
|
|
|
Website *string `json:"website" binding:"OmitEmpty;ValidUrl;MaxSize(255)"`
|
|
|
|
Description *string `json:"description" binding:"MaxSize(255)"`
|
|
|
|
Location *string `json:"location" binding:"MaxSize(50)"`
|
|
|
|
Language *string `json:"language"`
|
|
|
|
Theme *string `json:"theme"`
|
|
|
|
DiffViewStyle *string `json:"diff_view_style"`
|
|
|
|
// Privacy
|
|
|
|
HideEmail *bool `json:"hide_email"`
|
|
|
|
HideActivity *bool `json:"hide_activity"`
|
|
|
|
}
|
2023-03-14 15:45:21 +08:00
|
|
|
|
|
|
|
// RenameUserOption options when renaming a user
|
|
|
|
type RenameUserOption struct {
|
|
|
|
// New username for this user. This name cannot be in use yet by any other user.
|
|
|
|
//
|
|
|
|
// required: true
|
|
|
|
// unique: true
|
|
|
|
NewName string `json:"new_username" binding:"Required"`
|
|
|
|
}
|
2023-06-30 07:22:55 +08:00
|
|
|
|
|
|
|
// UpdateUserAvatarUserOption options when updating the user avatar
|
|
|
|
type UpdateUserAvatarOption struct {
|
|
|
|
// image must be base64 encoded
|
|
|
|
Image string `json:"image" binding:"Required"`
|
|
|
|
}
|
2024-03-01 16:23:28 +08:00
|
|
|
|
|
|
|
// Badge represents a user badge
|
|
|
|
// swagger:model
|
|
|
|
type Badge struct {
|
|
|
|
ID int64 `json:"id"`
|
|
|
|
Slug string `json:"slug"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
ImageURL string `json:"image_url"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// UserBadge represents a user badge
|
|
|
|
// swagger:model
|
|
|
|
type UserBadge struct {
|
|
|
|
ID int64 `json:"id"`
|
|
|
|
BadgeID int64 `json:"badge_id"`
|
|
|
|
UserID int64 `json:"user_id"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// UserBadgeOption options for link between users and badges
|
|
|
|
type UserBadgeOption struct {
|
|
|
|
// example: ["badge1","badge2"]
|
|
|
|
BadgeSlugs []string `json:"badge_slugs" binding:"Required"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// BadgeList
|
|
|
|
// swagger:response BadgeList
|
|
|
|
type BadgeList struct {
|
|
|
|
// in:body
|
|
|
|
Body []Badge `json:"body"`
|
|
|
|
}
|