mirror of
https://github.com/avatao-content/baseimage-tutorial-framework
synced 2024-09-19 02:34:10 +00:00
76 lines
2.2 KiB
Python
76 lines
2.2 KiB
Python
# Copyright (C) 2018 Avatao.com Innovative Learning Kft.
|
||
# All Rights Reserved. See LICENSE file for details.
|
||
|
||
from os.path import isdir, exists
|
||
|
||
from tfw.components.directory_monitor import DirectoryMonitor
|
||
from tfw.event_handler_base import TriggerlessEventHandler
|
||
from tfw.config.logs import logging
|
||
|
||
LOG = logging.getLogger(__name__)
|
||
|
||
|
||
class DirectoryMonitoringEventHandler(TriggerlessEventHandler):
|
||
def __init__(self, key, directory):
|
||
super().__init__(key)
|
||
self._directory = directory
|
||
self._monitor = None
|
||
self.reload_monitor()
|
||
self.commands = {'pause': self.pause,
|
||
'resume': self.resume,
|
||
'ignore': self.ignore,
|
||
'selectdir': self.selectdir}
|
||
|
||
@property
|
||
def directory(self):
|
||
return self._directory
|
||
|
||
@directory.setter
|
||
def directory(self, directory):
|
||
if not exists(directory) or not isdir(directory):
|
||
raise EnvironmentError('No such directory!')
|
||
self._directory = directory
|
||
|
||
@property
|
||
def monitor(self):
|
||
return self._monitor
|
||
|
||
def reload_monitor(self):
|
||
if self._monitor:
|
||
try:
|
||
self._monitor.stop()
|
||
except KeyError:
|
||
logging.debug('Working directory was removed – ignoring...')
|
||
self._monitor = DirectoryMonitor(self._directory)
|
||
self._monitor.watch() # This runs on a separate thread
|
||
|
||
def handle_event(self, key, message):
|
||
try:
|
||
message['data'] = self.commands[message['data']['command']](message['data'])
|
||
return message
|
||
except KeyError:
|
||
LOG.error('IGNORING MESSAGE: Invalid message received: %s', message)
|
||
|
||
def pause(self, data):
|
||
self.monitor.pause()
|
||
return data
|
||
|
||
def resume(self, data):
|
||
self.monitor.resume()
|
||
return data
|
||
|
||
def ignore(self, data):
|
||
self.monitor.ignore += data['ignore']
|
||
return data
|
||
|
||
def selectdir(self, data):
|
||
try:
|
||
self.directory = data['directory']
|
||
self.reload_monitor()
|
||
return data
|
||
except EnvironmentError:
|
||
LOG.error('Failed to switch directory!')
|
||
|
||
def cleanup(self):
|
||
self.monitor.stop()
|