Files
notifications-api/scripts/check_if_new_migration.py
Cliff Hill 1157f5639d black, isort, flake8
Signed-off-by: Cliff Hill <Clifford.hill@gsa.gov>
2023-12-08 21:43:52 -05:00

56 lines
1.8 KiB
Python

import os
import sys
from os.path import abspath, dirname
import requests
def get_latest_db_migration_to_apply():
project_dir = dirname(dirname(abspath(__file__))) # Get the main project directory
migrations_dir = "{}/migrations/versions/".format(project_dir)
migration_files = [
migration_file
for migration_file in os.listdir(migrations_dir)
if migration_file.endswith("py")
]
# sometimes there's a trailing underscore, if script was created with `flask db migrate --rev-id=...`
latest_file = (
sorted(migration_files, reverse=True)[0].replace("_.py", "").replace(".py", "")
)
return latest_file
def get_current_db_version():
api_status_url = "{}/_status".format(os.getenv("API_HOST_NAME"))
try:
response = requests.get(api_status_url)
response.raise_for_status()
current_db_version = response.json()["db_version"]
return current_db_version
except requests.exceptions.ConnectionError:
print(f"Could not make web request to {api_status_url}", file=sys.stderr)
return ""
except (
Exception
): # we expect these to be either either a http status code error, or a json decoding error
print(
f'Could not read status endpoint!\n\ncode {response.status_code}\nresponse "{response.text}"',
file=sys.stderr,
)
# if we can't make a request to the API, the API is probably down. By returning a blank string (which won't
# match the filename of the latest migration), we force the migration to run, as the code change to fix the api
# might involve a migration file.
return ""
def run():
if get_current_db_version() == get_latest_db_migration_to_apply():
print("no")
else:
print("yes")
if __name__ == "__main__":
run()