mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	This PR changes the `opts` argument in `SearchUsers()` to be passed by value instead of by pointer, as its mutations do not escape the function scope and are not used elsewhere. This simplifies reasoning about the function and avoids unnecessary pointer usage. This insight emerged during an initial attempt to refactor `RenderUserSearch()`, which currently intermixes multiple concerns. Co-authored-by: Philip Peterson <philip-peterson@users.noreply.github.com>
		
			
				
	
	
		
			124 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2015 The Gogs Authors. All rights reserved.
 | |
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package admin
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	"code.gitea.io/gitea/models/organization"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	api "code.gitea.io/gitea/modules/structs"
 | |
| 	"code.gitea.io/gitea/modules/web"
 | |
| 	"code.gitea.io/gitea/routers/api/v1/utils"
 | |
| 	"code.gitea.io/gitea/services/context"
 | |
| 	"code.gitea.io/gitea/services/convert"
 | |
| )
 | |
| 
 | |
| // CreateOrg api for create organization
 | |
| func CreateOrg(ctx *context.APIContext) {
 | |
| 	// swagger:operation POST /admin/users/{username}/orgs admin adminCreateOrg
 | |
| 	// ---
 | |
| 	// summary: Create an organization
 | |
| 	// consumes:
 | |
| 	// - application/json
 | |
| 	// produces:
 | |
| 	// - application/json
 | |
| 	// parameters:
 | |
| 	// - name: username
 | |
| 	//   in: path
 | |
| 	//   description: username of the user that will own the created organization
 | |
| 	//   type: string
 | |
| 	//   required: true
 | |
| 	// - name: organization
 | |
| 	//   in: body
 | |
| 	//   required: true
 | |
| 	//   schema: { "$ref": "#/definitions/CreateOrgOption" }
 | |
| 	// responses:
 | |
| 	//   "201":
 | |
| 	//     "$ref": "#/responses/Organization"
 | |
| 	//   "403":
 | |
| 	//     "$ref": "#/responses/forbidden"
 | |
| 	//   "422":
 | |
| 	//     "$ref": "#/responses/validationError"
 | |
| 
 | |
| 	form := web.GetForm(ctx).(*api.CreateOrgOption)
 | |
| 
 | |
| 	visibility := api.VisibleTypePublic
 | |
| 	if form.Visibility != "" {
 | |
| 		visibility = api.VisibilityModes[form.Visibility]
 | |
| 	}
 | |
| 
 | |
| 	org := &organization.Organization{
 | |
| 		Name:        form.UserName,
 | |
| 		FullName:    form.FullName,
 | |
| 		Description: form.Description,
 | |
| 		Website:     form.Website,
 | |
| 		Location:    form.Location,
 | |
| 		IsActive:    true,
 | |
| 		Type:        user_model.UserTypeOrganization,
 | |
| 		Visibility:  visibility,
 | |
| 	}
 | |
| 
 | |
| 	if err := organization.CreateOrganization(ctx, org, ctx.ContextUser); err != nil {
 | |
| 		if user_model.IsErrUserAlreadyExist(err) ||
 | |
| 			db.IsErrNameReserved(err) ||
 | |
| 			db.IsErrNameCharsNotAllowed(err) ||
 | |
| 			db.IsErrNamePatternNotAllowed(err) {
 | |
| 			ctx.APIError(http.StatusUnprocessableEntity, err)
 | |
| 		} else {
 | |
| 			ctx.APIErrorInternal(err)
 | |
| 		}
 | |
| 		return
 | |
| 	}
 | |
| 
 | |
| 	ctx.JSON(http.StatusCreated, convert.ToOrganization(ctx, org))
 | |
| }
 | |
| 
 | |
| // GetAllOrgs API for getting information of all the organizations
 | |
| func GetAllOrgs(ctx *context.APIContext) {
 | |
| 	// swagger:operation GET /admin/orgs admin adminGetAllOrgs
 | |
| 	// ---
 | |
| 	// summary: List all organizations
 | |
| 	// produces:
 | |
| 	// - application/json
 | |
| 	// parameters:
 | |
| 	// - name: page
 | |
| 	//   in: query
 | |
| 	//   description: page number of results to return (1-based)
 | |
| 	//   type: integer
 | |
| 	// - name: limit
 | |
| 	//   in: query
 | |
| 	//   description: page size of results
 | |
| 	//   type: integer
 | |
| 	// responses:
 | |
| 	//   "200":
 | |
| 	//     "$ref": "#/responses/OrganizationList"
 | |
| 	//   "403":
 | |
| 	//     "$ref": "#/responses/forbidden"
 | |
| 
 | |
| 	listOptions := utils.GetListOptions(ctx)
 | |
| 
 | |
| 	users, maxResults, err := user_model.SearchUsers(ctx, user_model.SearchUserOptions{
 | |
| 		Actor:       ctx.Doer,
 | |
| 		Type:        user_model.UserTypeOrganization,
 | |
| 		OrderBy:     db.SearchOrderByAlphabetically,
 | |
| 		ListOptions: listOptions,
 | |
| 		Visible:     []api.VisibleType{api.VisibleTypePublic, api.VisibleTypeLimited, api.VisibleTypePrivate},
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		ctx.APIErrorInternal(err)
 | |
| 		return
 | |
| 	}
 | |
| 	orgs := make([]*api.Organization, len(users))
 | |
| 	for i := range users {
 | |
| 		orgs[i] = convert.ToOrganization(ctx, organization.OrgFromUser(users[i]))
 | |
| 	}
 | |
| 
 | |
| 	ctx.SetLinkHeader(int(maxResults), listOptions.PageSize)
 | |
| 	ctx.SetTotalCountHeader(maxResults)
 | |
| 	ctx.JSON(http.StatusOK, &orgs)
 | |
| }
 |