mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 20:36:07 +01:00 
			
		
		
		
	* Update swagger documentation Add docs for missing endpoints Add documentation for request parameters Make parameter naming consistent Fix response documentation * Restore delete comments
		
			
				
	
	
		
			81 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2015 The Gogs Authors. All rights reserved.
 | 
						|
// Use of this source code is governed by a MIT-style
 | 
						|
// license that can be found in the LICENSE file.
 | 
						|
 | 
						|
package gitea
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"encoding/json"
 | 
						|
	"fmt"
 | 
						|
)
 | 
						|
 | 
						|
// 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;AlphaDashDot;MaxSize(35)"`
 | 
						|
	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)"`
 | 
						|
	SendNotify bool `json:"send_notify"`
 | 
						|
}
 | 
						|
 | 
						|
// AdminCreateUser create a user
 | 
						|
func (c *Client) AdminCreateUser(opt CreateUserOption) (*User, error) {
 | 
						|
	body, err := json.Marshal(&opt)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	user := new(User)
 | 
						|
	return user, c.getParsedResponse("POST", "/admin/users", jsonHeader, bytes.NewReader(body), user)
 | 
						|
}
 | 
						|
 | 
						|
// EditUserOption edit user options
 | 
						|
type EditUserOption struct {
 | 
						|
	SourceID int64 `json:"source_id"`
 | 
						|
	LoginName string `json:"login_name"`
 | 
						|
	FullName string `json:"full_name" binding:"MaxSize(100)"`
 | 
						|
	// required: true
 | 
						|
	// swagger:strfmt email
 | 
						|
	Email string `json:"email" binding:"Required;Email;MaxSize(254)"`
 | 
						|
	Password string `json:"password" binding:"MaxSize(255)"`
 | 
						|
	Website string `json:"website" binding:"MaxSize(50)"`
 | 
						|
	Location string `json:"location" binding:"MaxSize(50)"`
 | 
						|
	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"`
 | 
						|
}
 | 
						|
 | 
						|
// AdminEditUser modify user informations
 | 
						|
func (c *Client) AdminEditUser(user string, opt EditUserOption) error {
 | 
						|
	body, err := json.Marshal(&opt)
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
	_, err = c.getResponse("PATCH", fmt.Sprintf("/admin/users/%s", user), jsonHeader, bytes.NewReader(body))
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// AdminDeleteUser delete one user according name
 | 
						|
func (c *Client) AdminDeleteUser(user string) error {
 | 
						|
	_, err := c.getResponse("DELETE", fmt.Sprintf("/admin/users/%s", user), nil, nil)
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// AdminCreateUserPublicKey create one user with options
 | 
						|
func (c *Client) AdminCreateUserPublicKey(user string, opt CreateKeyOption) (*PublicKey, error) {
 | 
						|
	body, err := json.Marshal(&opt)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
	key := new(PublicKey)
 | 
						|
	return key, c.getParsedResponse("POST", fmt.Sprintf("/admin/users/%s/keys", user), jsonHeader, bytes.NewReader(body), key)
 | 
						|
}
 |