scripts/surveillance/collisions_ipv6.py
Daniel STAN 6f45725da9 [collisions_ipv6.py] mise en forme (esthétisme)
parce que je trouve qu'on parse mieux la query comme ça
2013-07-21 11:10:09 +02:00

34 lines
1.1 KiB
Python
Executable file

#!/usr/bin/env python
# -*- coding: utf-8 -*-
""" Pour détecter et signaler les collisions d'adresses IPv6 """
import psycopg2
import sys
sys.path.append('/usr/scripts')
import gestion.ipt as ipt
# Connection à la base sql via pgsql
pgsql = psycopg2.connect(database='filtrage', user='crans')
# Il faudra remplacer la ligne ci-dessous par pgsql.set_session(autocommit = True) sous wheezy
pgsql.set_isolation_level(0)
curseur = pgsql.cursor()
# On regarde s'il y a deux ipv6 identiques avec des mac non identiques
collision_mac_ip_request = """SELECT DISTINCT
a.date as date1, a.mac as mac1, a.ip as ip1,
b.date as date2, b.mac as mac2, b.ip as ip2
FROM mac_ip as a, mac_ip as b
WHERE a.ip = b.ip AND
a.mac != b.mac AND
a.date >= b.date AND
a.date - b.date < interval '3 day'
ORDER BY a.date;"""
curseur.execute(collision_mac_ip_request)
collision_mac_ip = curseur.fetchall()
if collision_mac_ip != []:
print "Collision d'addresses ipv6 : "
for (date1, mac1, ip1, date2, mac2, ip2) in collision_mac_ip:
print "%s %s %s" % (date1, ipt.mac_addr(mac1), ip1)
print "%s %s %s" % (date2, ipt.mac_addr(mac2), ip2)