mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 11:33:11 +00:00 
			
		
		
		
	Allow back-dating user creation via the `adminCreateUser` API operation. `CreateUserOption` now has an optional field `created_at`, which can contain a datetime-formatted string. If this field is present, the user's `created_unix` database field will be updated to its value. This is important for Blender's migration of users from Phabricator to Gitea. There are many users, and the creation timestamp of their account can give us some indication as to how long someone's been part of the community. The back-dating is done in a separate query that just updates the user's `created_unix` field. This was the easiest and cleanest way I could find, as in the initial `INSERT` query the field always is set to "now".
		
			
				
	
	
		
			55 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			55 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2015 The Gogs Authors. All rights reserved.
 | |
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package structs
 | |
| 
 | |
| import "time"
 | |
| 
 | |
| // CreateUserOption create user options
 | |
| type CreateUserOption struct {
 | |
| 	SourceID  int64  `json:"source_id"`
 | |
| 	LoginName string `json:"login_name"`
 | |
| 	// required: true
 | |
| 	Username string `json:"username" binding:"Required;Username;MaxSize(40)"`
 | |
| 	FullName string `json:"full_name" binding:"MaxSize(100)"`
 | |
| 	// required: true
 | |
| 	// swagger:strfmt email
 | |
| 	Email string `json:"email" binding:"Required;Email;MaxSize(254)"`
 | |
| 	// required: true
 | |
| 	Password           string `json:"password" binding:"Required;MaxSize(255)"`
 | |
| 	MustChangePassword *bool  `json:"must_change_password"`
 | |
| 	SendNotify         bool   `json:"send_notify"`
 | |
| 	Restricted         *bool  `json:"restricted"`
 | |
| 	Visibility         string `json:"visibility" binding:"In(,public,limited,private)"`
 | |
| 
 | |
| 	// For explicitly setting the user creation timestamp. Useful when users are
 | |
| 	// migrated from other systems. When omitted, the user's creation timestamp
 | |
| 	// will be set to "now".
 | |
| 	Created *time.Time `json:"created_at"`
 | |
| }
 | |
| 
 | |
| // EditUserOption edit user options
 | |
| type EditUserOption struct {
 | |
| 	// required: true
 | |
| 	SourceID int64 `json:"source_id"`
 | |
| 	// required: true
 | |
| 	LoginName string `json:"login_name" binding:"Required"`
 | |
| 	// swagger:strfmt email
 | |
| 	Email                   *string `json:"email" binding:"MaxSize(254)"`
 | |
| 	FullName                *string `json:"full_name" binding:"MaxSize(100)"`
 | |
| 	Password                string  `json:"password" binding:"MaxSize(255)"`
 | |
| 	MustChangePassword      *bool   `json:"must_change_password"`
 | |
| 	Website                 *string `json:"website" binding:"OmitEmpty;ValidUrl;MaxSize(255)"`
 | |
| 	Location                *string `json:"location" binding:"MaxSize(50)"`
 | |
| 	Description             *string `json:"description" binding:"MaxSize(255)"`
 | |
| 	Active                  *bool   `json:"active"`
 | |
| 	Admin                   *bool   `json:"admin"`
 | |
| 	AllowGitHook            *bool   `json:"allow_git_hook"`
 | |
| 	AllowImportLocal        *bool   `json:"allow_import_local"`
 | |
| 	MaxRepoCreation         *int    `json:"max_repo_creation"`
 | |
| 	ProhibitLogin           *bool   `json:"prohibit_login"`
 | |
| 	AllowCreateOrganization *bool   `json:"allow_create_organization"`
 | |
| 	Restricted              *bool   `json:"restricted"`
 | |
| 	Visibility              string  `json:"visibility" binding:"In(,public,limited,private)"`
 | |
| }
 |