From 3f8dd9f8af7c64534c288ac482732c3dbde48f74 Mon Sep 17 00:00:00 2001 From: 6543 <6543@obermui.de> Date: Sat, 15 May 2021 18:05:28 +0200 Subject: [PATCH 1/2] GitHub: migrate draft releases too --- modules/migrations/gitea_uploader.go | 21 ++++++++++++--------- modules/migrations/github.go | 7 ++++++- 2 files changed, 18 insertions(+), 10 deletions(-) diff --git a/modules/migrations/gitea_uploader.go b/modules/migrations/gitea_uploader.go index 29118fd51b22f..8b865d7971522 100644 --- a/modules/migrations/gitea_uploader.go +++ b/modules/migrations/gitea_uploader.go @@ -250,14 +250,16 @@ func (g *GiteaLocalUploader) CreateReleases(releases ...*base.Release) error { rel.OriginalAuthorID = release.PublisherID } - // calc NumCommits - commit, err := g.gitRepo.GetCommit(rel.TagName) - if err != nil { - return fmt.Errorf("GetCommit: %v", err) - } - rel.NumCommits, err = commit.CommitsCount() - if err != nil { - return fmt.Errorf("CommitsCount: %v", err) + // calc NumCommits if no draft + if !release.Draft { + commit, err := g.gitRepo.GetCommit(rel.TagName) + if err != nil { + return fmt.Errorf("GetCommit: %v", err) + } + rel.NumCommits, err = commit.CommitsCount() + if err != nil { + return fmt.Errorf("CommitsCount: %v", err) + } } for _, asset := range release.Assets { @@ -270,9 +272,10 @@ func (g *GiteaLocalUploader) CreateReleases(releases ...*base.Release) error { } // download attachment - err = func() error { + err := func() error { // asset.DownloadURL maybe a local file var rc io.ReadCloser + var err error if asset.DownloadURL == nil { rc, err = asset.DownloadFunc() if err != nil { diff --git a/modules/migrations/github.go b/modules/migrations/github.go index 282e3b4786151..2c34a75ab0a7c 100644 --- a/modules/migrations/github.go +++ b/modules/migrations/github.go @@ -280,6 +280,11 @@ func (g *GithubDownloaderV3) convertGithubRelease(rel *github.RepositoryRelease) email = *rel.Author.Email } + var published time.Time + if rel.PublishedAt != nil { + published = rel.PublishedAt.Time + } + r := &base.Release{ TagName: *rel.TagName, TargetCommitish: *rel.TargetCommitish, @@ -291,7 +296,7 @@ func (g *GithubDownloaderV3) convertGithubRelease(rel *github.RepositoryRelease) PublisherID: *rel.Author.ID, PublisherName: *rel.Author.Login, PublisherEmail: email, - Published: rel.PublishedAt.Time, + Published: published, } for _, asset := range rel.Assets { From 9d979e21e06d10ba33b7dc621a145c92d6a9747a Mon Sep 17 00:00:00 2001 From: 6543 <6543@obermui.de> Date: Sat, 15 May 2021 23:38:34 +0200 Subject: [PATCH 2/2] refactor --- modules/migrations/github.go | 47 ++++++++++++++---------------------- 1 file changed, 18 insertions(+), 29 deletions(-) diff --git a/modules/migrations/github.go b/modules/migrations/github.go index 2c34a75ab0a7c..8a3f5d34c78d0 100644 --- a/modules/migrations/github.go +++ b/modules/migrations/github.go @@ -264,39 +264,29 @@ func (g *GithubDownloaderV3) GetLabels() ([]*base.Label, error) { } func (g *GithubDownloaderV3) convertGithubRelease(rel *github.RepositoryRelease) *base.Release { - var ( - name string - desc string - ) + r := &base.Release{ + TagName: *rel.TagName, + TargetCommitish: *rel.TargetCommitish, + Draft: *rel.Draft, + Prerelease: *rel.Prerelease, + Created: rel.CreatedAt.Time, + PublisherID: *rel.Author.ID, + PublisherName: *rel.Author.Login, + } + if rel.Body != nil { - desc = *rel.Body + r.Body = *rel.Body } if rel.Name != nil { - name = *rel.Name + r.Name = *rel.Name } - var email string if rel.Author.Email != nil { - email = *rel.Author.Email + r.PublisherEmail = *rel.Author.Email } - var published time.Time if rel.PublishedAt != nil { - published = rel.PublishedAt.Time - } - - r := &base.Release{ - TagName: *rel.TagName, - TargetCommitish: *rel.TargetCommitish, - Name: name, - Body: desc, - Draft: *rel.Draft, - Prerelease: *rel.Prerelease, - Created: rel.CreatedAt.Time, - PublisherID: *rel.Author.ID, - PublisherName: *rel.Author.Login, - PublisherEmail: email, - Published: published, + r.Published = rel.PublishedAt.Time } for _, asset := range rel.Assets { @@ -311,18 +301,17 @@ func (g *GithubDownloaderV3) convertGithubRelease(rel *github.RepositoryRelease) Updated: asset.UpdatedAt.Time, DownloadFunc: func() (io.ReadCloser, error) { g.sleep() - asset, redir, err := g.client.Repositories.DownloadReleaseAsset(g.ctx, g.repoOwner, g.repoName, assetID, nil) + asset, redirectURL, err := g.client.Repositories.DownloadReleaseAsset(g.ctx, g.repoOwner, g.repoName, assetID, nil) if err != nil { return nil, err } - err = g.RefreshRate() - if err != nil { + if err := g.RefreshRate(); err != nil { log.Error("g.client.RateLimits: %s", err) } if asset == nil { - if redir != "" { + if redirectURL != "" { g.sleep() - req, err := http.NewRequestWithContext(g.ctx, "GET", redir, nil) + req, err := http.NewRequestWithContext(g.ctx, "GET", redirectURL, nil) if err != nil { return nil, err }