123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- // Copyright 2014 The Gogs Authors. All rights reserved.
- // SPDX-License-Identifier: MIT
-
- package structs
-
- import (
- "time"
-
- "code.gitea.io/gitea/modules/json"
- )
-
- // User represents a user
- // swagger:model
- type User struct {
- // the user's id
- ID int64 `json:"id"`
- // the user's username
- UserName string `json:"login"`
- // the user's authentication sign-in name.
- // default: empty
- LoginName string `json:"login_name"`
- // the user's full name
- FullName string `json:"full_name"`
- // swagger:strfmt email
- Email string `json:"email"`
- // URL to the user's avatar
- AvatarURL string `json:"avatar_url"`
- // User locale
- Language string `json:"language"`
- // Is the user an administrator
- IsAdmin bool `json:"is_admin"`
- // swagger:strfmt date-time
- LastLogin time.Time `json:"last_login,omitempty"`
- // swagger:strfmt date-time
- Created time.Time `json:"created,omitempty"`
- // Is user restricted
- Restricted bool `json:"restricted"`
- // Is user active
- IsActive bool `json:"active"`
- // Is user login prohibited
- ProhibitLogin bool `json:"prohibit_login"`
- // the user's location
- Location string `json:"location"`
- // the user's website
- Website string `json:"website"`
- // the user's description
- Description string `json:"description"`
- // User visibility level option: public, limited, private
- Visibility string `json:"visibility"`
-
- // user counts
- Followers int `json:"followers_count"`
- Following int `json:"following_count"`
- StarredRepos int `json:"starred_repos_count"`
- }
-
- // 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})
- }
-
- // 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"`
- }
-
- // 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"`
- }
-
- // UpdateUserAvatarUserOption options when updating the user avatar
- type UpdateUserAvatarOption struct {
- // image must be base64 encoded
- Image string `json:"image" binding:"Required"`
- }
|