127 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| // Copyright 2015 The Gogs Authors. All rights reserved.
 | |
| // Copyright 2019 The Gitea 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"
 | |
| )
 | |
| 
 | |
| // AdminListUsersOptions options for listing admin users
 | |
| type AdminListUsersOptions struct {
 | |
| 	ListOptions
 | |
| }
 | |
| 
 | |
| // AdminListUsers lists all users
 | |
| func (c *Client) AdminListUsers(opt AdminListUsersOptions) ([]*User, *Response, error) {
 | |
| 	opt.setDefaults()
 | |
| 	users := make([]*User, 0, opt.PageSize)
 | |
| 	resp, err := c.getParsedResponse("GET", fmt.Sprintf("/admin/users?%s", opt.getURLQuery().Encode()), nil, nil, &users)
 | |
| 	return users, resp, err
 | |
| }
 | |
| 
 | |
| // CreateUserOption create user options
 | |
| type CreateUserOption struct {
 | |
| 	SourceID           int64  `json:"source_id"`
 | |
| 	LoginName          string `json:"login_name"`
 | |
| 	Username           string `json:"username"`
 | |
| 	FullName           string `json:"full_name"`
 | |
| 	Email              string `json:"email"`
 | |
| 	Password           string `json:"password"`
 | |
| 	MustChangePassword *bool  `json:"must_change_password"`
 | |
| 	SendNotify         bool   `json:"send_notify"`
 | |
| }
 | |
| 
 | |
| // Validate the CreateUserOption struct
 | |
| func (opt CreateUserOption) Validate() error {
 | |
| 	if len(opt.Email) == 0 {
 | |
| 		return fmt.Errorf("email is empty")
 | |
| 	}
 | |
| 	if len(opt.Username) == 0 {
 | |
| 		return fmt.Errorf("username is empty")
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // AdminCreateUser create a user
 | |
| func (c *Client) AdminCreateUser(opt CreateUserOption) (*User, *Response, error) {
 | |
| 	if err := opt.Validate(); err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	body, err := json.Marshal(&opt)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	user := new(User)
 | |
| 	resp, err := c.getParsedResponse("POST", "/admin/users", jsonHeader, bytes.NewReader(body), user)
 | |
| 	return user, resp, err
 | |
| }
 | |
| 
 | |
| // EditUserOption edit user options
 | |
| type EditUserOption struct {
 | |
| 	SourceID                int64   `json:"source_id"`
 | |
| 	LoginName               string  `json:"login_name"`
 | |
| 	Email                   *string `json:"email"`
 | |
| 	FullName                *string `json:"full_name"`
 | |
| 	Password                string  `json:"password"`
 | |
| 	MustChangePassword      *bool   `json:"must_change_password"`
 | |
| 	Website                 *string `json:"website"`
 | |
| 	Location                *string `json:"location"`
 | |
| 	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"`
 | |
| }
 | |
| 
 | |
| // AdminEditUser modify user informations
 | |
| func (c *Client) AdminEditUser(user string, opt EditUserOption) (*Response, error) {
 | |
| 	if err := escapeValidatePathSegments(&user); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	body, err := json.Marshal(&opt)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	_, resp, err := c.getResponse("PATCH", fmt.Sprintf("/admin/users/%s", user), jsonHeader, bytes.NewReader(body))
 | |
| 	return resp, err
 | |
| }
 | |
| 
 | |
| // AdminDeleteUser delete one user according name
 | |
| func (c *Client) AdminDeleteUser(user string) (*Response, error) {
 | |
| 	if err := escapeValidatePathSegments(&user); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	_, resp, err := c.getResponse("DELETE", fmt.Sprintf("/admin/users/%s", user), nil, nil)
 | |
| 	return resp, err
 | |
| }
 | |
| 
 | |
| // AdminCreateUserPublicKey adds a public key for the user
 | |
| func (c *Client) AdminCreateUserPublicKey(user string, opt CreateKeyOption) (*PublicKey, *Response, error) {
 | |
| 	if err := escapeValidatePathSegments(&user); err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	body, err := json.Marshal(&opt)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	key := new(PublicKey)
 | |
| 	resp, err := c.getParsedResponse("POST", fmt.Sprintf("/admin/users/%s/keys", user), jsonHeader, bytes.NewReader(body), key)
 | |
| 	return key, resp, err
 | |
| }
 | |
| 
 | |
| // AdminDeleteUserPublicKey deletes a user's public key
 | |
| func (c *Client) AdminDeleteUserPublicKey(user string, keyID int) (*Response, error) {
 | |
| 	if err := escapeValidatePathSegments(&user); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	_, resp, err := c.getResponse("DELETE", fmt.Sprintf("/admin/users/%s/keys/%d", user, keyID), nil, nil)
 | |
| 	return resp, err
 | |
| }
 |