935008ec3f
Añade el capability group `recon` (dominio cybersecurity + pipelines, Python),
con la política de archivado OSINT y página madre docs/capabilities/recon.md.
Lookups y sondeo (wrappers de CLI):
- whois_lookup, rdap_lookup, dns_records, ping_host, traceroute_host, nmap_scan
- save_scan_to_osint (sink común) + recon_osint (pipeline one-shot scan+archivado)
Escaneo de puertos/servicios nativo (stdlib, sin nmap ni sudo):
- scan_tcp_ports: connect-scan TCP concurrente (open/closed/filtered)
- grab_service_banner: banner grab + identificación de servicio/versión real
- identify_port_service: puro, puerto -> servicio IANA esperado (~120 puertos)
- scan_port_services: pipeline one-shot (scan -> identify + banner por puerto abierto)
Fingerprint de tecnología web (estilo Wappalyzer), patrón pura/impura:
- fetch_http_fingerprint: GET stdlib, recoge headers/html/cookies (solo nombres)
- detect_web_tech: puro, matchea ~50 firmas regex -> tecnologías por categoría
- fingerprint_web_stack: pipeline one-shot url -> tecnologías
Todas devuelven dict {status} sin lanzar. Tests: 43 verdes, sin red externa.
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
3.0 KiB
3.0 KiB
name, kind, lang, domain, version, purity, signature, description, tags, params, output, uses_functions, uses_types, returns, returns_optional, error_type, imports, tested, tests, test_file_path, file_path
| name | kind | lang | domain | version | purity | signature | description | tags | params | output | uses_functions | uses_types | returns | returns_optional | error_type | imports | tested | tests | test_file_path | file_path | ||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| ping_host | function | py | cybersecurity | 1.0.0 | impure | def ping_host(host: str, count: int = 4, timeout_s: int = 30) -> dict | Sondeo de disponibilidad ICMP de un host ejecutando `ping -c <count> -w <timeout_s> <host>` (Linux) por subprocess y parseando el resumen: paquetes enviados/recibidos, % de perdida y rtt min/avg/max. Devuelve dict de estado sin lanzar; host inalcanzable o ICMP filtrado es status ok con loss_pct=100 y rtt None. `raw` siempre presente con el stdout. |
|
|
dict de estado. En exito {status:'ok', host, packets_sent:int|None, packets_recv:int|None, loss_pct:float, rtt_avg_ms:float|None, rtt_min_ms:float|None, rtt_max_ms:float|None, raw:str}; un host inalcanzable da loss_pct=100 y rtts None pero sigue status ok. En fallo {status:'error', error:str, host, raw:str}. | false | error_py_core | false | python/functions/cybersecurity/ping_host.py |
Ejemplo
import sys, os
sys.path.insert(0, os.path.join("python", "functions"))
from cybersecurity import ping_host
res = ping_host("1.1.1.1", count=4, timeout_s=10)
print(res["status"]) # "ok"
print(res["loss_pct"]) # 0.0
print(res["rtt_avg_ms"]) # 12.3
print(res["raw"]) # stdout crudo de ping para el vault
Cuando usarla
Usala para comprobar rapidamente si un host responde a ICMP y medir su latencia
antes de un escaneo mas pesado (traceroute, port scan). Util para verificar
conectividad y caracterizar la red de un objetivo en una fase de recon. Guarda
raw como evidencia en la nota OSINT.
Gotchas
- Funcion impura: envia trafico ICMP a la red. No determinista (latencia varia).
- Linux-only: usa la sintaxis
ping -c N -w Sde iputils. En BSD/macOS los flags difieren (-ten vez de-w) y el parseo podria fallar. - ICMP suele estar filtrado por firewalls: un host que SI existe puede no
responder a ping. Eso es
status:"ok"conloss_pct=100y rtt None, NO un error. No concluyas "host caido" solo por perdida total. - Requiere el binario
pingen PATH (paqueteiputils-ping). Si falta, devuelve{"status":"error",...}(no lanza). En algunos sistemas ping necesita capacidadcap_net_rawo setuid; si no la tiene puede fallar. - Nunca lanza: errores en
status. El timeout duro del subprocess estimeout_s + 5s; si se alcanza, esstatus:"error". packets_sent/packets_recvpueden ser None si la version de ping emite un resumen con formato inesperado; en ese caso revisaraw.