Skip to content

Commit

Permalink
[Backport] Prohibit automatic downgrades (#13108) (#13111)
Browse files Browse the repository at this point in the history
* Prohibit automatic downgrades

* do not only log, print to stderr too

* Update models/migrations/migrations.go

* Update models/migrations/migrations.go

Co-authored-by: Cirno the Strongest <[email protected]>

* a nit

Co-authored-by: zeripath <[email protected]>
Co-authored-by: Cirno the Strongest <[email protected]>
  • Loading branch information
3 people authored Oct 12, 2020
1 parent f9942ad commit e0ae0b3
Showing 1 changed file with 9 additions and 4 deletions.
13 changes: 9 additions & 4 deletions models/migrations/migrations.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ package migrations

import (
"fmt"
"os"
"regexp"
"strings"

Expand Down Expand Up @@ -290,12 +291,16 @@ Please try upgrading to a lower version first (suggested v1.6.4), then upgrade t
return nil
}

// Downgrading Gitea's database version not supported
if int(v-minDBVersion) > len(migrations) {
// User downgraded Gitea.
currentVersion.Version = int64(len(migrations) + minDBVersion)
_, err = x.ID(1).Update(currentVersion)
return err
msg := fmt.Sprintf("Downgrading database version from '%d' to '%d' is not supported and may result in loss of data integrity.\nIf you really know what you're doing, execute `UPDATE version SET version=%d WHERE id=1;`\n",
v, minDBVersion+len(migrations), minDBVersion+len(migrations))
fmt.Fprint(os.Stderr, msg)
log.Fatal(msg)
return nil
}

// Migrate
for i, m := range migrations[v-minDBVersion:] {
log.Info("Migration[%d]: %s", v+int64(i), m.Description())
if err = m.Migrate(x); err != nil {
Expand Down

0 comments on commit e0ae0b3

Please sign in to comment.