-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathapp.py
105 lines (90 loc) · 4.07 KB
/
app.py
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
from flask import Flask, render_template, request
import nmap
import yaml
import openai
# Crear la aplicación Flask
app = Flask(__name__)
# Cargar configuración desde un archivo YAML
def load_config():
try:
with open("config.yaml", "r") as f:
config = yaml.safe_load(f)
print("[INFO] Configuración cargada correctamente.")
return config
except FileNotFoundError:
print("[ERROR] El archivo 'config.yaml' no existe. Asegúrate de crearlo con las configuraciones necesarias.")
except Exception as e:
print(f"[ERROR] Error al cargar el archivo de configuración: {e}")
return {}
# Cargar la configuración
config = load_config()
# Configurar la clave de la API de OpenAI
if 'openai_api_key' in config:
openai.api_key = config['openai_api_key']
print("[INFO] OpenAI API configurado correctamente.")
else:
print("[WARNING] La clave API de OpenAI no está configurada.")
# Ruta principal
@app.route('/')
def home():
print("[INFO] Acceso a la página principal.")
return render_template('index.html')
# Ruta para realizar el escaneo
@app.route('/scan', methods=['POST'])
def scan():
target = request.form.get('target')
if not target:
print("[ERROR] No se ingresó un objetivo para escanear.")
return render_template('index.html', error="Por favor, ingresa un objetivo válido.")
print(f"[INFO] Iniciando escaneo para el objetivo: {target}")
nm = nmap.PortScanner()
try:
results = nm.scan(hosts=target, arguments='-sS -sV -O -A')
print(f"[INFO] Resultados del escaneo: {results}")
open_ports = []
for port, info in results['scan'][target]['tcp'].items():
if info['state'] == 'open':
open_ports.append({
'port': port,
'name': info.get('name', 'N/A'),
'product': info.get('product', 'N/A'),
'version': info.get('version', 'N/A'),
'extrainfo': info.get('extrainfo', 'N/A')
})
print(f"[INFO] Puertos abiertos detectados: {open_ports}")
return render_template('results.html', target=target, open_ports=open_ports)
except KeyError as ke:
print(f"[ERROR] El escaneo no encontró datos para el objetivo. Error: {ke}")
return render_template('index.html', error="No se encontraron datos para el objetivo ingresado.")
except Exception as e:
print(f"[ERROR] Error al escanear: {e}")
return render_template('index.html', error=f"Error al escanear: {str(e)}")
# Ruta para realizar acciones basadas en el análisis
@app.route('/action', methods=['POST'])
def action():
port = request.form.get('port')
product = request.form.get('product')
version = request.form.get('version')
extra_info = request.form.get('extrainfo')
print(f"[INFO] Acción recibida para el puerto {port} con producto {product}, versión {version}, extra: {extra_info}")
advice = "La funcionalidad de generación de información no está disponible en este momento."
if openai.api_key:
try:
solicitud = f"Análisis del puerto {port} con producto {product}, versión {version}, extra: {extra_info}."
response = openai.ChatCompletion.create(
model="gpt-3.5-turbo",
messages=[
{"role": "system", "content": "Eres un experto en análisis de seguridad."},
{"role": "user", "content": solicitud}
],
temperature=0.5,
max_tokens=200
)
advice = response['choices'][0]['message']['content'].strip()
except Exception as e:
print(f"[ERROR] Error al obtener respuesta de OpenAI: {e}")
advice = "Hubo un error al intentar obtener la información de OpenAI."
return render_template('action.html', port=port, advice=advice, product=product, version=version, extra_info=extra_info)
if __name__ == '__main__':
print("[INFO] Aplicación iniciada en modo depuración.")
app.run(debug=True, host='0.0.0.0', port=5200)