Add your description here
Project description
MISP-mcp
What is MCP?
The Model Context Protocol (MCP) is an open protocol designed to standardize how applications provide contextual information to large language models (LLMs). Much like how USB-C serves as a universal interface for connecting hardware devices, MCP acts as a universal connector between AI models and various data sources or tools. This standardization simplifies integration and enhances the adaptability and functionality of AI-powered applications.
Why MCP?
MCP helps you build agents and complex workflows on top of LLMs. LLMs frequently need to integrate with data and tools, and MCP provides:
- A growing list of pre-built integrations that your LLM can directly plug into
- The flexibility to switch between LLM providers and vendors
- Best practices for securing your data within your infrastructure
General architecture
At its core, MCP follows a client-server architecture where a host application can connect to multiple servers:
- MCP Hosts: Programs like Claude Desktop, IDEs, or AI tools that want to access data through MCP
- MCP Clients: Protocol clients that maintain 1:1 connections with servers
- MCP Servers: Lightweight programs that each expose specific capabilities through the standardized Model Context Protocol
- Local Data Sources: Your computer’s files, databases, and services that MCP servers can securely access
- Remote Services: External systems available over the internet (e.g., through APIs) that MCP servers can connect to
Get started
- Clone the repository
git clone https://github.com/Eacus/misp-mcp.git
-
Install Claude Desktop
- Follow the guide https://modelcontextprotocol.io/quickstart/user
- Add the following MCP configuration
{ "mcpServers": { "MISP-mcp":{ "command": "uv", "args": [ "--directory", "<path_to_repo>/server/", "run", "server.py" ] } } }
-
Restart Claude desktop
Basic Usage
Search Event by ID
Prompting with misp-mcp
Can you give to me the MISP event with id 119?
GUI
PyMISP
misp_url = 'https://127.0.0.1:8443'
misp_key = '<misp_key>'
# Should PyMISP verify the MISP certificate
misp_verifycert = False
r = misp.search(eventid=[119], metadata=True, pythonify=True)
Create an event
Prompting with misp-mcp
Create a new MISP event with the following parameters:
- Info:
This is my new MISP event- Distribution:
0(Your organization only)- Threat Level ID:
2(Medium)- Analysis Level:
1(Ongoing)
GUI
PyMISP
from pymisp import MISPEvent
event = MISPEvent()
event.info = 'This is my new MISP event' # Required
event.distribution = 0 # Optional, defaults to MISP.default_event_distribution in MISP config
event.threat_level_id = 2 # Optional, defaults to MISP.default_event_threat_level in MISP config
event.analysis = 1 # Optional, defaults to 0 (initial analysis)
print(event.to_json())
Administrative task
Create an user
Prompting with misp-mcp
Add a new user to the MISP instance using the following required fields:
email@email.com: the email address associated with the accounttest_id: the ID of the organization the user belongs torole_id: the ID of the role assigned to the user
GUI
PyMisp
from pymisp import ExpandedPyMISP, MISPUser
from keys import misp_url, misp_key, misp_verifycert
import argparse
misp = ExpandedPyMISP(misp_url, misp_key, misp_verifycert, 'json')
user = MISPUser()
user.email = <email>
user.org_id = <org_id>
user.role_id = <role_id>
misp.add_user(user, pythonify=True)
Add AI Capabilities!
Summarise all information about the MISP events that happened yesterday?
Generate a report written in Markdown based on the MISP event with id 114
# MISP Event Report: Configuration and Security Posture Issues
## Event Details
- **Event ID:** 114
- **UUID:** 9d8c6821-0db5-4745-bb58-aac4f04eab78
- **Date:** 2025-03-25
- **Status:** Not Published
- **Threat Level:** 4
- **Distribution:** 1 (Organization)
- **Analysis Status:** 0 (Initial)
## Organization Information
- **Organization:** ORG_Main
- **Organization UUID:** 3094f85b-a22f-475b-a68f-ae77c233bb72
- **Event Creator:** user88@org-admin.main.test
## Description
This event focuses on "Configuration and Security Posture Issues." It appears to be in an initial stage of analysis and has not yet been published within the MISP instance.
## Attributes
No attributes have been added to this event yet.
## Objects
No objects have been associated with this event.
## Related Events
No related events have been linked to this event.
## Galaxies
No galaxies have been associated with this event.
## Summary
This MISP event (ID: 114) is currently in development and focuses on configuration and security posture issues. The event has been created but does not yet contain any attributes, objects, or relationships with other events. The event is set to be shared only within the organization (ORG_Main).
## Recommendations
1. Add relevant attributes to provide context about the specific configuration and security posture issues being addressed
2. Consider adding objects to structure the information more effectively
3. Link to related events if applicable
4. Determine appropriate galaxies to categorize the threat information
5. Review the threat level assignment to ensure it accurately reflects the severity
6. Consider publishing the event when it contains sufficient information
------
*Report generated on April 9, 2025*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file iflow_mcp_eacus_misperer-0.1.0.tar.gz.
File metadata
- Download URL: iflow_mcp_eacus_misperer-0.1.0.tar.gz
- Upload date:
- Size: 7.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d7c0edf13fdcf1dfd2ce4b31f39061e7114f83ee2b66603023d84e0ae325cb25
|
|
| MD5 |
5a473a9faccca4d7ff7b8eb4f3da419b
|
|
| BLAKE2b-256 |
d89924b6fb66c28ae5f1b02ba0bfa0f8d18f1e0518d5585a87da89b66dbe7b02
|
File details
Details for the file iflow_mcp_eacus_misperer-0.1.0-py3-none-any.whl.
File metadata
- Download URL: iflow_mcp_eacus_misperer-0.1.0-py3-none-any.whl
- Upload date:
- Size: 7.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7b6797620552ad8c3ba4c7c091c3419c23a01440485c4df115c3b2ca0facad3a
|
|
| MD5 |
b1ec02edcfb34a6042626db6704320f8
|
|
| BLAKE2b-256 |
24ab10775e65e6ea98491479d265bb6d791156a65b1749c585b2625473ae72d4
|