summaryrefslogtreecommitdiffstats
path: root/vendor/code.gitea.io/sdk
diff options
context:
space:
mode:
authorAntoine GIRARD <sapk@users.noreply.github.com>2017-04-16 14:51:04 +0200
committerBo-Yi Wu <appleboy.tw@gmail.com>2017-04-16 20:51:04 +0800
commitcf91cfb993bed1a412590305f594db81dc83bca8 (patch)
treeacad8c7466cce2097aaec42049f07674fa908124 /vendor/code.gitea.io/sdk
parent237270ef50ba00b3007ea10c2302bc240188e092 (diff)
downloadgitea-cf91cfb993bed1a412590305f594db81dc83bca8.tar.gz
gitea-cf91cfb993bed1a412590305f594db81dc83bca8.zip
Migrate WatchInfo struct to api (#1492)
* Remove WatchInfo and link to api struct * Add vendor temporary update * Return to gitea vendor source
Diffstat (limited to 'vendor/code.gitea.io/sdk')
-rw-r--r--vendor/code.gitea.io/sdk/gitea/issue_comment.go2
-rw-r--r--vendor/code.gitea.io/sdk/gitea/repo_watch.go41
-rw-r--r--vendor/code.gitea.io/sdk/gitea/status.go95
3 files changed, 137 insertions, 1 deletions
diff --git a/vendor/code.gitea.io/sdk/gitea/issue_comment.go b/vendor/code.gitea.io/sdk/gitea/issue_comment.go
index c6978f42da..0977f98a4a 100644
--- a/vendor/code.gitea.io/sdk/gitea/issue_comment.go
+++ b/vendor/code.gitea.io/sdk/gitea/issue_comment.go
@@ -47,7 +47,7 @@ func (c *Client) CreateIssueComment(owner, repo string, index int64, opt CreateI
return nil, err
}
comment := new(Comment)
- return comment, c.getParsedResponse("POST", fmt.Sprintf("/repos/:%s/:%s/issues/%d/comments", owner, repo, index), jsonHeader, bytes.NewReader(body), comment)
+ return comment, c.getParsedResponse("POST", fmt.Sprintf("/repos/%s/%s/issues/%d/comments", owner, repo, index), jsonHeader, bytes.NewReader(body), comment)
}
// EditIssueCommentOption is option when editing an issue comment.
diff --git a/vendor/code.gitea.io/sdk/gitea/repo_watch.go b/vendor/code.gitea.io/sdk/gitea/repo_watch.go
new file mode 100644
index 0000000000..ffc3e2d2c5
--- /dev/null
+++ b/vendor/code.gitea.io/sdk/gitea/repo_watch.go
@@ -0,0 +1,41 @@
+// 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 (
+ "fmt"
+ "net/http"
+ "time"
+)
+
+// WatchInfo represents a API watch status of one repository
+type WatchInfo struct {
+ Subscribed bool `json:"subscribed"`
+ Ignored bool `json:"ignored"`
+ Reason interface{} `json:"reason"`
+ CreatedAt time.Time `json:"created_at"`
+ URL string `json:"url"`
+ RepositoryURL string `json:"repository_url"`
+}
+
+// GetWatchedRepos list all the watched repos of user
+func (c *Client) GetWatchedRepos(user, pass string) ([]*Repository, error) {
+ repos := make([]*Repository, 0, 10)
+ return repos, c.getParsedResponse("GET", fmt.Sprintf("/users/%s/subscriptions", user),
+ http.Header{"Authorization": []string{"Basic " + BasicAuthEncode(user, pass)}}, nil, &repos)
+}
+
+// WatchRepo start to watch a repository
+func (c *Client) WatchRepo(user, pass, repoUser, repoName string) (*WatchInfo, error) {
+ i := new(WatchInfo)
+ return i, c.getParsedResponse("PUT", fmt.Sprintf("/repos/%s/%s/subscription", repoUser, repoName),
+ http.Header{"Authorization": []string{"Basic " + BasicAuthEncode(user, pass)}}, nil, i)
+}
+
+// UnWatchRepo start to watch a repository
+func (c *Client) UnWatchRepo(user, pass, repoUser, repoName string) (int, error) {
+ return c.getStatusCode("DELETE", fmt.Sprintf("/repos/%s/%s/subscription", repoUser, repoName),
+ http.Header{"Authorization": []string{"Basic " + BasicAuthEncode(user, pass)}}, nil)
+}
diff --git a/vendor/code.gitea.io/sdk/gitea/status.go b/vendor/code.gitea.io/sdk/gitea/status.go
new file mode 100644
index 0000000000..e694add1c3
--- /dev/null
+++ b/vendor/code.gitea.io/sdk/gitea/status.go
@@ -0,0 +1,95 @@
+// 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"`
+}
+
+// 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"`
+}
+
+// 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"`
+}
+
+// ListStatusesOption holds pagination information
+type ListStatusesOption struct {
+ Page int
+}
+
+// CreateStatus creates a new Status for a given Commit
+//
+// POST /repos/:owner/:repo/statuses/:sha
+func (c *Client) CreateStatus(owner, repo, sha string, opts CreateStatusOption) (*Status, error) {
+ body, err := json.Marshal(&opts)
+ if err != nil {
+ return nil, err
+ }
+ status := &Status{}
+ return status, c.getParsedResponse("POST", fmt.Sprintf("/repos/%s/%s/statuses/%s", owner, repo, sha),
+ jsonHeader, bytes.NewReader(body), status)
+}
+
+// ListStatuses returns all statuses for a given Commit
+//
+// GET /repos/:owner/:repo/commits/:ref/statuses
+func (c *Client) ListStatuses(owner, repo, sha string, opts ListStatusesOption) ([]*Status, error) {
+ statuses := make([]*Status, 0, 10)
+ return statuses, c.getParsedResponse("GET", fmt.Sprintf("/repos/%s/%s/commits/%s/statuses?page=%d", owner, repo, sha, opts.Page), nil, nil, &statuses)
+}
+
+// GetCombinedStatus returns the CombinedStatus for a given Commit
+//
+// GET /repos/:owner/:repo/commits/:ref/status
+func (c *Client) GetCombinedStatus(owner, repo, sha string) (*CombinedStatus, error) {
+ status := &CombinedStatus{}
+ return status, c.getParsedResponse("GET", fmt.Sprintf("/repos/%s/%s/commits/%s/status", owner, repo, sha), nil, nil, status)
+}