mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 03:22:36 +00:00 
			
		
		
		
	This commit contains UI changes, tests and migrations for a feature that lets users optionally hide their pronouns from the general public. This is useful if a person wants to disclose that information to a smaller set of people on a local instance belonging to a local community/association. Co-authored-by: Gusted <gusted@noreply.codeberg.org> Co-authored-by: Beowulf <beowulf@beocode.eu> Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/6773 Reviewed-by: Gusted <gusted@noreply.codeberg.org> Co-authored-by: Panagiotis "Ivory" Vasilopoulos <git@n0toose.net> Co-committed-by: Panagiotis "Ivory" Vasilopoulos <git@n0toose.net>
		
			
				
	
	
		
			122 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // 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 ID of the user's Authentication Source
 | |
| 	SourceID int64 `json:"source_id"`
 | |
| 	// 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"`
 | |
| 	// URL to the user's gitea page
 | |
| 	HTMLURL string `json:"html_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 pronouns
 | |
| 	Pronouns string `json:"pronouns"`
 | |
| 	// 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) {
 | |
| 	// Redeclaring 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"`
 | |
| 	Pronouns            string `json:"pronouns"`
 | |
| 	Language            string `json:"language"`
 | |
| 	Theme               string `json:"theme"`
 | |
| 	DiffViewStyle       string `json:"diff_view_style"`
 | |
| 	EnableRepoUnitHints bool   `json:"enable_repo_unit_hints"`
 | |
| 	// Privacy
 | |
| 	HideEmail    bool `json:"hide_email"`
 | |
| 	HidePronouns bool `json:"hide_pronouns"`
 | |
| 	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)"`
 | |
| 	Pronouns            *string `json:"pronouns" binding:"MaxSize(50)"`
 | |
| 	Language            *string `json:"language"`
 | |
| 	Theme               *string `json:"theme"`
 | |
| 	DiffViewStyle       *string `json:"diff_view_style"`
 | |
| 	EnableRepoUnitHints *bool   `json:"enable_repo_unit_hints"`
 | |
| 	// Privacy
 | |
| 	HideEmail    *bool `json:"hide_email"`
 | |
| 	HidePronouns *bool `json:"hide_pronouns"`
 | |
| 	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"`
 | |
| }
 |