Splunk MCP for SOC Operations

Splunk MCP for SOC Operations

Enables AI-driven SOC investigations by providing automated Splunk querying, threat intelligence enrichment, and response actions through natural language. Includes tools for IP pivoting, lateral movement detection, and label harvesting.

Category
Visit Server

README

Splunk MCP for SOC Operations

Python 3.10+ License FastMCP

An AI-native MCP (Model Context Protocol) server for SOC operations with Splunk, featuring automated investigation tools, label harvesting, and DeepTempo integration capabilities.

๐ŸŽฏ Overview

This project extends the capabilities of livehybrid/splunk-mcp with SOC-specific enrichment tools and security controls designed for AI-driven security investigations via Claude Desktop and other MCP clients.

Key Features

  • Traditional SOC Workflows - IP pivoting, lateral movement detection, data exfiltration analysis
  • AI-Native Investigation - Cross-platform correlation, attack timeline reconstruction
  • Label Harvesting - Automatic discovery and mapping of Splunk field labels
  • Production Security - Input validation, audit logging, output sanitization
  • Multi-Mode Operation - SSE, STDIO, and API modes for flexible deployment

๐Ÿš€ Quick Start

Prerequisites

  • Python 3.10 or higher
  • Splunk Enterprise or Cloud instance
  • pip (included with Python)

Installation

  1. Clone the repository:

    git clone https://github.com/mando222/splunk-mcp-soc.git
    cd splunk-mcp-soc
    
  2. Install dependencies:

    Using pip (recommended):

    pip install -r requirements.txt
    

    Or with UV:

    uv sync
    

    Or with Poetry:

    poetry install
    
  3. Configure environment variables:

    Create a .env file:

    SPLUNK_HOST=localhost
    SPLUNK_PORT=8089
    SPLUNK_USERNAME=admin
    SPLUNK_PASSWORD=your-password
    SPLUNK_SCHEME=https
    VERIFY_SSL=false
    
  4. Test the connection:

    python test_connection.py
    
  5. Run the MCP server:

    # STDIO mode (for Claude Desktop)
    python splunk_mcp.py stdio
    
    # SSE mode (default)
    python splunk_mcp.py
    
    # API mode
    python splunk_mcp.py api
    

๐Ÿ› ๏ธ Available MCP Tools

Core Operations

  • health_check - Verify Splunk connectivity and available apps
  • ping - Check MCP server status
  • current_user - Get authenticated user information
  • list_users - List all Splunk users and roles

Index & Search Management

  • list_indexes - List all accessible indexes
  • get_index_info - Get detailed information about a specific index
  • indexes_and_sourcetypes - Comprehensive index and sourcetype mapping
  • search_splunk - Execute Splunk search queries with time ranges
  • list_saved_searches - View saved searches

KV Store Operations

  • list_kvstore_collections - List all KV store collections
  • create_kvstore_collection - Create new collections
  • delete_kvstore_collection - Remove collections

SOC Investigation Tools

  • pivot_by_ip - Investigate all activity from a specific IP address
  • find_lateral_movement - Detect lateral movement patterns
  • calculate_data_exfiltration - Analyze and quantify data exfiltration
  • build_attack_timeline - Construct chronological attack timelines
  • correlate_with_deeptempo_finding - Cross-reference with DeepTempo findings

Threat Intelligence Integration

  • enrich_ip_with_threat_intel - Enrich IPs with reputation data from multiple sources
    • Queries AbuseIPDB, AlienVault OTX, and internal Splunk threat lists
    • Provides reputation score, threat types, and confidence levels
  • check_ioc_reputation - Quick reputation check for any IOC (IP, domain, hash, URL)
    • Auto-detects IOC type and provides actionable verdict
  • add_to_threat_list - Add confirmed IOCs to Splunk threat intelligence
    • Supports expiration and automatic cleanup
  • get_mitre_attack_context - Get detailed MITRE ATT&CK technique information
    • Maps findings to tactics, techniques, and procedures
    • Includes detection methods and mitigations

Automated Response Actions

  • block_ip_address - Block malicious IPs at firewall/proxy level
    • Temporary or permanent blocking
    • Auto-unblock capability with configurable duration
  • isolate_host - Quarantine compromised hosts from network
    • Full, partial, or monitoring-only isolation levels
    • Integrates with NAC and endpoint security tools
  • create_incident_ticket - Auto-create tickets in ITSM platforms
    • ServiceNow, Jira, or native Splunk incident tracking
    • Automatic priority and SLA calculation
  • send_alert_notification - Push alerts to communication channels
    • Slack, Microsoft Teams, PagerDuty, email, SMS
    • Severity-based routing

Advanced Analytics & Anomaly Detection

  • detect_anomalies - Statistical anomaly detection on time-series data
    • Z-score based detection with configurable sensitivity
    • Identifies spikes, dips, and unusual patterns
  • identify_rare_events - Find statistically rare occurrences
    • Detects new processes, domains, or behaviors
    • Useful for zero-day and APT detection
  • baseline_normal_behavior - Establish behavioral profiles
    • Learn normal patterns for users, hosts, or services
    • Enables deviation-based threat detection

Label Harvesting

  • harvest_labels - Discover field labels and schemas from Splunk indexes
    • Configurable scope (all indexes, specific indexes, or CIM fields only)
    • Returns field names, types, sample values, and metadata
    • Supports filtering by index and time range
  • get_field_summary - Get detailed information about a specific field
    • Deep dive into field values, distribution, and relationships
    • Useful for understanding individual field usage
  • export_labels_to_deeptempo - Export labels in DeepTempo-compatible format
    • Generic JSON structure that can be adapted to DeepTempo's needs
    • Optional file export for integration workflows

๐Ÿ“Š Demo Scenarios

Scenario 1: IP Investigation

Query: "Show me all activity from IP 10.1.42.42"

Results:
- 65 total events discovered
- 47 unique destinations contacted
- 10+ lateral movement attempts detected
- 1.2 GB data exfiltration identified

Scenario 2: Attack Timeline

Query: "Build attack timeline for 10.1.42.42 and correlate with DeepTempo"

Results:
- 32-day attack timeline reconstructed
- Initial compromise โ†’ lateral movement โ†’ exfiltration
- 12 similar incidents identified
- Complete MITRE ATT&CK mapping

Scenario 3: Threat Hunting

Query: "Hunt for similar C2 beaconing patterns across all hosts"

Results:
- 3 additional compromised hosts found
- Common service account identified (jenkins_service)
- Botnet infrastructure mapped

๐Ÿงช Testing

Generate and ingest test security data:

# Generate test data
python generate_test_data.py

# Ingest into Splunk
python ingest_test_data.py your-password

This creates an mcp_demo index with 115 security events:

  • 50 C2 beaconing events
  • 40 authentication/lateral movement events
  • 20 DNS tunneling events
  • 5 data exfiltration events

Run the test suite:

pytest tests/

๐Ÿณ Docker Support

Run with Docker Compose

  1. SSE Mode (default):
docker compose up -d mcp
  1. API Mode:
docker compose run --rm mcp python splunk_mcp.py api
  1. STDIO Mode:
docker compose run -i --rm mcp python splunk_mcp.py stdio

Run Tests in Docker

./run_tests.sh --docker

๐Ÿ”ง Configuration

Environment Variables

Variable Description Default
SPLUNK_HOST Splunk server hostname localhost
SPLUNK_PORT Splunk management port 8089
SPLUNK_USERNAME Authentication username admin
SPLUNK_PASSWORD Authentication password -
SPLUNK_TOKEN Optional: Use token instead of user/pass -
SPLUNK_SCHEME Connection scheme (http/https) https
VERIFY_SSL Enable SSL certificate verification true
FASTMCP_LOG_LEVEL Logging level INFO
SERVER_MODE Server mode (sse/api/stdio) sse

Claude Desktop Integration

Add to your Claude Desktop config (~/Library/Application Support/Claude/claude_desktop_config.json):

{
  "mcpServers": {
    "splunk-soc": {
      "command": "python",
      "args": [
        "/path/to/splunk-mcp-soc/splunk_mcp.py",
        "stdio"
      ],
      "env": {
        "SPLUNK_HOST": "localhost",
        "SPLUNK_PORT": "8089",
        "SPLUNK_USERNAME": "admin",
        "SPLUNK_PASSWORD": "your-password"
      }
    }
  }
}

๐Ÿ“š Documentation

Document Purpose
SETUP_INSTRUCTIONS.md Detailed setup guide
DEMO_TOOLS_SPEC.md Complete tool specifications
SOC_PLAYBOOKS.md Investigation workflow examples
CONTRIBUTING.md Development guidelines
DEMO_TESTING_GUIDE.md Testing procedures

๐Ÿ—๏ธ Architecture

Claude Desktop / MCP Client
    โ”‚
    โ”œโ”€โ”€ Splunk MCP Server (this project)
    โ”‚   โ”œโ”€โ”€ SOC Investigation Tools
    โ”‚   โ”œโ”€โ”€ Label Harvesting
    โ”‚   โ””โ”€โ”€ Splunk SDK Integration
    โ”‚
    โ””โ”€โ”€ DeepTempo MCP Server (separate)
        โ”œโ”€โ”€ Embedding Similarity Search
        โ”œโ”€โ”€ MITRE ATT&CK Mapping
        โ””โ”€โ”€ LogLM Analysis

๐Ÿ” Security Considerations

Current Implementation

  • โœ… SSL/TLS support with configurable verification
  • โœ… Token-based and credential-based authentication
  • โœ… Environment variable configuration
  • โœ… Input validation on all tools
  • โœ… Audit logging support

Best Practices

  • Never commit .env files
  • Use VERIFY_SSL=true in production
  • Rotate credentials regularly
  • Monitor audit logs
  • Use least-privilege Splunk accounts

๐Ÿค Contributing

Contributions are welcome! Please see CONTRIBUTING.md for guidelines.

๐Ÿ“ Credits

This project is built upon livehybrid/splunk-mcp v0.3.0 and extends it with:

  • SOC-specific investigation tools
  • Label harvesting capabilities
  • DeepTempo integration support
  • Enhanced security controls

Dependencies

๐Ÿ“„ License

Apache License 2.0 - See LICENSE for details.

๐Ÿ› Troubleshooting

Connection Issues

# Test Splunk connectivity
python test_connection.py

# Check logs
tail -f splunk_mcp.log

No Data in Splunk

# Ingest test data
python ingest_test_data.py your-password

# Verify in Splunk UI
index=mcp_demo | stats count by event_type

MCP Server Won't Start

  • Verify .env file exists with correct values
  • Check Python version (3.10+ required)
  • Ensure Splunk is accessible
  • Review error logs

๐Ÿ“ž Support

For issues and questions:

  1. Check documentation
  2. Review error logs
  3. Open an issue on GitHub

Built with FastMCP for AI-native security operations ๐Ÿš€

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured