with process repos

This commit is contained in:
Kasper Juul Hermansen 2022-09-15 10:42:44 +02:00
parent 0ca78b015e
commit 04d1ffc971
Signed by: kjuulh
GPG Key ID: 57B6E1465221F912
2 changed files with 27 additions and 2 deletions

View File

@ -22,7 +22,7 @@ func CreateKrakenProcessCmd() *cobra.Command {
Path string `json:"path"` Path string `json:"path"`
}{ }{
Repository: "git@git.front.kjuulh.io:kjuulh/kraken.git", Repository: "git@git.front.kjuulh.io:kjuulh/kraken.git",
Branch: "feature/add-actions", Branch: "feature/process_repos",
Path: "_examples/actions/write_a_readme/", Path: "_examples/actions/write_a_readme/",
}) })
if err != nil { if err != nil {

View File

@ -7,6 +7,8 @@ import (
"time" "time"
"git.front.kjuulh.io/kjuulh/kraken/internal/actions" "git.front.kjuulh.io/kjuulh/kraken/internal/actions"
"git.front.kjuulh.io/kjuulh/kraken/internal/gitproviders"
"git.front.kjuulh.io/kjuulh/kraken/internal/schema"
"git.front.kjuulh.io/kjuulh/kraken/internal/services/providers" "git.front.kjuulh.io/kjuulh/kraken/internal/services/providers"
"git.front.kjuulh.io/kjuulh/kraken/internal/services/storage" "git.front.kjuulh.io/kjuulh/kraken/internal/services/storage"
"go.uber.org/zap" "go.uber.org/zap"
@ -18,12 +20,14 @@ type (
storage *storage.Service storage *storage.Service
git *providers.Git git *providers.Git
actionCreator *actions.ActionCreator actionCreator *actions.ActionCreator
gitea *gitproviders.Gitea
} }
ProcessReposDeps interface { ProcessReposDeps interface {
GetStorageService() *storage.Service GetStorageService() *storage.Service
GetGitProvider() *providers.Git GetGitProvider() *providers.Git
GetActionCreator() *actions.ActionCreator GetActionCreator() *actions.ActionCreator
GetGitea() *gitproviders.Gitea
} }
) )
@ -33,6 +37,7 @@ func NewProcessRepos(logger *zap.Logger, deps ProcessReposDeps) *ProcessRepos {
storage: deps.GetStorageService(), storage: deps.GetStorageService(),
git: deps.GetGitProvider(), git: deps.GetGitProvider(),
actionCreator: deps.GetActionCreator(), actionCreator: deps.GetActionCreator(),
gitea: deps.GetGitea(),
} }
} }
@ -48,7 +53,10 @@ func (pr *ProcessRepos) Process(ctx context.Context, repository string, branch s
return err return err
} }
repositoryUrls := action.Schema.Select.Repositories repositoryUrls, err := pr.getRepoUrls(ctx, action.Schema)
if err != nil {
return err
}
wg := sync.WaitGroup{} wg := sync.WaitGroup{}
wg.Add(len(repositoryUrls)) wg.Add(len(repositoryUrls))
@ -76,6 +84,23 @@ func (pr *ProcessRepos) Process(ctx context.Context, repository string, branch s
return nil return nil
} }
func (pr *ProcessRepos) getRepoUrls(ctx context.Context, schema *schema.KrakenSchema) ([]string, error) {
repoUrls := make([]string, 0)
repoUrls = append(repoUrls, schema.Select.Repositories...)
for _, provider := range schema.Select.Providers {
repos, err := pr.gitea.ListRepositoriesForOrganization(ctx, provider.Gitea, provider.Organisation)
if err != nil {
return nil, err
}
repoUrls = append(repoUrls, repos...)
}
return repoUrls, nil
}
func (pr *ProcessRepos) processRepo(ctx context.Context, repoUrl string, action *actions.Action) error { func (pr *ProcessRepos) processRepo(ctx context.Context, repoUrl string, action *actions.Action) error {
cleanup, area, err := pr.prepareAction(ctx) cleanup, area, err := pr.prepareAction(ctx)
defer func() { defer func() {