mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-31 06:21:11 +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)
		
	
			
		
			
				
	
	
		
			92 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			92 lines
		
	
	
	
		
			3.2 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| // Copyright 2017 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"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // StatusState holds the state of a Status
 | |
| // It can be "pending", "success", "error", "failure", and "warning"
 | |
| type StatusState string
 | |
| 
 | |
| const (
 | |
| 	// StatusPending is for when the Status is Pending
 | |
| 	StatusPending StatusState = "pending"
 | |
| 	// StatusSuccess is for when the Status is Success
 | |
| 	StatusSuccess StatusState = "success"
 | |
| 	// StatusError is for when the Status is Error
 | |
| 	StatusError StatusState = "error"
 | |
| 	// StatusFailure is for when the Status is Failure
 | |
| 	StatusFailure StatusState = "failure"
 | |
| 	// StatusWarning is for when the Status is Warning
 | |
| 	StatusWarning StatusState = "warning"
 | |
| )
 | |
| 
 | |
| // Status holds a single Status of a single Commit
 | |
| type Status struct {
 | |
| 	ID          int64       `json:"id"`
 | |
| 	State       StatusState `json:"status"`
 | |
| 	TargetURL   string      `json:"target_url"`
 | |
| 	Description string      `json:"description"`
 | |
| 	URL         string      `json:"url"`
 | |
| 	Context     string      `json:"context"`
 | |
| 	Creator     *User       `json:"creator"`
 | |
| 	Created     time.Time   `json:"created_at"`
 | |
| 	Updated     time.Time   `json:"updated_at"`
 | |
| }
 | |
| 
 | |
| // CreateStatusOption holds the information needed to create a new Status for a Commit
 | |
| type CreateStatusOption struct {
 | |
| 	State       StatusState `json:"state"`
 | |
| 	TargetURL   string      `json:"target_url"`
 | |
| 	Description string      `json:"description"`
 | |
| 	Context     string      `json:"context"`
 | |
| }
 | |
| 
 | |
| // CreateStatus creates a new Status for a given Commit
 | |
| func (c *Client) CreateStatus(owner, repo, sha string, opts CreateStatusOption) (*Status, *Response, error) {
 | |
| 	body, err := json.Marshal(&opts)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 	status := new(Status)
 | |
| 	resp, err := c.getParsedResponse("POST", fmt.Sprintf("/repos/%s/%s/statuses/%s", owner, repo, sha), jsonHeader, bytes.NewReader(body), status)
 | |
| 	return status, resp, err
 | |
| }
 | |
| 
 | |
| // ListStatusesOption options for listing a repository's commit's statuses
 | |
| type ListStatusesOption struct {
 | |
| 	ListOptions
 | |
| }
 | |
| 
 | |
| // ListStatuses returns all statuses for a given Commit
 | |
| func (c *Client) ListStatuses(owner, repo, sha string, opt ListStatusesOption) ([]*Status, *Response, error) {
 | |
| 	opt.setDefaults()
 | |
| 	statuses := make([]*Status, 0, opt.PageSize)
 | |
| 	resp, err := c.getParsedResponse("GET", fmt.Sprintf("/repos/%s/%s/commits/%s/statuses?%s", owner, repo, sha, opt.getURLQuery().Encode()), nil, nil, &statuses)
 | |
| 	return statuses, resp, err
 | |
| }
 | |
| 
 | |
| // CombinedStatus holds the combined state of several statuses for a single commit
 | |
| type CombinedStatus struct {
 | |
| 	State      StatusState `json:"state"`
 | |
| 	SHA        string      `json:"sha"`
 | |
| 	TotalCount int         `json:"total_count"`
 | |
| 	Statuses   []*Status   `json:"statuses"`
 | |
| 	Repository *Repository `json:"repository"`
 | |
| 	CommitURL  string      `json:"commit_url"`
 | |
| 	URL        string      `json:"url"`
 | |
| }
 | |
| 
 | |
| // GetCombinedStatus returns the CombinedStatus for a given Commit
 | |
| func (c *Client) GetCombinedStatus(owner, repo, sha string) (*CombinedStatus, *Response, error) {
 | |
| 	status := new(CombinedStatus)
 | |
| 	resp, err := c.getParsedResponse("GET", fmt.Sprintf("/repos/%s/%s/commits/%s/status", owner, repo, sha), nil, nil, status)
 | |
| 	return status, resp, err
 | |
| }
 |