2021-03-18 14:06:40 +08:00
// Copyright 2021 The Gitea Authors. All rights reserved.
2022-11-28 02:20:29 +08:00
// SPDX-License-Identifier: MIT
2021-03-18 14:06:40 +08:00
2022-11-02 16:54:36 +08:00
package v1_14 //nolint
2021-03-18 14:06:40 +08:00
import (
"fmt"
"regexp"
"code.gitea.io/gitea/modules/log"
"code.gitea.io/gitea/modules/setting"
2021-11-17 20:34:35 +08:00
2021-03-18 14:06:40 +08:00
"xorm.io/xorm"
)
2022-11-02 16:54:36 +08:00
func FixPostgresIDSequences ( x * xorm . Engine ) error {
2023-03-07 18:51:06 +08:00
if ! setting . Database . Type . IsPostgreSQL ( ) {
2021-03-18 14:06:40 +08:00
return nil
}
sess := x . NewSession ( )
defer sess . Close ( )
if err := sess . Begin ( ) ; err != nil {
return err
}
var sequences [ ] string
schema := sess . Engine ( ) . Dialect ( ) . URI ( ) . Schema
sess . Engine ( ) . SetSchema ( "" )
if err := sess . Table ( "information_schema.sequences" ) . Cols ( "sequence_name" ) . Where ( "sequence_name LIKE 'tmp_recreate__%_id_seq%' AND sequence_catalog = ?" , setting . Database . Name ) . Find ( & sequences ) ; err != nil {
log . Error ( "Unable to find sequences: %v" , err )
return err
}
sess . Engine ( ) . SetSchema ( schema )
sequenceRegexp := regexp . MustCompile ( ` tmp_recreate__(\w+)_id_seq.* ` )
for _ , sequence := range sequences {
tableName := sequenceRegexp . FindStringSubmatch ( sequence ) [ 1 ]
newSequenceName := tableName + "_id_seq"
if _ , err := sess . Exec ( fmt . Sprintf ( "ALTER SEQUENCE `%s` RENAME TO `%s`" , sequence , newSequenceName ) ) ; err != nil {
log . Error ( "Unable to rename %s to %s. Error: %v" , sequence , newSequenceName , err )
return err
}
if _ , err := sess . Exec ( fmt . Sprintf ( "SELECT setval('%s', COALESCE((SELECT MAX(id)+1 FROM `%s`), 1), false)" , newSequenceName , tableName ) ) ; err != nil {
log . Error ( "Unable to reset sequence %s for %s. Error: %v" , newSequenceName , tableName , err )
return err
}
}
return sess . Commit ( )
}