mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-11-04 00:11:04 +00:00 
			
		
		
		
	* first draft
* update gitea sdk to 9e280adb4da
* adapt feat of updated sdk
* releases now works
* break the Reactions loop
* use convertGiteaLabel
* fix endless loop because paggination is not supported there !!!
* rename gitea local uploader files
* pagination can bite you in the ass
* Version Checks
* lint
* docs
* rename gitea sdk import to miss future conficts
* go-swagger: dont scan the sdk structs
* make sure gitea can shutdown gracefully
* make GetPullRequests and GetIssues similar
* rm useles
* Add Test: started ...
* ... add tests ...
* Add tests and Fixing things
* Workaround missing SHA
* Adapt: Ensure that all migration requests are cancellable
(714ab71ddc)
* LINT: fix misspells in test set
* adapt ListMergeRequestAwardEmoji
* update sdk
* Return error when creating giteadownloader failed
* update sdk
* adapt new sdk
* adopt new features
* check version before err
* adapt: 'migrate service type switch page'
* optimize
* Fix DefaultBranch
* impruve
* handle subPath
* fix test
* Fix ReviewCommentPosition
* test GetReviews
* add DefaultBranch int test set
* rm unused
* Update SDK to v0.13.0
* addopt sdk changes
* found better link
* format template
* Update Docs
* Update Gitea SDK (v0.13.1)
		
	
			
		
			
				
	
	
		
			114 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			114 lines
		
	
	
	
		
			3.8 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"`
 | 
						|
	FullName                string `json:"full_name"`
 | 
						|
	Email                   string `json:"email"`
 | 
						|
	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) {
 | 
						|
	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) {
 | 
						|
	_, 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) {
 | 
						|
	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) {
 | 
						|
	_, resp, err := c.getResponse("DELETE", fmt.Sprintf("/admin/users/%s/keys/%d", user, keyID), nil, nil)
 | 
						|
	return resp, err
 | 
						|
}
 |