-class DirTrigger:
- def __init__(self, dir_path):
- pass
+import logging
+import threading
+import time
+from watchdog.events import DirDeletedEvent, FileDeletedEvent, FileSystemEventHandler
+from watchdog.observers import Observer
+
+class DirTrigger(FileSystemEventHandler):
+
+ def __init__(self, dir_path, cool_time, max_time):
+ self._got_event = False
+ self._last_event_time = 0.0
+ self._last_reset_time = 0.0
+ self._cool_time = cool_time
+ self._max_time = max_time
+ self._lock = threading.Lock()
+ self._observer = Observer()
+ self._observer.schedule(self, path=dir_path, recursive=True)
+
+ def start(self):
+ try:
+ self._observer.start()
+ except Exception as e:
+ logging.warning("Error starting file observer for %s: %s", dir_path, str(e))
+
+ def stop(self):
+ self._observer.stop()
def is_triggering(self):
- return False
+ self._lock.acquire()
+ try:
+ now = time.time()
+ return ( self._got_event and
+ (now - self._last_event_time > self._cool_time) ) or \
+ now - self._last_reset_time > self._max_time
+ finally:
+ self._lock.release()
+
+ def reset(self):
+ self._lock.acquire()
+ try:
+ self._got_event = False
+ self._last_reset_time = time.time()
+ finally:
+ self._lock.release()
+
+ def on_any_event(self, event):
+ if event.event_type == FileDeletedEvent or event.event_type == DirDeletedEvent:
+ return
+
+ self._lock.acquire()
+ try:
+ self._got_event = True
+ self._last_event_time = time.time()
+ finally:
+ self._lock.release()