summaryrefslogtreecommitdiffstats
path: root/models/migrations
diff options
context:
space:
mode:
Diffstat (limited to 'models/migrations')
-rw-r--r--models/migrations/v156.go19
1 files changed, 12 insertions, 7 deletions
diff --git a/models/migrations/v156.go b/models/migrations/v156.go
index d1770b6101..af37e67d82 100644
--- a/models/migrations/v156.go
+++ b/models/migrations/v156.go
@@ -55,6 +55,7 @@ func fixPublisherIDforTagReleases(x *xorm.Engine) error {
var (
repo *Repository
gitRepo *git.Repository
+ user *User
)
defer func() {
if gitRepo != nil {
@@ -69,7 +70,7 @@ func fixPublisherIDforTagReleases(x *xorm.Engine) error {
}
if err := sess.Limit(batchSize, start).
- Where("publisher_id = 0").
+ Where("publisher_id = 0 OR publisher_id is null").
Asc("repo_id", "id").Where("is_tag=?", true).
Find(&releases); err != nil {
return err
@@ -117,17 +118,21 @@ func fixPublisherIDforTagReleases(x *xorm.Engine) error {
return fmt.Errorf("GetTagCommit: %v", err)
}
- u := new(User)
- exists, err := sess.Where("email=?", commit.Author.Email).Get(u)
- if err != nil {
- return err
+ if user == nil || !strings.EqualFold(user.Email, commit.Author.Email) {
+ user = new(User)
+ _, err = sess.Where("email=?", commit.Author.Email).Get(user)
+ if err != nil {
+ return err
+ }
+
+ user.Email = commit.Author.Email
}
- if !exists {
+ if user.ID <= 0 {
continue
}
- release.PublisherID = u.ID
+ release.PublisherID = user.ID
if _, err := sess.ID(release.ID).Cols("publisher_id").Update(release); err != nil {
return err
}