mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-05 10:20:36 +02:00
7cf4f2eb89
Requirements: MySQL/MariaDB need to be configured with this settings: innodb_file_format = Barracuda innodb_file_per_table = On innodb_large_prefix = On to support key prefix length up to 3042 bytes. MySQL/MariaDB DSN will need this parameter: parseTime=true as per [1] The migration system itself mostly inspired by Rails (ActiveRecord), but it still rough at the edges. Could use some inputs. Next Todo: more testing! [1] https://github.com/go-sql-driver/mysql#parsetime
84 lines
2.0 KiB
Go
84 lines
2.0 KiB
Go
package migrate
|
|
|
|
type rev2nd struct{}
|
|
|
|
var SetupIndices = &rev2nd{}
|
|
|
|
func (r *rev2nd) Revision() int64 {
|
|
return 2
|
|
}
|
|
|
|
func (r *rev2nd) Up(mg *MigrationDriver) error {
|
|
if _, err := mg.AddIndex("members", []string{"team_id", "user_id"}, "unique"); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("members", []string{"team_id"}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("members", []string{"user_id"}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("commits", []string{"repo_id", "hash", "branch"}, "unique"); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("commits", []string{"repo_id"}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("commits", []string{"repo_id", "branch"}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("repos", []string{"team_id"}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("repos", []string{"user_id"}); err != nil {
|
|
return err
|
|
}
|
|
|
|
if _, err := mg.AddIndex("builds", []string{"commit_id"}); err != nil {
|
|
return err
|
|
}
|
|
|
|
_, err := mg.AddIndex("builds", []string{"commit_id", "slug"})
|
|
|
|
return err
|
|
}
|
|
|
|
func (r *rev2nd) Down(mg *MigrationDriver) error {
|
|
if _, err := mg.DropIndex("builds", []string{"commit_id", "slug"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("builds", []string{"commit_id"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("repos", []string{"user_id"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("repos", []string{"team_id"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("commits", []string{"repo_id", "branch"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("commits", []string{"repo_id"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("commits", []string{"repo_id", "hash", "branch"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("members", []string{"user_id"}); err != nil {
|
|
return err
|
|
}
|
|
if _, err := mg.DropIndex("members", []string{"team_id"}); err != nil {
|
|
return err
|
|
}
|
|
_, err := mg.DropIndex("members", []string{"team_id", "user_id"})
|
|
return err
|
|
}
|