4
4
# Mandos Monitor - Control and monitor the Mandos server
6
# Copyright © 2008-2012 Teddy Hogeborn
7
# Copyright © 2008-2012 Björn Påhlsson
6
# Copyright © 2008-2010 Teddy Hogeborn
7
# Copyright © 2008-2010 Björn Påhlsson
9
9
# This program is free software: you can redistribute it and/or modify
10
10
# it under the terms of the GNU General Public License as published by
19
19
# You should have received a copy of the GNU General Public License
20
20
# along with this program. If not, see <http://www.gnu.org/licenses/>.
22
# Contact the authors at <mandos@recompile.se>.
22
# Contact the authors at <mandos@fukt.bsnet.se>.
25
25
from __future__ import (division, absolute_import, print_function,
55
55
"ExtendedTimeout" : "Extended Timeout"
57
57
defaultkeywords = ("Name", "Enabled", "Timeout", "LastCheckedOK")
58
domain = "se.recompile"
58
domain = "se.bsnet.fukt"
59
59
busname = domain + ".Mandos"
61
61
server_interface = domain + ".Mandos"
62
62
client_interface = domain + ".Mandos.Client"
65
65
def timedelta_to_milliseconds(td):
66
66
"""Convert a datetime.timedelta object to milliseconds"""
71
71
def milliseconds_to_string(ms):
72
72
td = datetime.timedelta(0, 0, 0, ms)
73
return ("{days}{hours:02}:{minutes:02}:{seconds:02}"
74
.format(days = "{0}T".format(td.days) if td.days else "",
75
hours = td.seconds // 3600,
76
minutes = (td.seconds % 3600) // 60,
77
seconds = td.seconds % 60,
73
return ("%(days)s%(hours)02d:%(minutes)02d:%(seconds)02d"
74
% { "days": "%dT" % td.days if td.days else "",
75
"hours": td.seconds // 3600,
76
"minutes": (td.seconds % 3600) // 60,
77
"seconds": td.seconds % 60,
80
80
def string_to_delta(interval):
81
81
"""Parse a string and return a datetime.timedelta
93
93
>>> string_to_delta("5m 30s")
94
94
datetime.timedelta(0, 330)
96
value = datetime.timedelta(0)
97
regexp = re.compile("(\d+)([dsmhw]?)")
96
timevalue = datetime.timedelta(0)
97
regexp = re.compile("\d+[dsmhw]")
99
for num, suffix in regexp.findall(interval):
101
value += datetime.timedelta(int(num))
103
value += datetime.timedelta(0, int(num))
105
value += datetime.timedelta(0, 0, 0, 0, int(num))
107
value += datetime.timedelta(0, 0, 0, 0, 0, int(num))
109
value += datetime.timedelta(0, 0, 0, 0, 0, 0, int(num))
111
value += datetime.timedelta(0, 0, 0, int(num))
99
for s in regexp.findall(interval):
101
suffix = unicode(s[-1])
104
delta = datetime.timedelta(value)
106
delta = datetime.timedelta(0, value)
108
delta = datetime.timedelta(0, 0, 0, 0, value)
110
delta = datetime.timedelta(0, 0, 0, 0, 0, value)
112
delta = datetime.timedelta(0, 0, 0, 0, 0, 0, value)
115
except (ValueError, IndexError):
114
120
def print_clients(clients, keywords):
115
121
def valuetostring(value, keyword):
121
127
return unicode(value)
123
129
# Create format string to print table rows
124
format_string = " ".join("{{{key}:{width}}}".format(
125
width = max(len(tablewords[key]),
126
max(len(valuetostring(client[key],
130
key = key) for key in keywords)
130
format_string = " ".join("%%-%ds" %
131
max(len(tablewords[key]),
132
max(len(valuetostring(client[key],
131
137
# Print header line
132
print(format_string.format(**tablewords))
138
print(format_string % tuple(tablewords[key] for key in keywords))
133
139
for client in clients:
134
print(format_string.format(**dict((key,
135
valuetostring(client[key],
137
for key in keywords)))
140
print(format_string % tuple(valuetostring(client[key], key)
141
for key in keywords))
139
143
def has_actions(options):
140
144
return any((options.enable,
160
164
parser = argparse.ArgumentParser()
161
165
parser.add_argument("--version", action="version",
162
version = "%(prog)s {0}".format(version),
166
version = "%%prog %s" % version,
163
167
help="show version number and exit")
164
168
parser.add_argument("-a", "--all", action="store_true",
165
169
help="Select all clients")
298
302
dbus.PROPERTIES_IFACE)
300
if options.checker is not None:
301
305
client.Set(client_interface, "Checker",
303
307
dbus_interface=dbus.PROPERTIES_IFACE)
304
if options.host is not None:
305
309
client.Set(client_interface, "Host", options.host,
306
310
dbus_interface=dbus.PROPERTIES_IFACE)
307
if options.interval is not None:
308
312
client.Set(client_interface, "Interval",
309
313
timedelta_to_milliseconds
310
314
(string_to_delta(options.interval)),
311
315
dbus_interface=dbus.PROPERTIES_IFACE)
312
if options.approval_delay is not None:
316
if options.approval_delay:
313
317
client.Set(client_interface, "ApprovalDelay",
314
318
timedelta_to_milliseconds
315
319
(string_to_delta(options.
316
320
approval_delay)),
317
321
dbus_interface=dbus.PROPERTIES_IFACE)
318
if options.approval_duration is not None:
322
if options.approval_duration:
319
323
client.Set(client_interface, "ApprovalDuration",
320
324
timedelta_to_milliseconds
321
325
(string_to_delta(options.
322
326
approval_duration)),
323
327
dbus_interface=dbus.PROPERTIES_IFACE)
324
if options.timeout is not None:
325
329
client.Set(client_interface, "Timeout",
326
330
timedelta_to_milliseconds
327
331
(string_to_delta(options.timeout)),
328
332
dbus_interface=dbus.PROPERTIES_IFACE)
329
if options.extended_timeout is not None:
333
if options.extended_timeout:
330
334
client.Set(client_interface, "ExtendedTimeout",
331
335
timedelta_to_milliseconds
332
336
(string_to_delta(options.extended_timeout)),
333
337
dbus_interface=dbus.PROPERTIES_IFACE)
334
if options.secret is not None:
335
339
client.Set(client_interface, "Secret",
336
dbus.ByteArray(options.secret.read()),
340
dbus.ByteArray(open(options.secret,
337
342
dbus_interface=dbus.PROPERTIES_IFACE)
338
343
if options.approved_by_default is not None:
339
344
client.Set(client_interface, "ApprovedByDefault",