From ced1221ef65f4f0f40635bd64483f004d5eb72ce Mon Sep 17 00:00:00 2001 From: Thiago Rodrigues Date: Mon, 29 Aug 2016 22:23:59 -0300 Subject: [PATCH 1/2] adding pagination of repositories on bitbucketserver --- remote/bitbucketserver/internal/client.go | 54 ++++++++++++++--------- 1 file changed, 34 insertions(+), 20 deletions(-) diff --git a/remote/bitbucketserver/internal/client.go b/remote/bitbucketserver/internal/client.go index 11bf904f..5dec1896 100644 --- a/remote/bitbucketserver/internal/client.go +++ b/remote/bitbucketserver/internal/client.go @@ -4,6 +4,7 @@ import ( "bytes" "encoding/json" "fmt" + "strconv" log "github.com/Sirupsen/logrus" "github.com/drone/drone/model" "github.com/mrjones/oauth" @@ -16,7 +17,7 @@ const ( currentUserId = "%s/plugins/servlet/applinks/whoami" pathUser = "%s/rest/api/1.0/users/%s" pathRepo = "%s/rest/api/1.0/projects/%s/repos/%s" - pathRepos = "%s/rest/api/1.0/repos?limit=%s" + pathRepos = "%s/rest/api/1.0/repos?start=%s&limit=%s" pathHook = "%s/rest/api/1.0/projects/%s/repos/%s/settings/hooks/%s" pathSource = "%s/projects/%s/repos/%s/browse/%s?at=%s&raw" hookName = "com.atlassian.stash.plugin.stash-web-post-receive-hooks-plugin:postReceiveHook" @@ -91,25 +92,7 @@ func (c *Client) FindRepo(owner string, name string) (*Repo, error) { } func (c *Client) FindRepos() ([]*Repo, error) { - requestUrl := fmt.Sprintf(pathRepos, c.base, "1000") - log.Debug(fmt.Printf("request :%s", requestUrl)) - response, err := c.client.Get(requestUrl) - if err != nil { - return nil, err - } - defer response.Body.Close() - contents, err := ioutil.ReadAll(response.Body) - if err != nil { - return nil, err - } - var repoResponse Repos - err = json.Unmarshal(contents, &repoResponse) - if err != nil { - return nil, err - } - log.Debug(fmt.Printf("repoResponse: %+v\n", repoResponse)) - - return repoResponse.Values, nil + return c.paginatedRepos(0) } func (c *Client) FindRepoPerms(owner string, repo string) (*model.Perm, error) { @@ -213,3 +196,34 @@ func (c *Client) doDelete(url string) error { defer response.Body.Close() return nil } + +//Helper function to get repos paginated +func (c *Client) paginatedRepos(start int) ([]*Repo, error) { + limit := 1000 + requestUrl := fmt.Sprintf(pathRepos, c.base, strconv.Itoa(start), strconv.Itoa(limit)) + log.Debug(fmt.Printf("request :%s", requestUrl)) + response, err := c.client.Get(requestUrl) + if err != nil { + return nil, err + } + defer response.Body.Close() + contents, err := ioutil.ReadAll(response.Body) + if err != nil { + return nil, err + } + var repoResponse Repos + err = json.Unmarshal(contents, &repoResponse) + if err != nil { + return nil, err + } + log.Debug(fmt.Printf("repoResponse: %+v\n", repoResponse)) + + if(!repoResponse.IsLastPage){ + reposList, err := c.paginatedRepos(start + limit); + if err != nil { + return nil, err + } + repoResponse.Values = append(repoResponse.Values, reposList...) + } + return repoResponse.Values, nil +} \ No newline at end of file From 3a926b35be45b8dc63b682fa5c6f7b4234caf05d Mon Sep 17 00:00:00 2001 From: Thiago Rodrigues Date: Tue, 30 Aug 2016 00:06:35 -0300 Subject: [PATCH 2/2] better coding --- remote/bitbucketserver/internal/client.go | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) diff --git a/remote/bitbucketserver/internal/client.go b/remote/bitbucketserver/internal/client.go index 5dec1896..6a989fab 100644 --- a/remote/bitbucketserver/internal/client.go +++ b/remote/bitbucketserver/internal/client.go @@ -201,23 +201,18 @@ func (c *Client) doDelete(url string) error { func (c *Client) paginatedRepos(start int) ([]*Repo, error) { limit := 1000 requestUrl := fmt.Sprintf(pathRepos, c.base, strconv.Itoa(start), strconv.Itoa(limit)) - log.Debug(fmt.Printf("request :%s", requestUrl)) + log.Debugf("request :%s", requestUrl) response, err := c.client.Get(requestUrl) if err != nil { return nil, err } defer response.Body.Close() - contents, err := ioutil.ReadAll(response.Body) - if err != nil { - return nil, err - } var repoResponse Repos - err = json.Unmarshal(contents, &repoResponse) + err = json.NewDecoder(response.Body).Decode(&repoResponse) if err != nil { return nil, err } - log.Debug(fmt.Printf("repoResponse: %+v\n", repoResponse)) - + log.Debugf("repoResponse: %+v", repoResponse) if(!repoResponse.IsLastPage){ reposList, err := c.paginatedRepos(start + limit); if err != nil {