Servidor MCP de enriquecimiento
Un servidor de Protocolo de Contexto de Modelo (MCP) para realizar enriquecimiento dado un observable proporcionado. La combinación de los servicios configurados y los observables proporcionados determinará qué servicios de enriquecimiento utilizar.
Esta herramienta proporciona una implementación simple para realizar enriquecimiento de terceros utilizando servicios comunes (por ejemplo, VirusTotal, Hybrid Analysis, etc.).
Este proyecto no se ha utilizado en ningún entorno de producción.
Características
Esta implementación del servidor MCP enrichment-mcp
expone las siguientes herramientas .
- observable-lookup: un punto final genérico que examina y dirige el observable dado a la herramienta correcta.
- lookup-ipaddress: realiza el enriquecimiento en una dirección IPv4 determinada.
- lookup-domain: realiza el enriquecimiento en un nombre de dominio determinado.
- lookup-url: realiza el enriquecimiento en una URL determinada (y en algunos casos, en un nombre de dominio).
- lookup-email: realiza el enriquecimiento de una dirección de correo electrónico determinada.
Si encuentra un problema con el tipo observable determinado, cree un problema o puedo actualizar los patrones de expresiones regulares implementados actualmente.
Servicios soportados
Actualmente se admiten los siguientes servicios y tipos observables:
Si tiene alguna sugerencia o cree que se debería implementar otro servicio, ¡cree un problema o una solicitud de extracción!
Nombre | Se requiere clave API | Soporta IP | Admite dominio | Admite URL | Admite correo electrónico |
---|---|---|---|---|---|
VirusTotal | Sí | Sí | Sí | Sí | No |
Análisis híbrido | Sí | Sí | Sí | Sí | No |
Bóveda alienígena | Sí | Sí | Sí | Sí | No |
Shodan | Sí | Sí | Sí | Sí | No |
Urlscan.io | Sí | Sí | Sí | Sí | No |
AbuseIPDB | Sí | Sí | No | No | No |
He sido derrotado | Sí | No | No | No | Sí |
Requisitos
Este servicio MCP implementa un archivo de configuración personalizado que se utiliza para determinar qué servicios de enriquecimiento de terceros se deben utilizar para búsquedas observables.
Dado que esto es puramente para desarrollo/prueba en este momento, la forma más fácil de ejecutarlo en un sistema/Mac local es:
Esto requiere que utilice la plantilla proporcionada .env.example y cree un nuevo archivo .env
con sus secretos.
config.yaml
Este proyecto proporciona un archivo de configuración personalizado y creo que es bastante fácil de entender.
Primero, copie la configuración config.yaml.example proporcionada y elimine la extensión .example
antes de usar este servicio.
Dentro de este archivo de configuración hay dos secciones principales de datos; servidor y enriquecimientos .
De forma predeterminada, todos los servicios compatibles se asignan a los tipos de acciones de enriquecimiento implementados actualmente. Actualmente, el único tipo de acción de enriquecimiento real son lookups
pero es posible que se implementen otras en el futuro.
Debajo de las lookups
tenemos los diferentes tipos de enriquecimiento soportados.
Dicho esto, cada servicio individual puede tener una clave llamada apikey
y el valor de la clave API de ese servicio, pero considere no hacerlo.
Puede establecer este valor de clave directamente en config.yaml.example pero la forma preferida es usar un .env
.
NOTA: Se recomienda encarecidamente configurar los secretos como variables de entorno al implementar este servicio. ¡Deja de almacenar secretos, idiota!
Para que este servicio detecte estas variables, deben tener un formato específico. A continuación, se muestra la lista de variables admitidas actualmente:
- ENRIQUECIMIENTO_MCP_VIRUSTOTAL_CLAVE
- ENRIQUECIMIENTO_MCP_ANÁLISIS_HÍBRIDO_CLAVE
- ENRIQUECIMIENTO_MCP_ALIENVAULT_CLAVE
- ENRIQUECIMIENTO_MCP_SHODAN_CLAVE
- ENRIQUECIMIENTO_MCP_URLSCAN_CLAVE
- ENRIQUECIMIENTO_MCP_ABUSEIPDB_CLAVE
- ENRIQUECIMIENTO_MCP_HIBP_CLAVE
Configuración del servidor
Aquí hay configuraciones mínimas, ya que esto es principalmente para pruebas y entornos aislados, pero generalmente no es necesario cambiar ni alterar estas configuraciones para que este servicio funcione.
Configuración de enriquecimientos
Cada enriquecimiento en nuestro archivo de configuración reside bajo la clave enrichments
. Además, he desglosado los diferentes tipos de enriquecimiento que se pueden realizar. Esto significa que, en la implementación actual, solo tenemos un tipo de acción llamado lookups
pero en el futuro esto se puede ampliar para funciones como scans
, queries
, etc.
Debajo de estas acciones de alto nivel, enumeramos el tipo de observable, seguido de una lista de servicios que lo admiten. Los tipos de observables actualmente admitidos son:
- direcciónip - direcciones ipv4
- dominio - Un dominio o netloc
- url: una URL completa con esquema, etc.
- correo electrónico - Una dirección de correo electrónico estándar
También admitimos estos tipos, pero actualmente no están implementados:
- md5 - Un hash MD5 de archivo
- sha1 - Un hash SHA1 de archivo
- sha256 - Un hash SHA256 de archivo
Cada servicio debe tener un name
y una template
. Se puede proporcionar el campo apikey
, pero se recomienda usar variables de entorno.
Plantillas de indicaciones
Cada servicio y tipo de observable puede tener su propia plantilla. Estas se encuentran en el directorio de plantillas y se espera que todas las plantillas se encuentren aquí.
Cada servicio definido tiene una plantilla de solicitud que utiliza plantillas de jinja2. Puede modificarlas según sea necesario, pero el formato del nombre de archivo debe ser el mismo.
Estos archivos tienen el siguiente patrón de nombre de archivo.
Además, asegúrese de que el objeto de respuesta tenga los campos correctos en la plantilla o recibirá un error.
A continuación se muestra un ejemplo de salida para un mensaje de Enrich this IP 91.195.240.94
con algunos errores incluidos:
Uso
Para utilizar un servidor prediseñado, instrucciones desde aquí: https://modelcontextprotocol.io/quickstart/user
- Descargar Claude para escritorio
- Instalar uv
- Descargue este repositorio y agréguelo a la configuración de Claude para escritorio
- Claude para escritorio > Configuración > Desarrollador > Editar configuración
Esto creará un archivo de configuración en:
Abra el archivo de configuración en cualquier editor de texto. Reemplace el contenido del archivo con esto:
- Reiniciar Claude para escritorio
Ahora debería ver dos íconos en la barra de chat: un martillo que muestra las herramientas disponibles y un ícono de conexión que muestra el mensaje definido y la entrada requerida.
Diseño
Mientras construía este servidor, aprendí a usar Astral UV y MCP. Definitivamente, lo sobredimensioné, pero fue divertido. Además, tenía previstos usos futuros para parte de este código, así que intenté diseñarlo con eso en mente (más adelante).
Además, pasé específicamente a las plantillas Jinja2 porque esto permite una mejor gestión de las indicaciones/resultados devueltos y, nuevamente, también de los casos de uso futuros.
Envíanos tus comentarios, mejoras o solicitudes de funciones; nos alegrará escucharlos todos.
Contribuyendo
¡Agradecemos sus contribuciones! No dude en enviar solicitudes de incorporación de cambios.
Descargo de responsabilidad
Esta herramienta es únicamente para fines educativos y de prueba autorizada.
This server cannot be installed
Un servidor de protocolo de contexto de modelo que permite a los usuarios realizar búsquedas de enriquecimiento de terceros para observables de seguridad (direcciones IP, dominios, URL, correos electrónicos) a través de servicios como VirusTotal, Shodan y otros.
Related MCP Servers
- -securityFlicense-qualityA standalone Model Context Protocol server for Snyk security scanning functionality.Last updated -21JavaScript
- -securityFlicense-qualityA Model Context Protocol server that provides access to Shodan and VirusTotal APIs for cybersecurity analysis, enabling analysts to perform network intelligence operations including host lookups, vulnerability analysis, and threat intelligence gathering.Last updated -1TypeScript
- -securityAlicense-qualityA Model Context Protocol server designed for testing backend APIs for security vulnerabilities like authentication bypass, injection attacks, and data leakage.Last updated -1TypeScriptMIT License
- AsecurityFlicenseAqualityA Model Context Protocol server implementation that provides endpoints for wallet-based authentication, cluster management, and name registration services.Last updated -TypeScript