From 26c9a6e0fc0bf0eff6d2200b38fcdc057836bcbc Mon Sep 17 00:00:00 2001 From: Leigh Morresi <275001+dgtlmoon@users.noreply.github.com> Date: Tue, 2 Feb 2021 17:11:06 +0100 Subject: [PATCH] Easily download a full backup --- backend/backend.py | 30 ++++++++++++++++++++++++++++++ backend/templates/base.html | 3 +++ 2 files changed, 33 insertions(+) diff --git a/backend/backend.py b/backend/backend.py index 5b27e14b..4a1873fc 100644 --- a/backend/backend.py +++ b/backend/backend.py @@ -255,6 +255,36 @@ def favicon(): return send_from_directory("/app/static/images", filename="favicon.ico") +# We're good but backups are even better! +@app.route("/backup", methods=['GET']) +def get_backup(): + import zipfile + from pathlib import Path + import zlib + + # create a ZipFile object + backupname = "changedetection-backup-{}.zip".format(int(time.time())) + + # We only care about UUIDS from the current index file + uuids = list(datastore.data['watching'].keys()) + + with zipfile.ZipFile(os.path.join("/datastore", backupname), 'w', compression=zipfile.ZIP_DEFLATED, + compresslevel=6) as zipObj: + # Add the index + zipObj.write(os.path.join("/datastore", "url-watches.json")) + # Add any snapshot data we find + for txt_file_path in Path('/datastore').rglob('*.txt'): + parent_p = txt_file_path.parent + if parent_p.name in uuids: + zipObj.write(txt_file_path) + + return send_file(os.path.join("/datastore", backupname), + as_attachment=True, + mimetype="application/zip", + attachment_filename=backupname) + + + # A few self sanity checks, mostly for developer/bug check @app.route("/self-check", methods=['GET']) def selfcheck(): diff --git a/backend/templates/base.html b/backend/templates/base.html index d635e07f..5cf36056 100644 --- a/backend/templates/base.html +++ b/backend/templates/base.html @@ -24,6 +24,9 @@