with actions repo
This commit is contained in:
parent
ce55f6523c
commit
e40e7cc88b
@ -23,7 +23,7 @@ func CreateKrakenProcessCmd() *cobra.Command {
|
|||||||
}{
|
}{
|
||||||
Repository: "git@git.front.kjuulh.io:kjuulh/kraken.git",
|
Repository: "git@git.front.kjuulh.io:kjuulh/kraken.git",
|
||||||
Branch: "v0.1",
|
Branch: "v0.1",
|
||||||
Path: "_examples/actions/write_a_readme/kraken.yml",
|
Path: "_examples/actions/write_a_readme/",
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
|
@ -47,18 +47,13 @@ func (ac *ActionCreator) Prepare(ctx context.Context, ops *ActionCreatorOps) (*A
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
cloneCtx, _ := context.WithTimeout(ctx, time.Second*5)
|
cloneCtx, _ := context.WithTimeout(ctx, time.Second*10)
|
||||||
repo, err := ac.git.Clone(cloneCtx, area, ops.RepositoryUrl)
|
_, err = ac.git.CloneBranch(cloneCtx, area, ops.RepositoryUrl, ops.Branch)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ac.logger.Error("could not clone repo", zap.Error(err))
|
ac.logger.Error("could not clone repo", zap.Error(err))
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = ac.git.Checkout(ctx, repo, ops.Branch)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
executorUrl := path.Join(area.Path, ops.Path)
|
executorUrl := path.Join(area.Path, ops.Path)
|
||||||
if _, err = os.Stat(executorUrl); os.IsNotExist(err) {
|
if _, err = os.Stat(executorUrl); os.IsNotExist(err) {
|
||||||
return nil, fmt.Errorf("path is invalid: %s", ops.Path)
|
return nil, fmt.Errorf("path is invalid: %s", ops.Path)
|
||||||
@ -74,6 +69,8 @@ func (ac *ActionCreator) Prepare(ctx context.Context, ops *ActionCreatorOps) (*A
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ac.logger.Debug("Action creator done")
|
||||||
|
|
||||||
return &Action{
|
return &Action{
|
||||||
Schema: krakenSchema,
|
Schema: krakenSchema,
|
||||||
}, nil
|
}, nil
|
||||||
|
@ -34,6 +34,9 @@ func CommandRoute(logger *zap.Logger, app *gin.Engine, deps *serverdeps.ServerDe
|
|||||||
ctx := context.WithValue(context.Background(), jobs.JobId{}, jobId)
|
ctx := context.WithValue(context.Background(), jobs.JobId{}, jobId)
|
||||||
processRepos := commands.NewProcessRepos(logger, deps)
|
processRepos := commands.NewProcessRepos(logger, deps)
|
||||||
err = processRepos.Process(ctx, repository, branch, path)
|
err = processRepos.Process(ctx, repository, branch, path)
|
||||||
|
if err != nil {
|
||||||
|
logger.Error("could not process repo", zap.Error(err))
|
||||||
|
}
|
||||||
}(request.Repository, request.Branch, request.Path, jobId)
|
}(request.Repository, request.Branch, request.Path, jobId)
|
||||||
|
|
||||||
c.Status(http.StatusAccepted)
|
c.Status(http.StatusAccepted)
|
||||||
|
@ -48,7 +48,7 @@ func (pr *ProcessRepos) Process(ctx context.Context, repository string, branch s
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
repositoryUrls := make([]string, 0)
|
repositoryUrls := action.Schema.Select.Repositories
|
||||||
|
|
||||||
wg := sync.WaitGroup{}
|
wg := sync.WaitGroup{}
|
||||||
wg.Add(len(repositoryUrls))
|
wg.Add(len(repositoryUrls))
|
||||||
@ -60,7 +60,6 @@ func (pr *ProcessRepos) Process(ctx context.Context, repository string, branch s
|
|||||||
}()
|
}()
|
||||||
err := pr.processRepo(ctx, repoUrl, action)
|
err := pr.processRepo(ctx, repoUrl, action)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
pr.logger.Error("could not process repo", zap.Error(err))
|
|
||||||
errChan <- err
|
errChan <- err
|
||||||
}
|
}
|
||||||
}(ctx, repoUrl)
|
}(ctx, repoUrl)
|
||||||
@ -113,7 +112,6 @@ func (pr *ProcessRepos) prepareAction(
|
|||||||
pr.logger.Debug("Creating area")
|
pr.logger.Debug("Creating area")
|
||||||
area, err := pr.storage.CreateArea(ctx)
|
area, err := pr.storage.CreateArea(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
pr.logger.Error("failed to allocate area", zap.Error(err))
|
|
||||||
return nil, nil, err
|
return nil, nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,13 +131,11 @@ func (pr *ProcessRepos) clone(ctx context.Context, area *storage.Area, repoUrl s
|
|||||||
cloneCtx, _ := context.WithTimeout(ctx, time.Second*5)
|
cloneCtx, _ := context.WithTimeout(ctx, time.Second*5)
|
||||||
repo, err := pr.git.Clone(cloneCtx, area, repoUrl)
|
repo, err := pr.git.Clone(cloneCtx, area, repoUrl)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
pr.logger.Error("could not clone repo", zap.Error(err))
|
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = pr.git.CreateBranch(ctx, repo)
|
err = pr.git.CreateBranch(ctx, repo)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
pr.logger.Error("could not create branch", zap.Error(err))
|
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,9 +153,12 @@ func (pr *ProcessRepos) commit(ctx context.Context, area *storage.Area, repo *pr
|
|||||||
return fmt.Errorf("could not get diff: %w", err)
|
return fmt.Errorf("could not get diff: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = pr.git.Push(ctx, repo)
|
dryrun := true
|
||||||
if err != nil {
|
if !dryrun {
|
||||||
return fmt.Errorf("could not push to repo: %w", err)
|
err = pr.git.Push(ctx, repo)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("could not push to repo: %w", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,7 @@ func NewGit(logger *zap.Logger, gitConfig *GitConfig, openPGP *signer.OpenPGP) *
|
|||||||
return &Git{logger: logger, gitConfig: gitConfig, openPGP: openPGP}
|
return &Git{logger: logger, gitConfig: gitConfig, openPGP: openPGP}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (g *Git) Clone(ctx context.Context, storageArea *storage.Area, repoUrl string) (*GitRepo, error) {
|
func (g *Git) CloneBranch(ctx context.Context, storageArea *storage.Area, repoUrl string, branch string) (*GitRepo, error) {
|
||||||
g.logger.Debug(
|
g.logger.Debug(
|
||||||
"cloning repository",
|
"cloning repository",
|
||||||
zap.String("repoUrl", repoUrl),
|
zap.String("repoUrl", repoUrl),
|
||||||
@ -69,8 +69,8 @@ func (g *Git) Clone(ctx context.Context, storageArea *storage.Area, repoUrl stri
|
|||||||
URL: repoUrl,
|
URL: repoUrl,
|
||||||
Auth: auth,
|
Auth: auth,
|
||||||
RemoteName: "origin",
|
RemoteName: "origin",
|
||||||
ReferenceName: "refs/heads/main",
|
ReferenceName: plumbing.NewBranchReferenceName(branch),
|
||||||
SingleBranch: false,
|
SingleBranch: true,
|
||||||
NoCheckout: false,
|
NoCheckout: false,
|
||||||
Depth: 1,
|
Depth: 1,
|
||||||
RecurseSubmodules: 1,
|
RecurseSubmodules: 1,
|
||||||
@ -90,19 +90,41 @@ func (g *Git) Clone(ctx context.Context, storageArea *storage.Area, repoUrl stri
|
|||||||
return &GitRepo{repo: repo}, nil
|
return &GitRepo{repo: repo}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (g *Git) Checkout(ctx context.Context, gitRepo *GitRepo, branch string) error {
|
func (g *Git) Clone(ctx context.Context, storageArea *storage.Area, repoUrl string) (*GitRepo, error) {
|
||||||
wt, err := gitRepo.repo.Worktree()
|
g.logger.Debug(
|
||||||
|
"cloning repository",
|
||||||
|
zap.String("repoUrl", repoUrl),
|
||||||
|
zap.String("path", storageArea.Path),
|
||||||
|
)
|
||||||
|
|
||||||
|
auth, err := g.GetAuth()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return wt.Checkout(&git.CheckoutOptions{
|
cloneOptions := git.CloneOptions{
|
||||||
Hash: [20]byte{},
|
URL: repoUrl,
|
||||||
Branch: plumbing.NewBranchReferenceName(branch),
|
Auth: auth,
|
||||||
Create: false,
|
RemoteName: "origin",
|
||||||
Force: false,
|
ReferenceName: "refs/heads/main",
|
||||||
Keep: false,
|
SingleBranch: true,
|
||||||
})
|
NoCheckout: false,
|
||||||
|
Depth: 1,
|
||||||
|
RecurseSubmodules: 1,
|
||||||
|
Progress: g.getProgressWriter(),
|
||||||
|
Tags: 0,
|
||||||
|
InsecureSkipTLS: false,
|
||||||
|
CABundle: []byte{},
|
||||||
|
}
|
||||||
|
|
||||||
|
repo, err := git.PlainCloneContext(ctx, storageArea.Path, false, &cloneOptions)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
g.logger.Debug("done cloning repo")
|
||||||
|
|
||||||
|
return &GitRepo{repo: repo}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (g *Git) getProgressWriter() *zapio.Writer {
|
func (g *Git) getProgressWriter() *zapio.Writer {
|
||||||
|
10
roadmap.md
10
roadmap.md
@ -11,14 +11,14 @@
|
|||||||
|
|
||||||
### Not in scope
|
### Not in scope
|
||||||
|
|
||||||
- [ ] Pooled runners
|
- Pooled runners
|
||||||
- [ ] CLI with options
|
- CLI with options
|
||||||
- [ ] Server app
|
- Server app
|
||||||
- [ ] Git hosting providers
|
- Git hosting providers
|
||||||
|
|
||||||
## Version 0.1
|
## Version 0.1
|
||||||
|
|
||||||
- [ ] Setup a way to choose actions and predicates
|
- [x] Setup a way to choose actions and predicates
|
||||||
- [ ] Allow instantiation of actions, kraken template repo etc.
|
- [ ] Allow instantiation of actions, kraken template repo etc.
|
||||||
- [ ] Create pr for gitea provider
|
- [ ] Create pr for gitea provider
|
||||||
- [ ] Think about some sort of isolation
|
- [ ] Think about some sort of isolation
|
||||||
|
Loading…
Reference in New Issue
Block a user