2022-02-16 13:03:38 +00:00
|
|
|
"""Migrations module.
|
|
|
|
Migrations module is introduced in v1.1.1 and provides one-shot
|
|
|
|
migrations which cannot be performed from the NixOS configuration file changes.
|
|
|
|
These migrations are checked and ran before every start of the API.
|
|
|
|
|
|
|
|
You can disable certain migrations if needed by creating an array
|
|
|
|
at api.skippedMigrations in userdata.json and populating it
|
|
|
|
with IDs of the migrations to skip.
|
|
|
|
Adding DISABLE_ALL to that array disables the migrations module entirely.
|
|
|
|
"""
|
2024-01-09 18:58:09 +00:00
|
|
|
|
|
|
|
from selfprivacy_api.utils import ReadUserData, UserDataFiles
|
|
|
|
from selfprivacy_api.migrations.write_token_to_redis import WriteTokenToRedis
|
2024-02-12 15:17:18 +00:00
|
|
|
from selfprivacy_api.migrations.check_for_system_rebuild_jobs import (
|
|
|
|
CheckForSystemRebuildJobs,
|
|
|
|
)
|
2024-07-23 16:05:27 +00:00
|
|
|
from selfprivacy_api.migrations.add_prometheus import AddPrometheus
|
2022-01-11 05:36:11 +00:00
|
|
|
|
2022-07-30 14:48:33 +00:00
|
|
|
migrations = [
|
2024-01-09 18:58:09 +00:00
|
|
|
WriteTokenToRedis(),
|
2024-02-12 15:17:18 +00:00
|
|
|
CheckForSystemRebuildJobs(),
|
2024-07-18 16:40:18 +00:00
|
|
|
AddPrometheus(),
|
2022-07-30 14:48:33 +00:00
|
|
|
]
|
2022-01-11 05:41:25 +00:00
|
|
|
|
2022-01-11 05:36:11 +00:00
|
|
|
|
|
|
|
def run_migrations():
|
|
|
|
"""
|
|
|
|
Go over all migrations. If they are not skipped in userdata file, run them
|
|
|
|
if the migration needed.
|
|
|
|
"""
|
2024-01-09 18:58:09 +00:00
|
|
|
with ReadUserData(UserDataFiles.SECRETS) as data:
|
2022-01-11 05:36:11 +00:00
|
|
|
if "api" not in data:
|
|
|
|
skipped_migrations = []
|
|
|
|
elif "skippedMigrations" not in data["api"]:
|
|
|
|
skipped_migrations = []
|
|
|
|
else:
|
|
|
|
skipped_migrations = data["api"].get("skippedMigrations", [])
|
|
|
|
|
2022-01-11 05:57:14 +00:00
|
|
|
if "DISABLE_ALL" in skipped_migrations:
|
|
|
|
return
|
|
|
|
|
2022-01-11 05:36:11 +00:00
|
|
|
for migration in migrations:
|
|
|
|
if migration.get_migration_name() not in skipped_migrations:
|
2022-01-11 05:54:57 +00:00
|
|
|
try:
|
|
|
|
if migration.is_migration_needed():
|
2022-01-11 05:52:15 +00:00
|
|
|
migration.migrate()
|
2022-02-16 13:03:38 +00:00
|
|
|
except Exception as err:
|
2022-01-11 05:54:57 +00:00
|
|
|
print(f"Error while migrating {migration.get_migration_name()}")
|
2022-02-16 13:03:38 +00:00
|
|
|
print(err)
|
2022-01-11 05:54:57 +00:00
|
|
|
print("Skipping this migration")
|