Gitea remote support

This commit is contained in:
Ryan McGuire 2024-01-16 15:46:32 -05:00
parent 9747261a76
commit 25820024cd
2 changed files with 80 additions and 37 deletions

View File

@ -1,16 +1,43 @@
package gitearemote
import (
"errors"
"fmt"
"strconv"
"strings"
"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/projects"
"gitlab.sweetwater.com/it/devops/tools/gitlab-project-manager/internal/remotes/remote"
)
const giteaReposPerPage = 20
func (r *GiteaRemote) ReposToProjects(repos []*gitea.Repository) []*projects.Project {
pList := make([]*projects.Project, len(repos))
for i, repo := range repos {
path := strings.Split(repo.FullName, "/")
var repoPath []string
if len(path) > 1 {
repoPath = path[:len(path)-1]
} else {
repoPath = path
}
project := &projects.Project{
ID: int(repo.ID),
Description: repo.Description,
SSHURLToRepo: repo.SSHURL,
HTTPURLToRepo: repo.CloneURL,
WebURL: repo.HTMLURL,
Name: repo.Name,
NameWithNamespace: repo.FullName,
Path: strings.Join(repoPath, "/"),
AvatarURL: repo.AvatarURL,
PathWithNamespace: strings.Join(path, "/"),
LastActivityAt: repo.Updated,
Remote: r.info.Host,
}
pList[i] = project
}
return pList
}
func (r *GiteaRemote) GetNumProjects(opts *remote.RemoteQueryOpts) int {
var projects int
@ -24,37 +51,3 @@ func (r *GiteaRemote) GetNumProjects(opts *remote.RemoteQueryOpts) int {
projects, _ = strconv.Atoi(resp.Header.Get("X-Total-Count"))
return projects
}
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
}
// TODO finish implementing project load support
for _, repo := range repos {
fmt.Printf("Repo: %#v\n", repo)
}
if resp.LastPage == resp.NextPage {
break
}
giteaListOpts.Page = resp.NextPage
}
pi.DoneChan <- nil
}

View 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
}