ayuda con datetime, timedelta...
Publicado por cristian (1 intervención) el 27/04/2018 21:37:35
hola buenas, tengo este codigo que me dice las ip que intentan acceder al sistema de forma fallida en un intervalo de tiempo (fechas), me gustaria hacer lo mismo pero comprobandolo en un tiempo determinado, por ejemplo 5minutos sin tener que introducir toda la fecha.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#!/usr/bin/env python
#-*- coding: utf-8 -*-
from datetime import datetime
# Ejemplo formato de funcion: ana('Nov 24 05:45:22','Nov 26 05:45:22', 12)
def ana(fechainicio, fechafinal, nrepeticiones):
ficherolog = open ('auth.log', 'r')
fechainicio=datetime.strptime(fechainicio,'%b %d %H:%M:%S')
fechafinal=datetime.strptime(fechafinal,'%b %d %H:%M:%S')
ipfalladas=[]
iprepetida=[]
for linea in ficherolog.readlines():
if 'authentication failure' in linea:
li=linea.split()
sfe = li[0]+li[1]+li[2]
fe = datetime.strptime(sfe,'%b%d%H:%M:%S')
for ele in li:
if 'rhost' in ele:
ip = ele[6:]
if fe >= fechainicio and fe <= fechafinal:
ipfalladas.append(ip)
for ip in ipfalladas:
if ipfalladas.count(ip)>=nrepeticiones:
if ip not in iprepetida:
iprepetida.append(ip)
return iprepetida
ficherolog.close()
Valora esta pregunta


0