Skip to content

Commit

Permalink
feat: handling of a yolo.json config (#446)
Browse files Browse the repository at this point in the history
* feat: add tree command (build, artifacts)

Signed-off-by: ismael FALL <[email protected]>

* fix(tree): review comments

Signed-off-by: ismael FALL <[email protected]>

* feat(yolo.json): add handling of a yolo.json file to override build's infos

Signed-off-by: ismael FALL <[email protected]>

* fix(yolo.json): apply review

Signed-off-by: ismael FALL <[email protected]>

* fix(yolo.json): lint

Signed-off-by: ismael FALL <[email protected]>

* fix(yolo.json): remove useless for loop

Signed-off-by: ismael FALL <[email protected]>

* fix: remove debug

Signed-off-by: ismael FALL <[email protected]>

* fix: codefactor

Signed-off-by: ismael FALL <[email protected]>

* fix: codefactor

Signed-off-by: ismael FALL <[email protected]>

* feat(yolo.json): preload both project and commit raw version

Signed-off-by: ismael FALL <[email protected]>

Signed-off-by: ismael FALL <[email protected]>
  • Loading branch information
Doozers authored Sep 8, 2022
1 parent 253ad21 commit 3b95aa5
Show file tree
Hide file tree
Showing 8 changed files with 1,067 additions and 315 deletions.
13 changes: 13 additions & 0 deletions api/yolopb.proto
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,13 @@ message BuildListFilters {
// DB Schemas
//

message MetadataOverride {
string branch = 11;
Commit has_commit = 102;
string has_commit_id = 103 [(gogoproto.customname) = "HasCommitID"];
string has_project_id = 105 [(gogoproto.customname) = "HasProjectID"];
}

message Build {
/// fields

Expand All @@ -141,6 +148,12 @@ message Build {

/// relationships

string raw_branch = 21;
Commit has_raw_commit = 22;
Project has_raw_project = 23;
string has_raw_commit_id = 24 [(gogoproto.customname) = "HasRawCommitID"];
string has_raw_project_id = 25 [(gogoproto.customname) = "HasRawProjectID"];

repeated Artifact has_artifacts = 101 [(gogoproto.moretags) = "gorm:\"foreignkey:HasBuildID\""];
Commit has_commit = 102;
string has_commit_id = 103 [(gogoproto.customname) = "HasCommitID"];
Expand Down
2 changes: 1 addition & 1 deletion go/cmd/yolo/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -212,7 +212,7 @@ func yolo(args []string) error {
gr.Add(func() error { return svc.PkgmanWorker(ctx, opts) }, func(_ error) { cancel() })
}
if githubToken != "" {
opts := yolosvc.GithubWorkerOpts{Logger: logger, MaxBuilds: maxBuilds, ClearCache: cc, Once: once, ReposFilter: githubRepos}
opts := yolosvc.GithubWorkerOpts{Logger: logger, MaxBuilds: maxBuilds, ClearCache: cc, Once: once, ReposFilter: githubRepos, Token: githubToken}
gr.Add(func() error { return svc.GitHubWorker(ctx, opts) }, func(_ error) { cancel() })
}

Expand Down
2 changes: 1 addition & 1 deletion go/gen.sum

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

14 changes: 14 additions & 0 deletions go/pkg/yolopb/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package yolopb
import (
"net/url"

"github.com/gogo/protobuf/proto"
"github.com/stretchr/signature"
)

Expand Down Expand Up @@ -39,3 +40,16 @@ func (a *Artifact) AddSignedURLs(key string) error {
}
return nil
}

func (b *Build) ApplyMetadataOverride(override *MetadataOverride) {
bytes, err := override.Marshal()
if err != nil {
return
}
o := &Build{}
err = proto.Unmarshal(bytes, o)
if err != nil {
return
}
proto.Merge(b, o)
}
1,222 changes: 927 additions & 295 deletions go/pkg/yolopb/yolopb.pb.go

Large diffs are not rendered by default.

5 changes: 4 additions & 1 deletion go/pkg/yolostore/store.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,9 @@ import (
"fmt"

"berty.tech/yolo/v2/go/pkg/yolopb"
"github.com/jinzhu/gorm"
"go.uber.org/zap"

"github.com/jinzhu/gorm"
)

type Store interface {
Expand Down Expand Up @@ -310,7 +311,9 @@ func (s *store) GetBuildList(bl GetBuildListOpts) ([]*yolopb.Build, error) {

query = query.
Preload("HasCommit").
Preload("HasRawCommit").
Preload("HasProject").
Preload("HasRawProject").
Preload("HasProject.HasOwner").
Preload("HasMergerequest").
Preload("HasMergerequest.HasProject").
Expand Down
113 changes: 96 additions & 17 deletions go/pkg/yolosvc/driver_github.go
Original file line number Diff line number Diff line change
@@ -1,15 +1,23 @@
package yolosvc

import (
"archive/zip"
"bytes"
"context"
"fmt"
"io"
"net/http"
"strings"
"time"

"github.com/gogo/protobuf/jsonpb"
//nolint:staticcheck

"berty.tech/yolo/v2/go/pkg/yolopb"
"go.uber.org/zap"

"github.com/google/go-github/v32/github"
"github.com/tevino/abool"
"go.uber.org/zap"
)

type GithubWorkerOpts struct {
Expand All @@ -19,6 +27,7 @@ type GithubWorkerOpts struct {
ClearCache *abool.AtomicBool
Once bool
ReposFilter string
Token string
}

type githubRepoConfig struct {
Expand All @@ -34,7 +43,7 @@ type githubWorker struct {
repoConfigs []githubRepoConfig
}

func (worker *githubWorker) ParseConfig() (bool, error) {
func (worker *githubWorker) parseConfig() (bool, error) {
if worker.opts.ReposFilter == "" {
return false, nil
}
Expand Down Expand Up @@ -66,7 +75,7 @@ func (svc *service) GitHubWorker(ctx context.Context, opts GithubWorkerOpts) err
logger: opts.Logger.Named("ghub"),
}

shouldRun, err := worker.ParseConfig()
shouldRun, err := worker.parseConfig()
if err != nil {
svc.logger.Error("invalid config", zap.Error(err))
return fmt.Errorf("%w", err)
Expand Down Expand Up @@ -187,6 +196,50 @@ func (worker *githubWorker) fetchBaseObjects(ctx context.Context) (*yolopb.Batch
return batch, nil
}

func getOverrideBuildpb(owner string, repo string, artifactID int64, token string) (*yolopb.MetadataOverride, error) {
override := &yolopb.MetadataOverride{}

// https://github.com/actions/upload-artifact#zipped-artifact-downloads
req, err := http.NewRequest("GET", fmt.Sprintf("https://api.github.com/repos/%s/%s/actions/artifacts/%d/zip", owner, repo, artifactID), nil)
if err != nil {
return nil, fmt.Errorf("fetch yolo.json: %w", err)
}

req.Header.Set("Accept", "application/vnd.github+json")
req.Header.Set("Authorization", fmt.Sprintf("Bearer %s", token))

res, err := http.DefaultClient.Do(req)
if err != nil {
return nil, fmt.Errorf("fetch yolo.json: %w", err)
}
defer res.Body.Close()

zipFile, err := io.ReadAll(res.Body)
if err != nil {
return nil, err
}

bytesReader := bytes.NewReader(zipFile)
zipReader, err := zip.NewReader(bytesReader, int64(len(zipFile)))
if err != nil {
return nil, err
}

file := zipReader.File[0]
if file != nil && file.Name == "yolo.json" {
unzippedFileBytes, err := readZipFile(file)
if err != nil {
return nil, fmt.Errorf("fetch yolo.json: %w", err)
}
err = jsonpb.Unmarshal(bytes.NewReader(unzippedFileBytes), override)
if err != nil {
return nil, fmt.Errorf("fetch yolo.json: %w", err)
}
return override, nil
}
return nil, fmt.Errorf("fetch yolo.json: missing yolo.json inside artifact")
}

func (worker *githubWorker) fetchRepoActivity(ctx context.Context, repo githubRepoConfig, iteration int, lastFinishedBuild time.Time) (*yolopb.Batch, error) {
batch := yolopb.NewBatch()

Expand Down Expand Up @@ -240,6 +293,7 @@ func (worker *githubWorker) fetchRepoActivity(ctx context.Context, repo githubRe
if err != nil {
return nil, err
}

worker.logger.Debug("github.Actions.ListRepositoryWorkflowRuns",
zap.Int("total", len(ret.WorkflowRuns)),
zap.Duration("duration", time.Since(before)),
Expand All @@ -249,6 +303,10 @@ func (worker *githubWorker) fetchRepoActivity(ctx context.Context, repo githubRe

// FIXME: parallelize?
for _, run := range ret.WorkflowRuns {
overridepb, err := worker.getOverridepb(ctx, repo, *run.ID)
if err != nil {
worker.svc.logger.Warn("parsing yolo.json", zap.Error(err))
}
// FIXME: compare updated_at before doing next calls
runs = append(runs, run)

Expand All @@ -268,9 +326,9 @@ func (worker *githubWorker) fetchRepoActivity(ctx context.Context, repo githubRe
if err != nil {
return nil, err
}
batch.Merge(worker.batchFromWorkflowRun(run, ret))
batch.Merge(worker.batchFromWorkflowRun(run, ret, overridepb))
} else {
batch.Merge(worker.batchFromWorkflowRun(run, nil))
batch.Merge(worker.batchFromWorkflowRun(run, nil, overridepb))
}
}
}
Expand Down Expand Up @@ -323,6 +381,21 @@ func (worker *githubWorker) fetchRepoActivity(ctx context.Context, repo githubRe
return batch, nil
}

func (worker *githubWorker) getOverridepb(ctx context.Context, repo githubRepoConfig, runID int64) (*yolopb.MetadataOverride, error) {
// check for yolo.json
opts := &github.ListOptions{}
retArti, _, err := worker.svc.ghc.Actions.ListWorkflowRunArtifacts(ctx, repo.owner, repo.repo, runID, opts)
if err != nil {
return nil, err
}
for _, arti := range retArti.Artifacts {
if arti.GetName() == "yolo.json" {
return getOverrideBuildpb(repo.owner, repo.repo, *arti.ID, worker.opts.Token)
}
}
return nil, nil
}

func (worker *githubWorker) batchFromWorkflowRunArtifact(run *github.WorkflowRun, artifact *github.Artifact) *yolopb.Batch {
batch := yolopb.NewBatch()

Expand All @@ -345,25 +418,31 @@ func (worker *githubWorker) batchFromWorkflowRunArtifact(run *github.WorkflowRun
return batch
}

func (worker *githubWorker) batchFromWorkflowRun(run *github.WorkflowRun, prs []*github.PullRequest) *yolopb.Batch {
func (worker *githubWorker) batchFromWorkflowRun(run *github.WorkflowRun, prs []*github.PullRequest, override *yolopb.MetadataOverride) *yolopb.Batch {
batch := yolopb.NewBatch()
createdAt := run.GetCreatedAt().Time
updatedAt := run.GetUpdatedAt().Time
commitURL := run.GetHeadRepository().GetHTMLURL() + "/commit/" + run.GetHeadSHA()

newBuild := yolopb.Build{
ID: run.GetHTMLURL(),
ShortID: fmt.Sprintf("%d", run.GetID()),
CreatedAt: &createdAt,
UpdatedAt: &updatedAt,
HasCommitID: run.GetHeadSHA(),
Branch: run.GetHeadBranch(),
Driver: yolopb.Driver_GitHub,
CommitURL: commitURL,
HasProjectID: run.GetRepository().GetHTMLURL(),
Message: run.GetHeadCommit().GetMessage(),
ID: run.GetHTMLURL(),
ShortID: fmt.Sprintf("%d", run.GetID()),
CreatedAt: &createdAt,
UpdatedAt: &updatedAt,
HasRawCommitID: run.GetHeadSHA(),
HasCommitID: run.GetHeadSHA(),
RawBranch: run.GetHeadBranch(),
Branch: run.GetHeadBranch(),
Driver: yolopb.Driver_GitHub,
CommitURL: commitURL,
HasRawProjectID: run.GetRepository().GetHTMLURL(),
HasProjectID: run.GetRepository().GetHTMLURL(),
Message: run.GetHeadCommit().GetMessage(),
}

if override != nil {
newBuild.ApplyMetadataOverride(override)
}

if run.GetConclusion() != "" {
newBuild.FinishedAt = &updatedAt // maybe we can have a more accurate date?
}
Expand Down
11 changes: 11 additions & 0 deletions go/pkg/yolosvc/util.go
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
package yolosvc

import (
"archive/zip"
"crypto/md5"
"encoding/hex"
"fmt"
"io"
"path/filepath"
"regexp"

Expand Down Expand Up @@ -67,3 +69,12 @@ func guessMissingBuildInfo(build *yolopb.Build) {
build.VCSTagURL = fmt.Sprintf("%s/tree/%s", build.HasProjectID, build.VCSTag)
}
}

func readZipFile(zf *zip.File) ([]byte, error) {
f, err := zf.Open()
if err != nil {
return nil, err
}
defer f.Close()
return io.ReadAll(f)
}

0 comments on commit 3b95aa5

Please sign in to comment.