mirror of
https://github.com/go-gitea/gitea
synced 2024-11-18 07:52:03 +01:00
ebac051e72
* v38 migration used an outdated version of RepoUnit model (#2602) * change repoUnit model in migration * fix v16 migration repo_unit table * fix lint error * move type definition inside function Signed-off-by: David Schneiderbauer <dschneiderbauer@gmail.com> * fix lint error Signed-off-by: David Schneiderbauer <dschneiderbauer@gmail.com> * Fix time tracking migration * Refactor code * Fix migration from Gogs * v38 migration used an outdated version of RepoUnit model (#2602) * change repoUnit model in migration * fix v16 migration repo_unit table * fix lint error * move type definition inside function Signed-off-by: David Schneiderbauer <dschneiderbauer@gmail.com> * fix lint error Signed-off-by: David Schneiderbauer <dschneiderbauer@gmail.com> * Fix time tracking migration * Refactor code * Fix migration from Gogs * add error check Signed-off-by: David Schneiderbauer <dschneiderbauer@gmail.com> * Additiomal fixes for migrations * Fix timetracking migration * Add back nil check
70 lines
2 KiB
Go
70 lines
2 KiB
Go
// Copyright 2017 The Gitea Authors. All rights reserved.
|
|
// Use of this source code is governed by a MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package migrations
|
|
|
|
import (
|
|
"time"
|
|
|
|
"code.gitea.io/gitea/models"
|
|
|
|
"github.com/go-xorm/core"
|
|
"github.com/go-xorm/xorm"
|
|
)
|
|
|
|
func removeCommitsUnitType(x *xorm.Engine) (err error) {
|
|
// RepoUnit describes all units of a repository
|
|
type RepoUnit struct {
|
|
ID int64
|
|
RepoID int64 `xorm:"INDEX(s)"`
|
|
Type int `xorm:"INDEX(s)"`
|
|
Index int
|
|
Config core.Conversion `xorm:"TEXT"`
|
|
CreatedUnix int64 `xorm:"INDEX CREATED"`
|
|
Created time.Time `xorm:"-"`
|
|
}
|
|
|
|
// Update team unit types
|
|
const batchSize = 100
|
|
for start := 0; ; start += batchSize {
|
|
teams := make([]*models.Team, 0, batchSize)
|
|
if err := x.Limit(batchSize, start).Find(&teams); err != nil {
|
|
return err
|
|
}
|
|
if len(teams) == 0 {
|
|
break
|
|
}
|
|
for _, team := range teams {
|
|
ut := make([]models.UnitType, 0, len(team.UnitTypes))
|
|
for _, u := range team.UnitTypes {
|
|
if u < V16UnitTypeCommits {
|
|
ut = append(ut, u)
|
|
} else if u > V16UnitTypeSettings {
|
|
ut = append(ut, u-2)
|
|
} else if u > V16UnitTypeCommits && u != V16UnitTypeSettings {
|
|
ut = append(ut, u-1)
|
|
}
|
|
}
|
|
team.UnitTypes = ut
|
|
if _, err := x.ID(team.ID).Cols("unit_types").Update(team); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
|
|
// Delete commits and settings unit types
|
|
if _, err = x.In("`type`", []models.UnitType{V16UnitTypeCommits, V16UnitTypeSettings}).Delete(new(RepoUnit)); err != nil {
|
|
return err
|
|
}
|
|
// Fix renumber unit types that where in enumeration after settings unit type
|
|
if _, err = x.Where("`type` > ?", V16UnitTypeSettings).Decr("type").Decr("index").Update(new(RepoUnit)); err != nil {
|
|
return err
|
|
}
|
|
// Fix renumber unit types that where in enumeration after commits unit type
|
|
if _, err = x.Where("`type` > ?", V16UnitTypeCommits).Decr("type").Decr("index").Update(new(RepoUnit)); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|