Beispiel #1
0
    def ip4(self, username, password, ip):

        log = Log(conf.files.loginlog)
        indata = self.check_input(username, password, ip)
        dhcp = Dhcp()
        auth = Auth(indata['username'], indata['password'])
        firewall = Firewall()
        #        dhcp = DHCP(None)   ## Uses default leasefile given in conf.py
        #        lease = 1 #dhcp.get_ipv4_lease(indata['ip_addr']);
        mac = dhcp.find_mac(indata['ip_addr'])
        data = Data()

        if mac == False:
            # ip/mac pair does not exist in leasefile
            print "FEIL Mac/IP combo"
            exit(conf.exit_status.ip_mac_mismatch_error)
        elif auth.login() != True:
            print "Login failed."
            log.info("LOGIN FAILED: " + indata['username'] + " at " +
                     indata['ip_addr'])
            exit(conf.exit_status.login_error)
        else:
            firewall.accept_ip4(indata['ip_addr'])

## DATABASE GOES HERE
        log.info("LOGIN OK: " + indata['username'] + " at " +
                 indata['ip_addr'])
        data.DbAddRow(indata['username'], mac, indata['ip_addr'], "IPv6")
        #	    print lease[1]+" "+lease[0]
        ### WRITE SOMETHING TO A LOGFILE? (this goes to stdout)
        print "Login successful, {0} at ip {1}".format(indata['username'],
                                                       indata['ip_addr'])

        return
Beispiel #2
0
    def ip4(self,ip):
        """
        Drops IPv4 address from iptables and database
        """
        checkip = re.compile(conf.filter.ipv4_exact)
        if checkip.match(ip) == None:
            print "Invalid IP:\n"+ip
            exit(conf.exit_status.input_error)
        
        firewall = Firewall()
        data = Data()

        self.log.info("DROPPED: "+ip)
        firewall.drop_ip4(ip)
        data.DbActiveIp4(ip,0)