/mandos/release

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/release

« back to all changes in this revision

Viewing changes to mandos

  • Committer: Teddy Hogeborn
  • Date: 2008-09-04 07:30:58 UTC
  • mfrom: (24.1.87 mandos)
  • Revision ID: teddy@fukt.bsnet.se-20080904073058-h21spydersnh8jml
* README: Improved wording.

Show diffs side-by-side

added added

removed removed

Lines of Context:
55
55
import stat
56
56
import logging
57
57
import logging.handlers
58
 
import pwd
59
58
 
60
59
import dbus
61
60
import gobject
518
517
    Attributes:
519
518
        settings:       Server settings
520
519
        clients:        Set() of Client objects
521
 
        enabled:        Boolean; whether this server is activated yet
522
520
    """
523
521
    address_family = socket.AF_INET6
524
522
    def __init__(self, *args, **kwargs):
528
526
        if "clients" in kwargs:
529
527
            self.clients = kwargs["clients"]
530
528
            del kwargs["clients"]
531
 
        self.enabled = False
532
529
        return super(type(self), self).__init__(*args, **kwargs)
533
530
    def server_bind(self):
534
531
        """This overrides the normal server_bind() function
565
562
#                                            (self.settings
566
563
#                                             ["interface"]))
567
564
            return super(type(self), self).server_bind()
568
 
    def server_activate(self):
569
 
        if self.enabled:
570
 
            return super(type(self), self).server_activate()
571
 
    def enable(self):
572
 
        self.enabled = True
573
565
 
574
566
 
575
567
def string_to_delta(interval):
766
758
    client_config.read(os.path.join(server_settings["configdir"],
767
759
                                    "clients.conf"))
768
760
    
769
 
    clients = Set()
770
 
    tcp_server = IPv6_TCPServer((server_settings["address"],
771
 
                                 server_settings["port"]),
772
 
                                tcp_handler,
773
 
                                settings=server_settings,
774
 
                                clients=clients)
775
 
    uid = 65534
776
 
    gid = 65534
777
 
    try:
778
 
        uid = pwd.getpwnam("mandos").pw_uid
779
 
    except KeyError:
780
 
        try:
781
 
            uid = pwd.getpwnam("nobody").pw_uid
782
 
        except KeyError:
783
 
            pass
784
 
    try:
785
 
        gid = pwd.getpwnam("mandos").pw_gid
786
 
    except KeyError:
787
 
        try:
788
 
            gid = pwd.getpwnam("nogroup").pw_gid
789
 
        except KeyError:
790
 
            pass
791
 
    try:
792
 
        os.setuid(uid)
793
 
        os.setgid(gid)
794
 
    except OSError, error:
795
 
        if error[0] != errno.EPERM:
796
 
            raise error
797
 
 
798
761
    global service
799
762
    service = AvahiService(name = server_settings["servicename"],
800
763
                           type = "_mandos._tcp", );
814
777
                            avahi.DBUS_INTERFACE_SERVER)
815
778
    # End of Avahi example code
816
779
    
 
780
    clients = Set()
817
781
    def remove_from_clients(client):
818
782
        clients.remove(client)
819
783
        if not clients:
841
805
        # Close all input and output, do double fork, etc.
842
806
        daemon()
843
807
    
844
 
    pidfilename = "/var/run/mandos.pid"
 
808
    pidfilename = "/var/run/mandos/mandos.pid"
845
809
    pid = os.getpid()
846
810
    try:
847
811
        pidfile = open(pidfilename, "w")
876
840
    for client in clients:
877
841
        client.start()
878
842
    
879
 
    tcp_server.enable()
880
 
    tcp_server.server_activate()
881
 
    
 
843
    tcp_server = IPv6_TCPServer((server_settings["address"],
 
844
                                 server_settings["port"]),
 
845
                                tcp_handler,
 
846
                                settings=server_settings,
 
847
                                clients=clients)
882
848
    # Find out what port we got
883
849
    service.port = tcp_server.socket.getsockname()[1]
884
850
    logger.info(u"Now listening on address %r, port %d, flowinfo %d,"