mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 21:28:11 +09:00 
			
		
		
		
	Replace #16455 Close #21803 Mixing different Gitea contexts together causes some problems: 1. Unable to respond proper content when error occurs, eg: Web should respond HTML while API should respond JSON 2. Unclear dependency, eg: it's unclear when Context is used in APIContext, which fields should be initialized, which methods are necessary. To make things clear, this PR introduces a Base context, it only provides basic Req/Resp/Data features. This PR mainly moves code. There are still many legacy problems and TODOs in code, leave unrelated changes to future PRs.
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2014 The Gogs Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package forms
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 
 | |
| 	"code.gitea.io/gitea/modules/context"
 | |
| 	"code.gitea.io/gitea/modules/structs"
 | |
| 	"code.gitea.io/gitea/modules/web/middleware"
 | |
| 
 | |
| 	"gitea.com/go-chi/binding"
 | |
| )
 | |
| 
 | |
| // AdminCreateUserForm form for admin to create user
 | |
| type AdminCreateUserForm struct {
 | |
| 	LoginType          string `binding:"Required"`
 | |
| 	LoginName          string
 | |
| 	UserName           string `binding:"Required;Username;MaxSize(40)"`
 | |
| 	Email              string `binding:"Required;Email;MaxSize(254)"`
 | |
| 	Password           string `binding:"MaxSize(255)"`
 | |
| 	SendNotify         bool
 | |
| 	MustChangePassword bool
 | |
| 	Visibility         structs.VisibleType
 | |
| }
 | |
| 
 | |
| // Validate validates form fields
 | |
| func (f *AdminCreateUserForm) Validate(req *http.Request, errs binding.Errors) binding.Errors {
 | |
| 	ctx := context.GetValidateContext(req)
 | |
| 	return middleware.Validate(errs, ctx.Data, f, ctx.Locale)
 | |
| }
 | |
| 
 | |
| // AdminEditUserForm form for admin to create user
 | |
| type AdminEditUserForm struct {
 | |
| 	LoginType               string `binding:"Required"`
 | |
| 	UserName                string `binding:"Username;MaxSize(40)"`
 | |
| 	LoginName               string
 | |
| 	FullName                string `binding:"MaxSize(100)"`
 | |
| 	Email                   string `binding:"Required;Email;MaxSize(254)"`
 | |
| 	Password                string `binding:"MaxSize(255)"`
 | |
| 	Website                 string `binding:"ValidUrl;MaxSize(255)"`
 | |
| 	Location                string `binding:"MaxSize(50)"`
 | |
| 	MaxRepoCreation         int
 | |
| 	Active                  bool
 | |
| 	Admin                   bool
 | |
| 	Restricted              bool
 | |
| 	AllowGitHook            bool
 | |
| 	AllowImportLocal        bool
 | |
| 	AllowCreateOrganization bool
 | |
| 	ProhibitLogin           bool
 | |
| 	Reset2FA                bool `form:"reset_2fa"`
 | |
| 	Visibility              structs.VisibleType
 | |
| }
 | |
| 
 | |
| // Validate validates form fields
 | |
| func (f *AdminEditUserForm) Validate(req *http.Request, errs binding.Errors) binding.Errors {
 | |
| 	ctx := context.GetValidateContext(req)
 | |
| 	return middleware.Validate(errs, ctx.Data, f, ctx.Locale)
 | |
| }
 | |
| 
 | |
| // AdminDashboardForm form for admin dashboard operations
 | |
| type AdminDashboardForm struct {
 | |
| 	Op   string `binding:"required"`
 | |
| 	From string
 | |
| }
 | |
| 
 | |
| // Validate validates form fields
 | |
| func (f *AdminDashboardForm) Validate(req *http.Request, errs binding.Errors) binding.Errors {
 | |
| 	ctx := context.GetValidateContext(req)
 | |
| 	return middleware.Validate(errs, ctx.Data, f, ctx.Locale)
 | |
| }
 |