mirror of
https://github.com/ail-project/ail-framework.git
synced 2024-11-27 00:07:16 +00:00
Merge branch 'newModuleInformation' into production
This commit is contained in:
commit
74e0bc7acb
2 changed files with 192 additions and 101 deletions
26
all_modules.txt
Normal file
26
all_modules.txt
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
Global
|
||||||
|
Duplicates
|
||||||
|
Indexer
|
||||||
|
Attributes
|
||||||
|
Lines
|
||||||
|
DomClassifier
|
||||||
|
Tokenize
|
||||||
|
Curve
|
||||||
|
CurveManageTopSets
|
||||||
|
Categ
|
||||||
|
CreditCards
|
||||||
|
Mail
|
||||||
|
Onion
|
||||||
|
DumpValidOnion
|
||||||
|
Web
|
||||||
|
WebStats
|
||||||
|
SQLInjectionDetection
|
||||||
|
ModuleStats
|
||||||
|
Browse_warning_paste
|
||||||
|
SentimentAnalysis
|
||||||
|
Release
|
||||||
|
Credential
|
||||||
|
Cve
|
||||||
|
Phone
|
||||||
|
SourceCode
|
||||||
|
Keys
|
|
@ -2,8 +2,7 @@
|
||||||
# -*-coding:UTF-8 -*
|
# -*-coding:UTF-8 -*
|
||||||
|
|
||||||
from asciimatics.widgets import Frame, ListBox, Layout, Divider, Text, \
|
from asciimatics.widgets import Frame, ListBox, Layout, Divider, Text, \
|
||||||
Button, TextBox, Widget, Label
|
Button, Label
|
||||||
from asciimatics.effects import Cycle, Print, Stars
|
|
||||||
from asciimatics.scene import Scene
|
from asciimatics.scene import Scene
|
||||||
from asciimatics.screen import Screen
|
from asciimatics.screen import Screen
|
||||||
from asciimatics.exceptions import ResizeScreenError, NextScene, StopApplication
|
from asciimatics.exceptions import ResizeScreenError, NextScene, StopApplication
|
||||||
|
@ -25,26 +24,38 @@ command_search_pid = "ps a -o pid,cmd | grep {}"
|
||||||
command_search_name = "ps a -o pid,cmd | grep {}"
|
command_search_name = "ps a -o pid,cmd | grep {}"
|
||||||
command_restart_module = "screen -S \"Script\" -X screen -t \"{}\" bash -c \"./{}.py; read x\""
|
command_restart_module = "screen -S \"Script\" -X screen -t \"{}\" bash -c \"./{}.py; read x\""
|
||||||
|
|
||||||
printarrayGlob = [None]*14
|
printarrayLog = [None]*14
|
||||||
lastTimeKillCommand = {}
|
lastTimeKillCommand = {}
|
||||||
|
|
||||||
|
# Used to pass information through scenes
|
||||||
current_selected_value = 0
|
current_selected_value = 0
|
||||||
current_selected_queue = ""
|
current_selected_queue = ""
|
||||||
current_selected_action = ""
|
current_selected_action = ""
|
||||||
current_selected_action = 0
|
current_selected_action = 0
|
||||||
|
|
||||||
|
# Map PID to Queue name (For restart and killing)
|
||||||
PID_NAME_DICO = {}
|
PID_NAME_DICO = {}
|
||||||
|
|
||||||
|
# Tables containing info for the dashboad
|
||||||
TABLES = {"running": [], "idle": [], "notRunning": [], "logs": [("No events recorded yet", 0)]}
|
TABLES = {"running": [], "idle": [], "notRunning": [], "logs": [("No events recorded yet", 0)]}
|
||||||
TABLES_TITLES = {"running": "", "idle": "", "notRunning": "", "logs": ""}
|
TABLES_TITLES = {"running": "", "idle": "", "notRunning": "", "logs": ""}
|
||||||
TABLES_PADDING = {"running": [12, 23, 8, 8, 23, 10, 55, 11, 11, 12], "idle": [9, 23, 8, 12, 50], "notRunning": [9, 23, 35], "logs": [15, 23, 8, 50]}
|
TABLES_PADDING = {"running": [12, 23, 8, 8, 23, 10, 55, 11, 11, 12], "idle": [9, 23, 8, 12, 50], "notRunning": [9, 23, 35], "logs": [15, 23, 8, 50]}
|
||||||
|
|
||||||
|
# Indicator for the health of a queue (green(0), red(2), yellow(1))
|
||||||
QUEUE_STATUS = {}
|
QUEUE_STATUS = {}
|
||||||
|
|
||||||
|
# Maintain the state of the CPU objects
|
||||||
CPU_TABLE = {}
|
CPU_TABLE = {}
|
||||||
CPU_OBJECT_TABLE = {}
|
CPU_OBJECT_TABLE = {}
|
||||||
|
|
||||||
|
# Path of the current paste for a pid
|
||||||
COMPLETE_PASTE_PATH_PER_PID = {}
|
COMPLETE_PASTE_PATH_PER_PID = {}
|
||||||
|
|
||||||
|
'''
|
||||||
|
ASCIIMATICS WIDGETS EXTENSION
|
||||||
|
'''
|
||||||
|
|
||||||
|
# Custom listbox
|
||||||
class CListBox(ListBox):
|
class CListBox(ListBox):
|
||||||
|
|
||||||
def __init__(self, queue_name, *args, **kwargs):
|
def __init__(self, queue_name, *args, **kwargs):
|
||||||
|
@ -85,6 +96,8 @@ class CListBox(ListBox):
|
||||||
self._x + self._offset + dx,
|
self._x + self._offset + dx,
|
||||||
self._y + i + dy - self._start_line,
|
self._y + i + dy - self._start_line,
|
||||||
colour, attr, bg)
|
colour, attr, bg)
|
||||||
|
|
||||||
|
# Pick color depending on queue health
|
||||||
if self.queue_name == "running":
|
if self.queue_name == "running":
|
||||||
if QUEUE_STATUS[pid] == 2:
|
if QUEUE_STATUS[pid] == 2:
|
||||||
queueStatus = Screen.COLOUR_RED
|
queueStatus = Screen.COLOUR_RED
|
||||||
|
@ -105,11 +118,13 @@ class CListBox(ListBox):
|
||||||
# Move up one line in text - use value to trigger on_select.
|
# Move up one line in text - use value to trigger on_select.
|
||||||
self._line = max(0, self._line - 1)
|
self._line = max(0, self._line - 1)
|
||||||
self.value = self._options[self._line][1]
|
self.value = self._options[self._line][1]
|
||||||
|
|
||||||
elif len(self._options) > 0 and event.key_code == Screen.KEY_DOWN:
|
elif len(self._options) > 0 and event.key_code == Screen.KEY_DOWN:
|
||||||
# Move down one line in text - use value to trigger on_select.
|
# Move down one line in text - use value to trigger on_select.
|
||||||
self._line = min(len(self._options) - 1, self._line + 1)
|
self._line = min(len(self._options) - 1, self._line + 1)
|
||||||
self.value = self._options[self._line][1]
|
self.value = self._options[self._line][1]
|
||||||
elif len(self._options) > 0 and event.key_code == ord(' '):
|
|
||||||
|
elif len(self._options) > 0 and event.key_code in [ord(' '), ord('\n')] :
|
||||||
global current_selected_value, current_selected_queue
|
global current_selected_value, current_selected_queue
|
||||||
if self.queue_name == "logs":
|
if self.queue_name == "logs":
|
||||||
return event
|
return event
|
||||||
|
@ -117,9 +132,15 @@ class CListBox(ListBox):
|
||||||
current_selected_queue = self.queue_name
|
current_selected_queue = self.queue_name
|
||||||
self._frame.save()
|
self._frame.save()
|
||||||
raise NextScene("action_choice")
|
raise NextScene("action_choice")
|
||||||
|
|
||||||
|
# Quit if press q
|
||||||
|
elif event.key_code == ord('q'):
|
||||||
|
Dashboard._quit()
|
||||||
|
|
||||||
else:
|
else:
|
||||||
# Ignore any other key press.
|
# Ignore any other key press.
|
||||||
return event
|
return event
|
||||||
|
|
||||||
elif isinstance(event, MouseEvent):
|
elif isinstance(event, MouseEvent):
|
||||||
# Mouse event - rebase coordinates to Frame context.
|
# Mouse event - rebase coordinates to Frame context.
|
||||||
new_event = self._frame.rebase_event(event)
|
new_event = self._frame.rebase_event(event)
|
||||||
|
@ -145,6 +166,7 @@ class CListBox(ListBox):
|
||||||
return event
|
return event
|
||||||
|
|
||||||
|
|
||||||
|
# Custom label centered in the middle
|
||||||
class CLabel(Label):
|
class CLabel(Label):
|
||||||
def __init__(self, label, listTitle=False):
|
def __init__(self, label, listTitle=False):
|
||||||
super(Label, self).__init__(None, tab_stop=False)
|
super(Label, self).__init__(None, tab_stop=False)
|
||||||
|
@ -166,9 +188,17 @@ class CLabel(Label):
|
||||||
self._frame.canvas.print_at(
|
self._frame.canvas.print_at(
|
||||||
self._text, self._x, self._y, colour, attr, bg)
|
self._text, self._x, self._y, colour, attr, bg)
|
||||||
|
|
||||||
class ListView(Frame):
|
'''
|
||||||
|
END EXTENSION
|
||||||
|
'''
|
||||||
|
|
||||||
|
'''
|
||||||
|
SCENE DEFINITION
|
||||||
|
'''
|
||||||
|
|
||||||
|
class Dashboard(Frame):
|
||||||
def __init__(self, screen):
|
def __init__(self, screen):
|
||||||
super(ListView, self).__init__(screen,
|
super(Dashboard, self).__init__(screen,
|
||||||
screen.height,
|
screen.height,
|
||||||
screen.width,
|
screen.width,
|
||||||
hover_focus=True,
|
hover_focus=True,
|
||||||
|
@ -255,7 +285,7 @@ class Confirm(Frame):
|
||||||
if current_selected_action == "KILL":
|
if current_selected_action == "KILL":
|
||||||
kill_module(PID_NAME_DICO[int(current_selected_value)], current_selected_value)
|
kill_module(PID_NAME_DICO[int(current_selected_value)], current_selected_value)
|
||||||
else:
|
else:
|
||||||
count = int(current_selected_amount)
|
count = int(current_selected_amount) #Number of queue to start
|
||||||
if current_selected_queue in ["running", "idle"]:
|
if current_selected_queue in ["running", "idle"]:
|
||||||
restart_module(PID_NAME_DICO[int(current_selected_value)], count)
|
restart_module(PID_NAME_DICO[int(current_selected_value)], count)
|
||||||
else:
|
else:
|
||||||
|
@ -376,13 +406,12 @@ class Show_paste(Frame):
|
||||||
title="Show current paste",
|
title="Show current paste",
|
||||||
reduce_cpu=True)
|
reduce_cpu=True)
|
||||||
|
|
||||||
# Create the form for displaying the list of contacts.
|
|
||||||
layout = Layout([100], fill_frame=True)
|
layout = Layout([100], fill_frame=True)
|
||||||
self.layout = layout
|
self.layout = layout
|
||||||
self.add_layout(layout)
|
self.add_layout(layout)
|
||||||
|
|
||||||
self.label_list = []
|
self.label_list = []
|
||||||
self.num_label = 41
|
self.num_label = 42 # Number of line available for displaying the paste
|
||||||
for i in range(self.num_label):
|
for i in range(self.num_label):
|
||||||
self.label_list += [Label("THE PASTE CONTENT " + str(i))]
|
self.label_list += [Label("THE PASTE CONTENT " + str(i))]
|
||||||
layout.add_widget(self.label_list[i])
|
layout.add_widget(self.label_list[i])
|
||||||
|
@ -410,26 +439,35 @@ class Show_paste(Frame):
|
||||||
return
|
return
|
||||||
|
|
||||||
paste = Paste.Paste(COMPLETE_PASTE_PATH_PER_PID[current_selected_value])
|
paste = Paste.Paste(COMPLETE_PASTE_PATH_PER_PID[current_selected_value])
|
||||||
old_content = paste.get_p_content()[0:4000]
|
old_content = paste.get_p_content()[0:4000] # Limit number of char to be displayed
|
||||||
|
|
||||||
#Replace unprintable char by ?
|
#Replace unprintable char by ?
|
||||||
content = ""
|
content = ""
|
||||||
for i, c in enumerate(old_content):
|
for i, c in enumerate(old_content):
|
||||||
if ord(c) > 127:
|
if ord(c) > 127: # Used to avoid printing unprintable char
|
||||||
content += '?'
|
content += '?'
|
||||||
|
elif c == "\t": # Replace tab by 4 spaces
|
||||||
|
content += " "
|
||||||
else:
|
else:
|
||||||
content += c
|
content += c
|
||||||
|
|
||||||
#Print in the correct label
|
#Print in the correct label, END or more
|
||||||
to_print = ""
|
to_print = ""
|
||||||
i = 0
|
i = 0
|
||||||
for line in content.split("\n"):
|
for line in content.split("\n"):
|
||||||
if i==self.num_label:
|
if i > self.num_label - 2:
|
||||||
break
|
break
|
||||||
self.label_list[i]._text = str(i) + ". " + line.replace("\r","")
|
self.label_list[i]._text = str(i) + ". " + line.replace("\r","")
|
||||||
i += 1
|
i += 1
|
||||||
|
|
||||||
while i<self.num_label:
|
if i > self.num_label - 2:
|
||||||
|
self.label_list[i]._text = "- ALL PASTE NOT DISPLAYED -"
|
||||||
|
i += 1
|
||||||
|
else:
|
||||||
|
self.label_list[i]._text = "- END of PASTE -"
|
||||||
|
i += 1
|
||||||
|
|
||||||
|
while i<self.num_label: #Clear out remaining lines
|
||||||
self.label_list[i]._text = ""
|
self.label_list[i]._text = ""
|
||||||
i += 1
|
i += 1
|
||||||
|
|
||||||
|
@ -445,36 +483,14 @@ class Show_paste(Frame):
|
||||||
for i in range(2,self.num_label):
|
for i in range(2,self.num_label):
|
||||||
self.label_list[i]._text = ""
|
self.label_list[i]._text = ""
|
||||||
|
|
||||||
|
'''
|
||||||
|
END SCENES DEFINITION
|
||||||
|
'''
|
||||||
|
|
||||||
def demo(screen):
|
|
||||||
dashboard = ListView(screen)
|
|
||||||
confirm = Confirm(screen)
|
|
||||||
action_choice = Action_choice(screen)
|
|
||||||
show_paste = Show_paste(screen)
|
|
||||||
scenes = [
|
|
||||||
Scene([dashboard], -1, name="dashboard"),
|
|
||||||
Scene([action_choice], -1, name="action_choice"),
|
|
||||||
Scene([confirm], -1, name="confirm"),
|
|
||||||
Scene([show_paste], -1, name="show_paste"),
|
|
||||||
]
|
|
||||||
|
|
||||||
# screen.play(scenes)
|
|
||||||
screen.set_scenes(scenes)
|
|
||||||
time_cooldown = time.time()
|
|
||||||
global TABLES
|
|
||||||
while True:
|
|
||||||
if time.time() - time_cooldown > args.refresh:
|
|
||||||
cleanRedis()
|
|
||||||
for key, val in fetchQueueData().iteritems():
|
|
||||||
TABLES[key] = val
|
|
||||||
TABLES["logs"] = format_string(printarrayGlob, TABLES_PADDING["logs"])
|
|
||||||
if current_selected_value == 0:
|
|
||||||
dashboard._update(None)
|
|
||||||
screen.refresh()
|
|
||||||
time_cooldown = time.time()
|
|
||||||
screen.draw_next_frame()
|
|
||||||
time.sleep(0.02)
|
|
||||||
|
|
||||||
|
'''
|
||||||
|
MANAGE MODULES AND GET INFOS
|
||||||
|
'''
|
||||||
|
|
||||||
def getPid(module):
|
def getPid(module):
|
||||||
p = Popen([command_search_pid.format(module+".py")], stdin=PIPE, stdout=PIPE, bufsize=1, shell=True)
|
p = Popen([command_search_pid.format(module+".py")], stdin=PIPE, stdout=PIPE, bufsize=1, shell=True)
|
||||||
|
@ -489,8 +505,7 @@ def clearRedisModuleInfo():
|
||||||
for k in server.keys("MODULE_*"):
|
for k in server.keys("MODULE_*"):
|
||||||
server.delete(k)
|
server.delete(k)
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], "*", "-", "Cleared redis module info"], 0))
|
log(([str(inst_time).split(' ')[1], "*", "-", "Cleared redis module info"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
|
|
||||||
def cleanRedis():
|
def cleanRedis():
|
||||||
for k in server.keys("MODULE_TYPE_*"):
|
for k in server.keys("MODULE_TYPE_*"):
|
||||||
|
@ -498,38 +513,39 @@ def cleanRedis():
|
||||||
for pid in server.smembers(k):
|
for pid in server.smembers(k):
|
||||||
flag_pid_valid = False
|
flag_pid_valid = False
|
||||||
proc = Popen([command_search_name.format(pid)], stdin=PIPE, stdout=PIPE, bufsize=1, shell=True)
|
proc = Popen([command_search_name.format(pid)], stdin=PIPE, stdout=PIPE, bufsize=1, shell=True)
|
||||||
for line in proc.stdout:
|
try:
|
||||||
splittedLine = line.split()
|
for line in proc.stdout:
|
||||||
if ('python2' in splittedLine or 'python' in splittedLine) and "./"+moduleName+".py" in splittedLine:
|
splittedLine = line.split()
|
||||||
flag_pid_valid = True
|
if ('python2' in splittedLine or 'python' in splittedLine) and "./"+moduleName+".py" in splittedLine:
|
||||||
|
flag_pid_valid = True
|
||||||
|
|
||||||
if not flag_pid_valid:
|
if not flag_pid_valid:
|
||||||
#print flag_pid_valid, 'cleaning', pid, 'in', k
|
#print flag_pid_valid, 'cleaning', pid, 'in', k
|
||||||
server.srem(k, pid)
|
server.srem(k, pid)
|
||||||
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
|
log(([str(inst_time).split(' ')[1], moduleName, pid, "Cleared invalid pid in " + k], 0))
|
||||||
|
|
||||||
|
#Error due to resize, interrupted sys call
|
||||||
|
except IOError as e:
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], moduleName, pid, "Cleared invalid pid in " + k], 0))
|
log(([str(inst_time).split(' ')[1], " - ", " - ", "Cleaning fail due to resize."], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
#time.sleep(5)
|
|
||||||
|
|
||||||
def restart_module(module, count=1):
|
def restart_module(module, count=1):
|
||||||
for i in range(count):
|
for i in range(count):
|
||||||
p2 = Popen([command_restart_module.format(module, module)], stdin=PIPE, stdout=PIPE, bufsize=1, shell=True)
|
p2 = Popen([command_restart_module.format(module, module)], stdin=PIPE, stdout=PIPE, bufsize=1, shell=True)
|
||||||
time.sleep(0.2)
|
time.sleep(0.2)
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, "?", "Restarted " + str(count) + "x"], 0))
|
log(([str(inst_time).split(' ')[1], module, "?", "Restarted " + str(count) + "x"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def kill_module(module, pid):
|
def kill_module(module, pid):
|
||||||
#print ''
|
|
||||||
#print '-> trying to kill module:', module
|
#print '-> trying to kill module:', module
|
||||||
|
|
||||||
if pid is None:
|
if pid is None:
|
||||||
#print 'pid was None'
|
#print 'pid was None'
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, pid, "PID was None"], 0))
|
log(([str(inst_time).split(' ')[1], module, pid, "PID was None"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
pid = getPid(module)
|
pid = getPid(module)
|
||||||
else: #Verify that the pid is at least in redis
|
else: #Verify that the pid is at least in redis
|
||||||
if server.exists("MODULE_"+module+"_"+str(pid)) == 0:
|
if server.exists("MODULE_"+module+"_"+str(pid)) == 0:
|
||||||
|
@ -538,62 +554,51 @@ def kill_module(module, pid):
|
||||||
lastTimeKillCommand[pid] = int(time.time())
|
lastTimeKillCommand[pid] = int(time.time())
|
||||||
if pid is not None:
|
if pid is not None:
|
||||||
try:
|
try:
|
||||||
#os.kill(pid, signal.SIGUSR1)
|
|
||||||
p = psutil.Process(int(pid))
|
p = psutil.Process(int(pid))
|
||||||
p.terminate()
|
p.terminate()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
#print pid, 'already killed'
|
#print pid, 'already killed'
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, pid, "Already killed"], 0))
|
log(([str(inst_time).split(' ')[1], module, pid, "Already killed"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
return
|
return
|
||||||
time.sleep(0.2)
|
time.sleep(0.2)
|
||||||
if not p.is_running():
|
if not p.is_running():
|
||||||
#print module, 'has been killed'
|
#print module, 'has been killed'
|
||||||
#print 'restarting', module, '...'
|
#print 'restarting', module, '...'
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, pid, "Killed"], 0))
|
log(([str(inst_time).split(' ')[1], module, pid, "Killed"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
#restart_module(module)
|
#restart_module(module)
|
||||||
|
|
||||||
else:
|
else:
|
||||||
#print 'killing failed, retrying...'
|
#print 'killing failed, retrying...'
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, pid, "Killing #1 failed."], 0))
|
log(([str(inst_time).split(' ')[1], module, pid, "Killing #1 failed."], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
|
|
||||||
#os.kill(pid, signal.SIGUSR1)
|
|
||||||
#time.sleep(1)
|
|
||||||
p.terminate()
|
p.terminate()
|
||||||
if not p.is_running():
|
if not p.is_running():
|
||||||
#print module, 'has been killed'
|
#print module, 'has been killed'
|
||||||
#print 'restarting', module, '...'
|
#print 'restarting', module, '...'
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, pid, "Killed"], 0))
|
log(([str(inst_time).split(' ')[1], module, pid, "Killed"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
#restart_module(module)
|
#restart_module(module)
|
||||||
else:
|
else:
|
||||||
#print 'killing failed!'
|
#print 'killing failed!'
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, pid, "Killing failed!"], 0))
|
log(([str(inst_time).split(' ')[1], module, pid, "Killing failed!"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
else:
|
else:
|
||||||
#print 'Module does not exist'
|
#print 'Module does not exist'
|
||||||
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
inst_time = datetime.datetime.fromtimestamp(int(time.time()))
|
||||||
printarrayGlob.insert(0, ([str(inst_time).split(' ')[1], module, pid, "Killing failed, module not found"], 0))
|
log(([str(inst_time).split(' ')[1], module, pid, "Killing failed, module not found"], 0))
|
||||||
printarrayGlob.pop()
|
|
||||||
#time.sleep(5)
|
|
||||||
cleanRedis()
|
cleanRedis()
|
||||||
|
|
||||||
|
|
||||||
|
# Fetch the data for all queue
|
||||||
|
|
||||||
def fetchQueueData():
|
def fetchQueueData():
|
||||||
|
|
||||||
all_queue = set()
|
all_queue = set()
|
||||||
printarray1 = []
|
printarray_running = []
|
||||||
printarray2 = []
|
printarray_idle = []
|
||||||
printarray3 = []
|
printarray_notrunning = []
|
||||||
for queue, card in server.hgetall("queues").iteritems():
|
for queue, card in server.hgetall("queues").iteritems():
|
||||||
all_queue.add(queue)
|
all_queue.add(queue)
|
||||||
key = "MODULE_" + queue + "_"
|
key = "MODULE_" + queue + "_"
|
||||||
|
@ -604,9 +609,11 @@ def fetchQueueData():
|
||||||
value = server.get(key + str(moduleNum))
|
value = server.get(key + str(moduleNum))
|
||||||
complete_paste_path = server.get(key + str(moduleNum) + "_PATH")
|
complete_paste_path = server.get(key + str(moduleNum) + "_PATH")
|
||||||
COMPLETE_PASTE_PATH_PER_PID[moduleNum] = complete_paste_path
|
COMPLETE_PASTE_PATH_PER_PID[moduleNum] = complete_paste_path
|
||||||
|
|
||||||
if value is not None:
|
if value is not None:
|
||||||
timestamp, path = value.split(", ")
|
timestamp, path = value.split(", ")
|
||||||
if timestamp is not None and path is not None:
|
if timestamp is not None and path is not None:
|
||||||
|
# Queue health
|
||||||
startTime_readable = datetime.datetime.fromtimestamp(int(timestamp))
|
startTime_readable = datetime.datetime.fromtimestamp(int(timestamp))
|
||||||
processed_time_readable = str((datetime.datetime.now() - startTime_readable)).split('.')[0]
|
processed_time_readable = str((datetime.datetime.now() - startTime_readable)).split('.')[0]
|
||||||
if ((datetime.datetime.now() - startTime_readable).total_seconds()) > args.treshold:
|
if ((datetime.datetime.now() - startTime_readable).total_seconds()) > args.treshold:
|
||||||
|
@ -616,9 +623,11 @@ def fetchQueueData():
|
||||||
else:
|
else:
|
||||||
QUEUE_STATUS[moduleNum] = 0
|
QUEUE_STATUS[moduleNum] = 0
|
||||||
|
|
||||||
|
# Queue contain elements
|
||||||
if int(card) > 0:
|
if int(card) > 0:
|
||||||
|
# Queue need to be killed
|
||||||
if int((datetime.datetime.now() - startTime_readable).total_seconds()) > args.treshold:
|
if int((datetime.datetime.now() - startTime_readable).total_seconds()) > args.treshold:
|
||||||
#log = open(log_filename, 'a')
|
log(([time.time(), queue, "-", "ST:"+timestamp+" PT:"+time.time()-timestamp], 0), True)
|
||||||
#log.write(json.dumps([queue, card, str(startTime_readable), str(processed_time_readable), path]) + "\n")
|
#log.write(json.dumps([queue, card, str(startTime_readable), str(processed_time_readable), path]) + "\n")
|
||||||
try:
|
try:
|
||||||
last_kill_try = time.time() - lastTimeKillCommand[moduleNum]
|
last_kill_try = time.time() - lastTimeKillCommand[moduleNum]
|
||||||
|
@ -627,6 +636,7 @@ def fetchQueueData():
|
||||||
if args.autokill == 1 and last_kill_try > kill_retry_threshold :
|
if args.autokill == 1 and last_kill_try > kill_retry_threshold :
|
||||||
kill_module(queue, int(moduleNum))
|
kill_module(queue, int(moduleNum))
|
||||||
|
|
||||||
|
# Create CPU objects
|
||||||
try:
|
try:
|
||||||
cpu_percent = CPU_OBJECT_TABLE[int(moduleNum)].cpu_percent()
|
cpu_percent = CPU_OBJECT_TABLE[int(moduleNum)].cpu_percent()
|
||||||
CPU_TABLE[moduleNum].insert(1, cpu_percent)
|
CPU_TABLE[moduleNum].insert(1, cpu_percent)
|
||||||
|
@ -646,43 +656,47 @@ def fetchQueueData():
|
||||||
cpu_avg = cpu_percent
|
cpu_avg = cpu_percent
|
||||||
mem_percent = 0
|
mem_percent = 0
|
||||||
|
|
||||||
array_module_type.append( ([" <K> [ ]", str(queue), str(moduleNum), str(card), str(startTime_readable), str(processed_time_readable), str(path), "{0:.2f}".format(cpu_percent)+"%", "{0:.2f}".format(mem_percent)+"%", "{0:.2f}".format(cpu_avg)+"%"], moduleNum) )
|
array_module_type.append( ([" <K> [ ]", str(queue), str(moduleNum), str(card), str(startTime_readable),
|
||||||
|
str(processed_time_readable), str(path), "{0:.2f}".format(cpu_percent)+"%",
|
||||||
|
"{0:.2f}".format(mem_percent)+"%", "{0:.2f}".format(cpu_avg)+"%"], moduleNum) )
|
||||||
|
|
||||||
else:
|
else:
|
||||||
printarray2.append( ([" <K> ", str(queue), str(moduleNum), str(processed_time_readable), str(path)], moduleNum) )
|
printarray_idle.append( ([" <K> ", str(queue), str(moduleNum), str(processed_time_readable), str(path)], moduleNum) )
|
||||||
|
|
||||||
PID_NAME_DICO[int(moduleNum)] = str(queue)
|
PID_NAME_DICO[int(moduleNum)] = str(queue)
|
||||||
array_module_type.sort(lambda x,y: cmp(x[0][4], y[0][4]), reverse=True)
|
array_module_type.sort(lambda x,y: cmp(x[0][4], y[0][4]), reverse=True) #Sort by num of pastes
|
||||||
for e in array_module_type:
|
for e in array_module_type:
|
||||||
printarray1.append(e)
|
printarray_running.append(e)
|
||||||
|
|
||||||
for curr_queue in module_file_array:
|
for curr_queue in module_file_array:
|
||||||
if curr_queue not in all_queue:
|
if curr_queue not in all_queue: #Module not running by default
|
||||||
printarray3.append( ([" <S> ", curr_queue, "Not running by default"], curr_queue) )
|
printarray_notrunning.append( ([" <S> ", curr_queue, "Not running by default"], curr_queue) )
|
||||||
else:
|
else: #Module did not process anything yet
|
||||||
if len(list(server.smembers('MODULE_TYPE_'+curr_queue))) == 0:
|
if len(list(server.smembers('MODULE_TYPE_'+curr_queue))) == 0:
|
||||||
if curr_queue not in no_info_modules:
|
if curr_queue not in no_info_modules:
|
||||||
no_info_modules[curr_queue] = int(time.time())
|
no_info_modules[curr_queue] = int(time.time())
|
||||||
printarray3.append( ([" <S> ", curr_queue, "No data"], curr_queue) )
|
printarray_notrunning.append( ([" <S> ", curr_queue, "No data"], curr_queue) )
|
||||||
else:
|
else:
|
||||||
#If no info since long time, try to kill
|
#If no info since long time, try to kill
|
||||||
if args.autokill == 1:
|
if args.autokill == 1:
|
||||||
if int(time.time()) - no_info_modules[curr_queue] > args.treshold:
|
if int(time.time()) - no_info_modules[curr_queue] > args.treshold:
|
||||||
kill_module(curr_queue, None)
|
kill_module(curr_queue, None)
|
||||||
no_info_modules[curr_queue] = int(time.time())
|
no_info_modules[curr_queue] = int(time.time())
|
||||||
printarray3.append( ([" <S> ", curr_queue, "Stuck or idle, restarting in " + str(abs(args.treshold - (int(time.time()) - no_info_modules[curr_queue]))) + "s"], curr_queue) )
|
printarray_notrunning.append( ([" <S> ", curr_queue, "Stuck or idle, restarting in " + str(abs(args.treshold - (int(time.time()) - no_info_modules[curr_queue]))) + "s"], curr_queue) )
|
||||||
else:
|
else:
|
||||||
printarray3.append( ([" <S> ", curr_queue, "Stuck or idle, restarting disabled"], curr_queue) )
|
printarray_notrunning.append( ([" <S> ", curr_queue, "Stuck or idle, restarting disabled"], curr_queue) )
|
||||||
|
|
||||||
|
|
||||||
printarray1.sort(key=lambda x: x[0], reverse=False)
|
printarray_running.sort(key=lambda x: x[0], reverse=False)
|
||||||
printarray2.sort(key=lambda x: x[0], reverse=False)
|
printarray_idle.sort(key=lambda x: x[0], reverse=False)
|
||||||
|
|
||||||
printstring1 = format_string(printarray1, TABLES_PADDING["running"])
|
printstring_running = format_string(printarray_running, TABLES_PADDING["running"])
|
||||||
printstring2 = format_string(printarray2, TABLES_PADDING["idle"])
|
printstring_idle = format_string(printarray_idle, TABLES_PADDING["idle"])
|
||||||
printstring3 = format_string(printarray3, TABLES_PADDING["notRunning"])
|
printstring_notrunning = format_string(printarray_notrunning, TABLES_PADDING["notRunning"])
|
||||||
|
|
||||||
return {"running": printstring1, "idle": printstring2, "notRunning": printstring3}
|
return {"running": printstring_running, "idle": printstring_idle, "notRunning": printstring_notrunning}
|
||||||
|
|
||||||
|
# Format the input string with its related padding to have collumn like text in CListBox
|
||||||
def format_string(tab, padding_row):
|
def format_string(tab, padding_row):
|
||||||
printstring = []
|
printstring = []
|
||||||
for row in tab:
|
for row in tab:
|
||||||
|
@ -703,6 +717,52 @@ def format_string(tab, padding_row):
|
||||||
printstring.append( (text, the_pid) )
|
printstring.append( (text, the_pid) )
|
||||||
return printstring
|
return printstring
|
||||||
|
|
||||||
|
def log(data, write_on_disk=False):
|
||||||
|
printarrayLog.insert(0, data)
|
||||||
|
printarrayLog.pop()
|
||||||
|
if write_on_disk:
|
||||||
|
with open(log_filename, 'a') as log:
|
||||||
|
log.write(json.dumps(data[0]) + "\n")
|
||||||
|
|
||||||
|
'''
|
||||||
|
END MANAGE
|
||||||
|
'''
|
||||||
|
|
||||||
|
def demo(screen):
|
||||||
|
dashboard = Dashboard(screen)
|
||||||
|
confirm = Confirm(screen)
|
||||||
|
action_choice = Action_choice(screen)
|
||||||
|
show_paste = Show_paste(screen)
|
||||||
|
scenes = [
|
||||||
|
Scene([dashboard], -1, name="dashboard"),
|
||||||
|
Scene([action_choice], -1, name="action_choice"),
|
||||||
|
Scene([confirm], -1, name="confirm"),
|
||||||
|
Scene([show_paste], -1, name="show_paste"),
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
screen.set_scenes(scenes)
|
||||||
|
time_cooldown = time.time() # Cooldown before refresh
|
||||||
|
global TABLES
|
||||||
|
while True:
|
||||||
|
#Stop on resize
|
||||||
|
if screen.has_resized():
|
||||||
|
screen._scenes[screen._scene_index].exit()
|
||||||
|
raise ResizeScreenError("Screen resized", screen._scenes[screen._scene_index])
|
||||||
|
|
||||||
|
if time.time() - time_cooldown > args.refresh:
|
||||||
|
cleanRedis()
|
||||||
|
for key, val in fetchQueueData().iteritems(): #fetch data and put it into the tables
|
||||||
|
TABLES[key] = val
|
||||||
|
TABLES["logs"] = format_string(printarrayLog, TABLES_PADDING["logs"])
|
||||||
|
|
||||||
|
#refresh dashboad only if the scene is active (no value selected)
|
||||||
|
if current_selected_value == 0:
|
||||||
|
dashboard._update(None)
|
||||||
|
screen.refresh()
|
||||||
|
time_cooldown = time.time()
|
||||||
|
screen.draw_next_frame()
|
||||||
|
time.sleep(0.02) #time between screen refresh (For UI navigation, not data actualisation)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
@ -755,7 +815,12 @@ if __name__ == "__main__":
|
||||||
except SyntaxError:
|
except SyntaxError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
last_scene = None
|
||||||
while True:
|
while True:
|
||||||
Screen.wrapper(demo)
|
try:
|
||||||
sys.exit(0)
|
Screen.wrapper(demo)
|
||||||
|
sys.exit(0)
|
||||||
|
except ResizeScreenError as e:
|
||||||
|
pass
|
||||||
|
except StopApplication:
|
||||||
|
sys.exit(0)
|
||||||
|
|
Loading…
Reference in a new issue