Gitea remote support
This commit is contained in:
50
internal/remotes/gitea/gitea_stream.go
Normal file
50
internal/remotes/gitea/gitea_stream.go
Normal file
@@ -0,0 +1,50 @@
|
||||
package gitearemote
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
|
||||
"code.gitea.io/sdk/gitea"
|
||||
"gitlab.sweetwater.com/it/devops/tools/gitlab-project-manager/internal/remotes/load"
|
||||
"gitlab.sweetwater.com/it/devops/tools/gitlab-project-manager/internal/remotes/remote"
|
||||
)
|
||||
|
||||
const giteaReposPerPage = 20
|
||||
|
||||
func (r *GiteaRemote) StreamProjects(pi *load.ProgressInfo, opts *remote.RemoteQueryOpts) {
|
||||
defer close(pi.ProgressChan)
|
||||
defer close(pi.ProjectsChan)
|
||||
|
||||
// Get projects. TODO support concurrency
|
||||
giteaListOpts := gitea.ListOptions{Page: 1, PageSize: giteaReposPerPage}
|
||||
for {
|
||||
repos, resp, err := r.api.ListMyRepos(gitea.ListReposOptions{ListOptions: giteaListOpts})
|
||||
|
||||
fmt.Printf("Gitea PrevPage %d, NextPage %d, Pages %d\n", resp.PrevPage, resp.NextPage, resp.LastPage)
|
||||
|
||||
if err != nil {
|
||||
pi.ErrorChan <- err
|
||||
break
|
||||
} else if len(repos) < 1 {
|
||||
pi.ErrorChan <- errors.New("No gitea repos found")
|
||||
break
|
||||
}
|
||||
|
||||
// Write updates to channels
|
||||
pi.ProjectsChan <- r.ReposToProjects(repos)
|
||||
pi.ProgressChan <- load.Progress{
|
||||
Page: giteaListOpts.Page,
|
||||
Pages: resp.LastPage,
|
||||
Projects: len(repos),
|
||||
TotalProjects: pi.NumProjects,
|
||||
}
|
||||
|
||||
if resp.LastPage == resp.NextPage {
|
||||
break
|
||||
}
|
||||
|
||||
giteaListOpts.Page = resp.NextPage
|
||||
}
|
||||
|
||||
pi.DoneChan <- nil
|
||||
}
|
||||
Reference in New Issue
Block a user