2018-04-03 12:49:14 +00:00
|
|
|
# Copyright (C) 2018 Avatao.com Innovative Learning Kft.
|
|
|
|
# All Rights Reserved. See LICENSE file for details.
|
|
|
|
|
2018-03-20 13:29:14 +00:00
|
|
|
from os.path import isdir, exists
|
|
|
|
|
2018-04-18 16:47:51 +00:00
|
|
|
from tfw import EventHandlerBase
|
2018-03-20 13:29:14 +00:00
|
|
|
from tfw.config.logs import logging
|
2018-04-14 20:57:37 +00:00
|
|
|
from tfw.mixins import MonitorManagerMixin
|
2018-04-06 13:21:45 +00:00
|
|
|
from .directory_monitor import DirectoryMonitor
|
2018-03-25 14:06:59 +00:00
|
|
|
|
|
|
|
LOG = logging.getLogger(__name__)
|
2018-03-20 13:29:14 +00:00
|
|
|
|
|
|
|
|
2018-04-18 16:47:51 +00:00
|
|
|
class DirectoryMonitoringEventHandler(EventHandlerBase, MonitorManagerMixin):
|
2018-03-20 13:29:14 +00:00
|
|
|
def __init__(self, key, directory):
|
|
|
|
super().__init__(key)
|
|
|
|
self._directory = directory
|
2018-06-18 13:13:39 +00:00
|
|
|
MonitorManagerMixin.__init__(
|
|
|
|
self,
|
|
|
|
DirectoryMonitor,
|
|
|
|
key,
|
|
|
|
self._directory
|
|
|
|
)
|
2018-04-14 20:57:37 +00:00
|
|
|
|
2018-06-04 20:16:44 +00:00
|
|
|
self.commands = {
|
|
|
|
'pause': self.pause,
|
|
|
|
'resume': self.resume,
|
|
|
|
'ignore': self.ignore,
|
|
|
|
'selectdir': self.selectdir
|
|
|
|
}
|
2018-03-20 13:29:14 +00:00
|
|
|
|
|
|
|
@property
|
|
|
|
def directory(self):
|
|
|
|
return self._directory
|
|
|
|
|
|
|
|
@directory.setter
|
|
|
|
def directory(self, directory):
|
2018-03-30 15:50:20 +00:00
|
|
|
if not exists(directory) or not isdir(directory):
|
|
|
|
raise EnvironmentError('No such directory!')
|
2018-03-20 13:29:14 +00:00
|
|
|
self._directory = directory
|
|
|
|
|
2018-04-13 18:45:34 +00:00
|
|
|
def handle_event(self, message):
|
2018-03-20 13:29:14 +00:00
|
|
|
try:
|
|
|
|
message['data'] = self.commands[message['data']['command']](message['data'])
|
|
|
|
return message
|
|
|
|
except KeyError:
|
2018-03-25 14:25:01 +00:00
|
|
|
LOG.error('IGNORING MESSAGE: Invalid message received: %s', message)
|
2018-03-20 13:29:14 +00:00
|
|
|
|
|
|
|
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:
|
2018-03-25 14:06:59 +00:00
|
|
|
LOG.error('Failed to switch directory!')
|
2018-03-20 13:29:14 +00:00
|
|
|
|
|
|
|
def cleanup(self):
|
|
|
|
self.monitor.stop()
|