4
4
# Mandos Monitor - Control and monitor the Mandos server
 
6
 
# Copyright © 2009-2012 Teddy Hogeborn
 
7
 
# Copyright © 2009-2012 Björn Påhlsson
 
 
6
# Copyright © 2009-2011 Teddy Hogeborn
 
 
7
# Copyright © 2009-2011 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,
 
 
49
49
logging.getLogger('dbus.proxies').setLevel(logging.CRITICAL)
 
51
51
# Some useful constants
 
52
 
domain = 'se.recompile'
 
 
52
domain = 'se.bsnet.fukt'
 
53
53
server_interface = domain + '.Mandos'
 
54
54
client_interface = domain + '.Mandos.Client'
 
57
57
# Always run in monochrome mode
 
58
58
urwid.curses_display.curses.has_colors = lambda : False
 
 
244
243
    def checker_started(self, command):
 
245
 
        """Server signals that a checker started. This could be useful
 
246
 
           to log in the future. """
 
247
244
        #self.logger('Client %s started checker "%s"'
 
248
245
        #            % (self.properties["Name"], unicode(command)))
 
 
317
314
                message = "Denial in %s. (a)pprove?"
 
318
315
            message = message % unicode(timer).rsplit(".", 1)[0]
 
319
316
        elif self.last_checker_failed:
 
320
 
            # When checker has failed, print a timer until client expires
 
321
 
            expires = self.properties["Expires"]
 
323
 
                timer = datetime.timedelta(0)
 
325
 
                expires = datetime.datetime.strptime(expires,
 
326
 
                                                     '%Y-%m-%dT%H:%M:%S.%f')
 
327
 
                timer = expires - datetime.datetime.utcnow()
 
 
317
            timeout = datetime.timedelta(milliseconds
 
 
320
            last_ok = isoformat_to_datetime(
 
 
321
                max((self.properties["LastCheckedOK"]
 
 
322
                     or self.properties["Created"]),
 
 
323
                    self.properties["LastEnabled"]))
 
 
324
            timer = timeout - (datetime.datetime.utcnow() - last_ok)
 
328
325
            message = ('A checker has failed! Time until client'
 
329
326
                       ' gets disabled: %s'
 
330
327
                           % unicode(timer).rsplit(".", 1)[0])
 
 
500
496
        self.busname = domain + '.Mandos'
 
501
497
        self.main_loop = gobject.MainLoop()
 
 
498
        self.bus = dbus.SystemBus()
 
 
499
        mandos_dbus_objc = self.bus.get_object(
 
 
500
            self.busname, "/", follow_name_owner_changes=True)
 
 
501
        self.mandos_serv = dbus.Interface(mandos_dbus_objc,
 
 
505
            mandos_clients = (self.mandos_serv
 
 
506
                              .GetAllClientsWithProperties())
 
 
507
        except dbus.exceptions.DBusException:
 
 
508
            mandos_clients = dbus.Dictionary()
 
 
511
         .connect_to_signal("ClientRemoved",
 
 
512
                            self.find_and_remove_client,
 
 
513
                            dbus_interface=server_interface,
 
 
516
         .connect_to_signal("ClientAdded",
 
 
518
                            dbus_interface=server_interface,
 
 
521
         .connect_to_signal("ClientNotFound",
 
 
522
                            self.client_not_found,
 
 
523
                            dbus_interface=server_interface,
 
 
525
        for path, client in mandos_clients.iteritems():
 
 
526
            client_proxy_object = self.bus.get_object(self.busname,
 
 
528
            self.add_client(MandosClientWidget(server_proxy_object
 
 
531
                                               =client_proxy_object,
 
503
541
    def client_not_found(self, fingerprint, address):
 
504
542
        self.log_message(("Client with address %s and fingerprint %s"
 
 
610
649
        """Start the main loop and exit when it's done."""
 
611
 
        self.bus = dbus.SystemBus()
 
612
 
        mandos_dbus_objc = self.bus.get_object(
 
613
 
            self.busname, "/", follow_name_owner_changes=True)
 
614
 
        self.mandos_serv = dbus.Interface(mandos_dbus_objc,
 
618
 
            mandos_clients = (self.mandos_serv
 
619
 
                              .GetAllClientsWithProperties())
 
620
 
        except dbus.exceptions.DBusException:
 
621
 
            mandos_clients = dbus.Dictionary()
 
624
 
         .connect_to_signal("ClientRemoved",
 
625
 
                            self.find_and_remove_client,
 
626
 
                            dbus_interface=server_interface,
 
629
 
         .connect_to_signal("ClientAdded",
 
631
 
                            dbus_interface=server_interface,
 
634
 
         .connect_to_signal("ClientNotFound",
 
635
 
                            self.client_not_found,
 
636
 
                            dbus_interface=server_interface,
 
638
 
        for path, client in mandos_clients.iteritems():
 
639
 
            client_proxy_object = self.bus.get_object(self.busname,
 
641
 
            self.add_client(MandosClientWidget(server_proxy_object
 
644
 
                                               =client_proxy_object,
 
655
651
        self._input_callback_tag = (gobject.io_add_watch
 
656
652
                                    (sys.stdin.fileno(),