From 4fef9db82947baadeb9017295eae1826356fd04c Mon Sep 17 00:00:00 2001 From: Ben Hearsum Date: Thu, 12 Oct 2023 16:46:59 -0400 Subject: [PATCH] Add support for cleaning up data from releases_json/release_assets --- scripts/manage-db.py | 36 ++++++++++++++++++++++++++---------- 1 file changed, 26 insertions(+), 10 deletions(-) diff --git a/scripts/manage-db.py b/scripts/manage-db.py index 246385458..4306c6c60 100755 --- a/scripts/manage-db.py +++ b/scripts/manage-db.py @@ -19,21 +19,21 @@ sys.path.append(path.join(path.dirname(__file__), path.join("..", "vendor", "lib", "python"))) +RELEASES_CLEANUP_CONDITION = """ +LEFT JOIN rules rules_mapping ON (name=rules_mapping.mapping) +WHERE name LIKE '%%nightly%%' +AND name NOT LIKE '%%latest' +AND rules_mapping.mapping IS NULL +AND (STR_TO_DATE(RIGHT(name, 14), "%%Y%%m%%d%%H%%i%%S") < NOW() - INTERVAL {nightly_age} DAY); +""" + + def cleanup_releases(trans, nightly_age, dryrun=True): # This and the subsequent queries use "%%%%%" because we end up going # through two levels of Python string formatting. The first is here, # and the second happens at a low level of SQLAlchemy when the transaction # is being executed. - query = ( - """ -LEFT JOIN rules rules_mapping ON (name=rules_mapping.mapping) -WHERE name LIKE '%%%%nightly%%%%' -AND name NOT LIKE '%%%%latest' -AND rules_mapping.mapping IS NULL -AND (STR_TO_DATE(RIGHT(name, 14), "%%%%Y%%%%m%%%%d%%%%H%%%%i%%%%S") < NOW() - INTERVAL %s DAY); -""" - % nightly_age - ) + query = RELEASES_CLEANUP_CONDITION.format(nightly_age=nightly_age) if dryrun: todelete = trans.execute("SELECT name FROM releases" + query).fetchall() print("Releases rows to be deleted:") @@ -45,6 +45,20 @@ def cleanup_releases(trans, nightly_age, dryrun=True): trans.execute("DELETE releases FROM releases" + query) +def cleanup_releases_json(trans, nightly_age, dryrun=True): + query = RELEASES_CLEANUP_CONDITION.format(nightly_age=nightly_age) + if dryrun: + todelete = trans.execute("SELECT name FROM releases_json" + query).fetchall() + print("Releases JSON rows to be deleted:") + if todelete: + print("\n".join(itertools.chain(*todelete))) + else: + print(" - None") + else: + trans.execute("DELETE releases_json FROM releases_json" + query) + trans.execute("DELETE release_assets FROM release_assets" + query) + + def chunk_list(list_object, n): """ Yield successive n-sized chunks from list_object. @@ -203,5 +217,7 @@ def _strip_multiple_spaces(string): with db.begin() as trans: if action == "cleanup": cleanup_releases(trans, nightly_age, dryrun=False) + cleanup_releases_json(trans, nightly_age, dryrun=False) else: cleanup_releases(trans, nightly_age, dryrun=True) + cleanup_releases_json(trans, nightly_age, dryrun=True)