agent-guard-mcp

agent-guard-mcp

agent-guard-mcp

Category
Visit Server

README

agent-guard-mcp

CI License: MIT Go Reference

MCP Guard Server — Budget control, approval workflows, and audit logging for AI agents.

Works with Claude Code, Cursor, ChatGPT, and any AI agent that speaks the MCP protocol.

Features

  • Budget Control — Daily credits hard limit prevents agent overspending
  • High-Risk Approval — Operations exceeding amount threshold or matching sensitive resource keywords trigger human approval
  • Approval Workflow — Agent requests → token generated → human approves via Dashboard or Telegram
  • Audit Log — All spend, approval, and rejection actions recorded with cursor-based pagination
  • Web Dashboard — Gin + HTMX + Tailwind real-time dashboard
  • Telegram Notifications — Instant approval links for high-risk operations
  • Multi-Transport — stdio / SSE / StreamableHTTP with automatic detection

MCP Tools

Tool Description
check_budget Query today's budget status
spend Execute a spend (auto-detects high-risk)
request_approval Explicitly request human approval
approve Approve a pending token
reject Reject a pending token
check_approval Poll approval status
get_audit_log Query audit log with filtering and pagination
get_pending_approvals List all pending approval requests

Quick Start

Requirements

  • Go 1.24+
  • No CGO required (pure Go SQLite driver)

Build from Source

git clone https://github.com/dygogogo/agent-guard-mcp.git
cd agent-guard-mcp
go build -o mcp-guard main.go

Download Pre-built Binary

Download the latest release for your platform:

Platform amd64 arm64
macOS darwin-amd64.zip darwin-arm64.zip
Linux linux-amd64.zip linux-arm64.zip
Windows windows-amd64.zip windows-arm64.zip

Or visit the latest release page.

Configuration

Configure via environment variables or .env file:

Variable Description Default
MCP_TRANSPORT Transport: stdio / sse / http Auto-detect (TTY → http)
BUDGET_LIMIT Daily budget cap (credits) 10.0
HIGH_RISK_THRESHOLD High-risk amount threshold 2.0
HIGH_RISK_RESOURCES High-risk resource keywords (comma-separated) delete,send
DB_PATH SQLite database path ./mcp-guard.db
DASHBOARD_PORT Dashboard HTTP port 8080
APPROVAL_BASE_URL Base URL for approval links http://localhost:8080
LOG_LEVEL Log level: debug/info/warn/error info
PAYER_ID Payer identity hostname
TELEGRAM_BOT_TOKEN Telegram Bot Token (optional) -
TELEGRAM_CHAT_ID Telegram Chat ID (optional) -

Running

# HTTP mode (auto-detected, with Dashboard)
./mcp-guard
# Dashboard: http://localhost:8080/dashboard
# MCP endpoint: http://localhost:8080/mcp

# stdio mode (for MCP clients)
MCP_TRANSPORT=stdio ./mcp-guard

# SSE mode
MCP_TRANSPORT=sse ./mcp-guard
# SSE endpoint: http://localhost:8080/sse

Claude Code Integration

Add to Claude Code's MCP configuration:

{
  "mcpServers": {
    "agent-guard-mcp": {
      "command": "mcp-guard",
      "env": {
        "MCP_TRANSPORT": "stdio",
        "BUDGET_LIMIT": "10"
      }
    }
  }
}

Architecture

┌─────────────┐     MCP Protocol     ┌────────────────┐
│  AI Agent   │ ◄──────────────────► │  MCP Guard      │
│ (Claude,    │   stdio / HTTP       │  Server         │
│  Cursor...) │                      │                  │
└─────────────┘                      │  ┌────────────┐ │
                                     │  │  BudgetStore │ │
┌─────────────┐    HTTP              │  │  (SQLite)    │ │
│  Dashboard  │ ◄──────────────────► │  └────────────┘ │
│  (Gin+HTMX) │                      └────────────────┘
└─────────────┘

┌─────────────┐    Webhook
│  Telegram   │ ◄────── Approval notifications
└─────────────┘

Core Files

File Description
main.go Entry point, transport selection, graceful shutdown
server.go MCP Server with 8 registered tools
store.go BudgetStore interface + SQLite implementation
approval.go High-risk detection, approval workflow, Telegram
config.go Environment config, auto transport detection
logger.go zap logging (stdio mode: file only)
dashboard.go Gin Web Dashboard

Approval Workflow

1. Agent calls spend(amount=5.0, resource="/api/delete")
2. MCP Guard detects high-risk (amount > threshold OR resource keyword matched)
3. Returns {status: "pending_approval", token: "xxx"}
4. Agent polls check_approval(token) for status
5. Human approves/rejects via Dashboard or Telegram
6. Agent receives final result (approved/rejected/budget_exceeded)

Testing

# All tests with race detection
go test -race -count=1 ./...

# Integration tests only
go test -race -run TestIntegration -v ./...

# Coverage
go test -race -cover ./...

Tech Stack

  • Go 1.24 — Language
  • mcp-go — MCP protocol Go SDK
  • Gin — Web framework (Dashboard)
  • modernc.org/sqlite — Pure Go SQLite (no CGO)
  • zap — Structured logging
  • HTMX + Tailwind CSS — Dashboard frontend

License

MIT


中文

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
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
Qdrant Server

Qdrant Server

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

Official
Featured