cco-mcp
Real-time audit and approval system for Claude Code tool calls, enabling monitoring and control of AI agent actions with a web dashboard.
README
CCO-MCP (Claude Code Oversight)
Real-time audit and approval system for Claude Code tool calls. Get instant visibility and control over AI agent actions with a sleek web dashboard.

Overview
CCO-MCP provides a security layer between Claude Code and your system, enabling you to monitor and control AI tool calls in real-time. It acts as a firewall for AI actions, allowing you to review sensitive operations before they execute while auto-approving safe ones based on configurable rules. This let's you scale to many more non-interactive Claude Code instances running in the background without incurring "tab-switching fatigue".
Get Started
Clone and run with Docker Compose
git clone https://github.com/onegrep/cco-mcp.git
cd cco-mcp
docker-compose up
Configure Claude Code
Install CCO-MCP at the user scope:
claude mcp add -s user -t http cco-mcp http://localhost:8660/mcp
This will add the following to your Claude Code config:
{
"mcpServers": {
"cco-mcp": {
"type": "http",
"url": "http://localhost:8660/mcp"
}
}
}
For self-hosted deployments, replace http://localhost:8660/mcp with your deployment URL.
Visit http://localhost:8660 to access the dashboard.
Enable Approval Prompts
To use CCO-MCP for approval prompts, run Claude Code in non-interactive mode with the appropriate Permission Prompt Tool flag:
claude code -p "your prompt here" --permission-prompt-tool mcp__cco-mcp__approval_prompt
This enables Claude to request approval through CCO-MCP before executing sensitive operations without using the "dangerously skip permissions" option.
Main Features
š”ļø Smart Approval Rules
Create rules to auto-approve safe operations (like file reads) while requiring manual approval for sensitive ones (like running bash commands).
š Real-Time Dashboard
Monitor all tool calls as they happen with live updates via Server-Sent Events.
š Detailed Audit Logs
Every tool call is logged with full context including agent identity, parameters, and approval status.
Configuration Options
All configuration can be managed through the web interface at http://localhost:8660/config.
Default Action and Timeouts
- Default Action: Choose whether unmatched requests are automatically approved or require manual review
- Auto-Deny Timeout: Set how long to wait for manual approval before automatically denying (default: 5 minutes)
- Entry TTL: Configure how long audit log entries are retained (default: 24 hours)
Approval Rules
Rules use a priority system (lower numbers = higher priority) to determine actions:
- Tool Matching: Match specific tools (built-in like Read/Write or MCP server tools)
- Agent Matching: Create rules for specific agent identities
- Pattern Matching: Use wildcards for flexible rule creation
- Actions: Set rules to auto-approve or auto-deny matching requests
Environment Variables
PORT- Server port (default: 8660)CCO_CONFIG_PATH- Config file location (default: ~/.cco-mcp/config.json)
Development
Project Structure
cco-mcp/
āāā src/ # TypeScript backend
ā āāā audit/ # Core audit service
ā āāā routes/ # REST API endpoints
ā āāā server.ts # MCP server
āāā ui/ # React frontend
ā āāā src/
ā āāā components/
ā āāā pages/
āāā dist/ # Build output
Design Principles
- Simplicity first - Enabling core use-case of approving background agents
- Real-time by default - SSE for instant updates
- Type safety - Full TypeScript coverage
- User-friendly - Intuitive UI with helpful defaults
Local Development
# Install required tools
just brew
# Setup project dependencies
just setup
# Run both backend and UI
just dev-all
# Run tests
just test
# Format code
just format
# Build everything
just build-all
Contributing
We welcome contributions! Please see our Contributing Guide for details.
License
MIT License - Copyright 2025 OneGrep, Inc.
Acknowledgments
Built for use with Claude Code and the Model Context Protocol by Anthropic.
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.