Introduce threshold dependant shell output coloring with unit presentation
This commit is contained in:
parent
618ebbeccc
commit
37db4b7f18
1 changed files with 21 additions and 3 deletions
|
@ -40,6 +40,7 @@ class Module(core.module.Module):
|
||||||
def __init__(self, config, theme):
|
def __init__(self, config, theme):
|
||||||
super().__init__(config, theme, core.widget.Widget(self.get_output))
|
super().__init__(config, theme, core.widget.Widget(self.get_output))
|
||||||
|
|
||||||
|
self.__unit= self.parameter("unit", 'echo "no unit configured"')
|
||||||
self.__command = self.parameter("command", 'echo "no command configured"')
|
self.__command = self.parameter("command", 'echo "no command configured"')
|
||||||
self.__async = util.format.asbool(self.parameter("async"))
|
self.__async = util.format.asbool(self.parameter("async"))
|
||||||
|
|
||||||
|
@ -55,7 +56,7 @@ class Module(core.module.Module):
|
||||||
self.__output = value
|
self.__output = value
|
||||||
|
|
||||||
def get_output(self, _):
|
def get_output(self, _):
|
||||||
return self.__output
|
return self.__output + str(self.parameter("unit"))
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
# if requested then run not async version and just execute command in this thread
|
# if requested then run not async version and just execute command in this thread
|
||||||
|
@ -77,7 +78,24 @@ class Module(core.module.Module):
|
||||||
self.__current_thread.start()
|
self.__current_thread.start()
|
||||||
|
|
||||||
def state(self, _):
|
def state(self, _):
|
||||||
|
if self.parameter("unit") is None:
|
||||||
if self.__output == "no command configured":
|
if self.__output == "no command configured":
|
||||||
|
return "critical"
|
||||||
|
else:
|
||||||
|
if self.parameter("warning") is None:
|
||||||
|
warning_threshold = 75
|
||||||
|
else:
|
||||||
|
warning_threshold = float(self.parameter("warning"))
|
||||||
|
|
||||||
|
if self.parameter("critical") is None:
|
||||||
|
critical_threshold = 90
|
||||||
|
else:
|
||||||
|
critical_threshold = float(self.parameter("critical"))
|
||||||
|
|
||||||
|
if float(self.__output) > critical_threshold:
|
||||||
|
return "critical"
|
||||||
|
|
||||||
|
if float(self.__output) > warning_threshold:
|
||||||
return "warning"
|
return "warning"
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue