mirror of https://github.com/Icinga/icinga2.git
parent
2d42cae358
commit
b16e6d7e52
|
@ -15,14 +15,52 @@
|
||||||
# along with this program; if not, write to the Free Software Foundation
|
# along with this program; if not, write to the Free Software Foundation
|
||||||
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
from icinga2.utils.debug import ObjectsFile
|
import os, sys, getopt
|
||||||
|
from icinga2.utils.debug import ObjectsFileReader
|
||||||
from icinga2.config import LocalStateDir
|
from icinga2.config import LocalStateDir
|
||||||
from signal import signal, SIGPIPE, SIG_DFL
|
from signal import signal, SIGPIPE, SIG_DFL
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
signal(SIGPIPE, SIG_DFL)
|
signal(SIGPIPE, SIG_DFL)
|
||||||
|
|
||||||
fp = open(LocalStateDir + "/cache/icinga2/icinga2.debug")
|
color_mode = 'auto'
|
||||||
of = ObjectsFile(fp)
|
|
||||||
for obj in of:
|
try:
|
||||||
print obj
|
opts, args = getopt.getopt(sys.argv[1:], "h", ["help", "color"])
|
||||||
|
except getopt.GetoptError as err:
|
||||||
|
# print help information and exit:
|
||||||
|
print str(err) # will print something like "option -a not recognized"
|
||||||
|
usage()
|
||||||
|
sys.exit(2)
|
||||||
|
output = None
|
||||||
|
verbose = False
|
||||||
|
for o, a in opts:
|
||||||
|
if o in ("-h", "--help"):
|
||||||
|
usage()
|
||||||
|
sys.exit()
|
||||||
|
elif o == "--color":
|
||||||
|
color_mode = 'always'
|
||||||
|
else:
|
||||||
|
assert False, "unhandled option"
|
||||||
|
|
||||||
|
if len(args) > 0:
|
||||||
|
fname = args[0]
|
||||||
|
else:
|
||||||
|
fname = LocalStateDir + "/cache/icinga2/icinga2.debug"
|
||||||
|
|
||||||
|
if color_mode == 'always':
|
||||||
|
use_colors = True
|
||||||
|
elif color_mode == 'never':
|
||||||
|
use_colors = False
|
||||||
|
else:
|
||||||
|
use_colors = os.isatty(1)
|
||||||
|
|
||||||
|
fp = open(fname)
|
||||||
|
ofr = ObjectsFileReader(fp)
|
||||||
|
for obj in ofr:
|
||||||
|
print obj.format(use_colors)
|
||||||
|
|
||||||
|
def usage():
|
||||||
|
print "Syntax: %s [--color] [file]" % (sys.argv[0])
|
||||||
|
print ""
|
||||||
|
print "Displays a list of objects from the specified Icinga 2 objects file."
|
||||||
|
|
|
@ -39,16 +39,13 @@ class DebugObject(object):
|
||||||
def __init__(self, obj):
|
def __init__(self, obj):
|
||||||
self._obj = obj
|
self._obj = obj
|
||||||
|
|
||||||
def __str__(self):
|
def format(self, use_colors=False):
|
||||||
return self.format_object()
|
|
||||||
|
|
||||||
def format_object(self):
|
|
||||||
if self._obj["abstract"]:
|
if self._obj["abstract"]:
|
||||||
result = "Template '"
|
result = "Template '"
|
||||||
else:
|
else:
|
||||||
result = "Object '"
|
result = "Object '"
|
||||||
result += self._obj["properties"]["__name"] + "' of type '" + self._obj["type"] + "':\n"
|
result += self._obj["properties"]["__name"] + "' of type '" + self._obj["type"] + "':\n"
|
||||||
result += self.format_properties(2)
|
result += self.format_properties(use_colors, 2)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
|
@ -65,26 +62,33 @@ class DebugObject(object):
|
||||||
else:
|
else:
|
||||||
return str(value)
|
return str(value)
|
||||||
|
|
||||||
def format_properties(self, indent=0, path=[]):
|
def format_properties(self, use_colors=False, indent=0, path=[]):
|
||||||
props = self._obj["properties"]
|
props = self._obj["properties"]
|
||||||
for component in path:
|
for component in path:
|
||||||
props = props[component]
|
props = props[component]
|
||||||
|
|
||||||
|
if use_colors:
|
||||||
|
color_begin = _colors.GREEN
|
||||||
|
color_end = _colors.RESET
|
||||||
|
else:
|
||||||
|
color_begin = ''
|
||||||
|
color_end = ''
|
||||||
|
|
||||||
result = ""
|
result = ""
|
||||||
for key, value in props.items():
|
for key, value in props.items():
|
||||||
path.append(key)
|
path.append(key)
|
||||||
result += ' ' * indent + "* %s%s%s" % (_colors.GREEN, key, _colors.RESET)
|
result += ' ' * indent + "* %s%s%s" % (color_begin, key, color_end)
|
||||||
hints = self.format_hints(self, indent + 2, path)
|
hints = self.format_hints(use_colors, indent + 2, path)
|
||||||
if isinstance(value, dict):
|
if isinstance(value, dict):
|
||||||
result += "\n" + hints
|
result += "\n" + hints
|
||||||
result += self.format_properties(indent + 2, path)
|
result += self.format_properties(use_colors, indent + 2, path)
|
||||||
else:
|
else:
|
||||||
result += " = %s\n" % (DebugObject.format_value(value))
|
result += " = %s\n" % (DebugObject.format_value(value))
|
||||||
result += hints
|
result += hints
|
||||||
path.pop()
|
path.pop()
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def format_hints(self, dhints, indent=0, path=[]):
|
def format_hints(self, use_colors, indent=0, path=[]):
|
||||||
dhints = self._obj["debug_hints"]
|
dhints = self._obj["debug_hints"]
|
||||||
try:
|
try:
|
||||||
for component in path:
|
for component in path:
|
||||||
|
@ -92,13 +96,20 @@ class DebugObject(object):
|
||||||
except KeyError:
|
except KeyError:
|
||||||
return ""
|
return ""
|
||||||
|
|
||||||
|
if use_colors:
|
||||||
|
color_begin = _colors.CYAN
|
||||||
|
color_end = _colors.RESET
|
||||||
|
else:
|
||||||
|
color_begin = ''
|
||||||
|
color_end = ''
|
||||||
|
|
||||||
result = ""
|
result = ""
|
||||||
for message in dhints["messages"]:
|
for message in dhints["messages"]:
|
||||||
result += ' ' * indent + "%% %smodified in %s, lines %s:%s-%s:%s%s\n" % (_colors.CYAN,
|
result += ' ' * indent + "%% %smodified in %s, lines %s:%s-%s:%s%s\n" % (color_begin,
|
||||||
message[1], message[2], message[3], message[4], message[5], _colors.RESET)
|
message[1], message[2], message[3], message[4], message[5], color_end)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
class ObjectsFile(object):
|
class ObjectsFileReader(object):
|
||||||
def __init__(self, file):
|
def __init__(self, file):
|
||||||
self._file = file
|
self._file = file
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue