mirror of
https://github.com/Pardus-LiderAhenk/ahenk
synced 2024-11-27 04:02:25 +03:00
107 lines
3.9 KiB
Python
107 lines
3.9 KiB
Python
|
#!/usr/bin/python3
|
||
|
# -*- coding: utf-8 -*-
|
||
|
# Author: İsmail BAŞARAN <ismail.basaran@tubitak.gov.tr> <basaran.ismaill@gmail.com>
|
||
|
|
||
|
from base.scheduler.custom.all_match import AllMatch
|
||
|
from base.scope import Scope
|
||
|
|
||
|
|
||
|
class ScheduleTaskJob(object):
|
||
|
def __init__(self, task):
|
||
|
scope = Scope.get_instance()
|
||
|
|
||
|
self.logger = scope.get_logger()
|
||
|
self.task_manager = scope.get_task_manager()
|
||
|
self.plugin_manager = scope.get_plugin_manager()
|
||
|
self.task = task
|
||
|
cron_sj = self.parse_cron_str(task.get_cron_str())
|
||
|
try:
|
||
|
if cron_sj:
|
||
|
self.mins = self.conv_to_set(cron_sj[0])
|
||
|
self.hours = self.conv_to_set(cron_sj[1])
|
||
|
self.days = self.conv_to_set(cron_sj[2])
|
||
|
self.months = self.conv_to_set(cron_sj[3])
|
||
|
self.dow = self.conv_to_set(cron_sj[4])
|
||
|
self.action = self.process_task
|
||
|
self.logger.debug('Instance created.')
|
||
|
except Exception as e:
|
||
|
self.logger.error(
|
||
|
'A problem occurred while creating instance of ScheduleTaskJob. Error Message : {0}'.format(
|
||
|
str(e)))
|
||
|
|
||
|
def process_task(self):
|
||
|
try:
|
||
|
self.logger.debug('Running scheduled task now...')
|
||
|
self.plugin_manager.process_task(self.task)
|
||
|
self.logger.debug('Scheduled Task was executed.')
|
||
|
# There is no any single shot task
|
||
|
# if self.is_single_shot():
|
||
|
# Scope.getInstance().get_scheduler().remove_job(self.task.get_id())
|
||
|
except Exception as e:
|
||
|
self.logger.error(
|
||
|
'A problem occurred while running scheduled task. Error Message: {0}'.format(str(e)))
|
||
|
|
||
|
def parse_cron_str(self, cron_str):
|
||
|
self.logger.debug('Parsing cron string...')
|
||
|
try:
|
||
|
cron_exp_arr = cron_str.split(" ")
|
||
|
cron_sj = []
|
||
|
count = 0
|
||
|
for exp in cron_exp_arr:
|
||
|
if exp.isdigit():
|
||
|
cron_sj.append(exp)
|
||
|
elif '*' == exp:
|
||
|
cron_sj.append(AllMatch())
|
||
|
elif '/' in exp:
|
||
|
range_val = int(exp.split("/")[1])
|
||
|
if count == 0:
|
||
|
cron_sj.append(range(0, 60, range_val))
|
||
|
elif count == 1:
|
||
|
cron_sj.append(range(0, 24, range_val))
|
||
|
elif count == 2:
|
||
|
cron_sj.append(range(0, 7, range_val))
|
||
|
elif count == 3:
|
||
|
cron_sj.append(range(0, 12, range_val))
|
||
|
elif count == 3:
|
||
|
cron_sj.append(range(0, 7, range_val))
|
||
|
else:
|
||
|
self.logger.warning('Unsupported expression.')
|
||
|
elif ',' in exp:
|
||
|
cron_sj.append("(" + str(exp) + ")")
|
||
|
else:
|
||
|
self.logger.warning('Unsupported expression.')
|
||
|
count += 1
|
||
|
return cron_sj
|
||
|
except Exception as e:
|
||
|
self.logger.error(
|
||
|
'A problem occurred while parsing cron expression. Error Message: {0}'.format(str(e)))
|
||
|
|
||
|
def conv_to_set(self, obj):
|
||
|
self.logger.debug('Converting {0} to set'.format(str(obj)))
|
||
|
|
||
|
if str(obj).isdigit():
|
||
|
return set([int(obj)])
|
||
|
if not isinstance(obj, set):
|
||
|
obj = set(obj)
|
||
|
|
||
|
return obj
|
||
|
|
||
|
# def is_single_shot(self):
|
||
|
# if '*' in self.task.cron_str:
|
||
|
# return True
|
||
|
# else:
|
||
|
# return False
|
||
|
|
||
|
def matchtime(self, t):
|
||
|
"""Return True if this event should trigger at the specified datetime"""
|
||
|
|
||
|
return ((t.minute in self.mins) and
|
||
|
(t.hour in self.hours) and
|
||
|
(t.day in self.days) and
|
||
|
(t.month in self.months) and
|
||
|
(t.weekday() in self.dow))
|
||
|
|
||
|
def check(self, t):
|
||
|
if self.matchtime(t) is True:
|
||
|
self.action()
|