forgejo/models/migrations
forgejo-backport-action 400bd08cfe [v10.0/forgejo] fix: discard v25 secrets migrations errors instead of failing (#7255)
**Backport:** https://codeberg.org/forgejo/forgejo/pulls/7251

Failing the migration when a corrupted record is found is problematic because there is no transaction and the database may need to be restored from a backup to attempt the migration again, after deleting the corrupted records.

Each documented case of failed migration was resolved by removing the corrupted records. There is no instance of a failed migration that was caused by non corrupted record.

In the unlikely event of a false negative where a two_factor record is discarded although it is in use, the only consequence is that the user will have to enroll again. Detailed logs are displayed so the Forgejo admin can file a bug report if that happens.

Refs: https://codeberg.org/forgejo/forgejo/issues/6637

<!--start release-notes-assistant-->

## Release notes
<!--URL:https://codeberg.org/forgejo/forgejo-->
- Bug fixes
  - [PR](https://codeberg.org/forgejo/forgejo/pulls/7251): <!--number 7251 --><!--line 0 --><!--description V2hlbiBtaWdyYXRpbmcgZnJvbSBhIEZvcmdlam8gdmVyc2lvbiBsb3dlciB0aGFuIHYxMCwgdGhlIFRPVFAgc2VjcmV0cyBmb3VuZCB0byBiZSBjb3JydXB0ZWQgYXJlIG5vdyB0cmFuc3BhcmVudGx5IHJlbW92ZWQgZnJvbSB0aGUgZGF0YWJhc2UgaW5zdGVhZCBvZiBmYWlsaW5nIHRoZSBtaWdyYXRpb24uIFRPVFAgaXMgbm8gbG9uZ2VyIHJlcXVpcmVkIHRvIGxvZ2luIHdpdGggdGhlIGFzc29jaWF0ZWQgdXNlcnMuIFRoZXkgc2hvdWxkIGJlIGluZm9ybWVkIGJlY2F1c2UgdGhleSB3aWxsIG5lZWQgdG8gdmlzaXQgdGhlaXIgc2VjdXJpdHkgc2V0dGluZ3MgYW5kIGNvbmZpZ3VyZSBUT1RQIGFnYWluLiBObyBvdGhlciBhY3Rpb24gaXMgcmVxdWlyZWQu-->When migrating from a Forgejo version lower than v10, the TOTP secrets found to be corrupted are now transparently removed from the database instead of failing the migration. TOTP is no longer required to login with the associated users. They should be informed because they will need to visit their security settings and configure TOTP again. No other action is required.<!--description-->
<!--end release-notes-assistant-->

Co-authored-by: Earl Warren <contact@earl-warren.org>
Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/7255
Reviewed-by: Gusted <gusted@noreply.codeberg.org>
Reviewed-by: Earl Warren <earl-warren@noreply.codeberg.org>
Co-authored-by: forgejo-backport-action <forgejo-backport-action@noreply.codeberg.org>
Co-committed-by: forgejo-backport-action <forgejo-backport-action@noreply.codeberg.org>
2025-03-17 17:55:32 +00:00
..
base [CHORE] Move test related function to own package 2024-07-14 17:00:49 +02:00
fixtures [v10.0/forgejo] fix: discard v25 secrets migrations errors instead of failing (#7255) 2025-03-17 17:55:32 +00:00
test Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_6 Enable more revive linter rules (#30608) 2024-04-28 15:39:00 +02:00
v1_7 Rename Sync2 -> Sync (#26479) 2023-08-13 21:17:21 +02:00
v1_8 [CHORE] Remove Microsoft SQL Server Support 2024-04-05 23:37:36 +02:00
v1_9 Enable more revive linter rules (#30608) 2024-04-28 15:39:00 +02:00
v1_10 Rename Sync2 -> Sync (#26479) 2023-08-13 21:17:21 +02:00
v1_11 Enable more revive linter rules (#30608) 2024-04-28 15:39:00 +02:00
v1_12 [CHORE] Remove Microsoft SQL Server Support 2024-04-05 23:37:36 +02:00
v1_13 [CHORE] Remove Microsoft SQL Server Support 2024-04-05 23:37:36 +02:00
v1_14 Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_15 Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_16 Fix linting issues 2024-08-18 16:25:13 +02:00
v1_17 Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_18 Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_19 Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_20 Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_21 Upgrade xorm to v1.3.9 and improve some migrations Sync (#29899) 2024-07-22 15:44:13 +02:00
v1_22 Add testifylint to lint checks (#4535) 2024-07-30 19:41:10 +00:00
v1_23 [v10.0/forgejo] fix: reduce noise for the v303 migration (#6594) 2025-01-17 08:15:16 +00:00
migrations.go fix: keying SQLite migration 2024-12-24 10:05:59 +01:00
migrations_test.go [PORT] Refactor the DB migration system slightly (gitea#32344) 2024-11-03 17:00:48 +01:00