From d2b7958cc29117e04bf4270dab515cba4093d6e5 Mon Sep 17 00:00:00 2001 From: dgtlmoon Date: Wed, 8 Jun 2022 16:27:27 +0200 Subject: [PATCH] Misc improvements --- changedetectionio/__init__.py | 4 ++-- changedetectionio/store.py | 19 +++++++++++++++---- 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/changedetectionio/__init__.py b/changedetectionio/__init__.py index 45073440..c285f99a 100644 --- a/changedetectionio/__init__.py +++ b/changedetectionio/__init__.py @@ -467,8 +467,8 @@ def changedetection_app(config=None, datastore_o=None): except KeyError: flash('Watch not found', 'error') else: - flash("Cleared snapshot history for watch {}".format(uuid)) - #@todo gives 'Not enough saved change detection snapshots to produce a report.' after scrub.. interesting + flash("Scrubbed watch {}".format(uuid)) + return redirect(url_for('index')) @app.route("/scrub", methods=['GET', 'POST']) diff --git a/changedetectionio/store.py b/changedetectionio/store.py index 9befd47a..0d33337a 100644 --- a/changedetectionio/store.py +++ b/changedetectionio/store.py @@ -254,12 +254,23 @@ class ChangeDetectionStore: def scrub_watch(self, uuid): import pathlib - self.__data['watching'][uuid].update({'history': {}, 'last_checked': 0, 'last_changed': 0, 'previous_md5': False}) - self.needs_write_urgent = True - - for item in pathlib.Path(self.datastore_path).rglob(uuid+"/*.txt"): + self.__data['watching'][uuid].update( + {'last_checked': 0, + 'last_changed': 0, + 'last_viewed': 0, + 'previous_md5': False, + 'last_notification_error': False, + 'last_error': False}) + + # JSON Data, Screenshots, Textfiles (history index and snapshots), HTML in the future etc + for item in pathlib.Path(os.path.join(self.datastore_path, uuid)).rglob("*.*"): unlink(item) + # Force the attr to recalculate + bump = self.__data['watching'][uuid].history + + self.needs_write_urgent = True + def add_watch(self, url, tag="", extras=None, write_to_disk_now=True): if extras is None: