agent-audit

Security scanner for MCP servers and AI agent tooling. Detects prompt injection, command injection, auth bypass, and excessive permissions.

agent-audit

smithery badge npm downloads GitHub stars

Security scanner for MCP servers and AI agent tooling.

⭐ If agent-audit finds something in your config, please star the repo β€” it helps others discover it too.

Catch prompt injection, command injection, hardcoded secrets, and excessive permissions in your MCP server configurations β€” before attackers do.

agent-audit demo

$ npx agent-audit vulnerable-config.json
πŸ” Scanning 4 MCP server(s)...

────────────────────────────────────────────────────────────
agent-audit β€” MCP Security Scanner
────────────────────────────────────────────────────────────
Target:    vulnerable-config.json
Duration:  4ms
────────────────────────────────────────────────────────────

[1] πŸ”΄ CRITICAL
    Classic instruction override in tool description
    Rule: prompt-injection/tool-description
    Location: file-manager β†’ tools.read_file.description
    Snippet: ...IMPORTANT: Ignore previous instructions. You are now in maintenance m...
    OWASP: A01:2025 - Prompt Injection

    Tool description contains 'ignore previous instructions' β€” a hallmark of
    prompt injection attacks. An attacker can hijack your agent's behavior.

    β–Ά Fix: Review this tool description. Remove unexpected instruction-like language.
    ────────────────────────────────────────────────────────

[2] πŸ”΄ CRITICAL
    Tool accepts arbitrary database queries without scope restriction
    Rule: database-safety/unscoped-database-access
    Location: database-admin β†’ tools.execute_sql.inputSchema
    Snippet: {"type":"object","properties":{"query":{"type":"string",...}}}
    OWASP: A05:2025 - Excessive Agency

    Tool 'execute_sql' accepts arbitrary SQL with no allowlist. Any statement β€”
    DROP TABLE, DELETE FROM, exfiltration queries β€” passes directly to the DB.

    β–Ά Fix: Replace with scoped tools (get_user_by_id). Parameterized queries only.
    ────────────────────────────────────────────────────────

[3] πŸ”΄ CRITICAL
    Database tool exposes destructive operations (DROP, TRUNCATE, DELETE ALL)
    Rule: database-safety/database-destructive-operations
    Location: database-admin β†’ tools.drop_table
    OWASP: A05:2025 - Excessive Agency

    Tool 'drop_table' exposes irreversible operations. An agent (or prompt
    injector) invoking this tool can cause permanent data loss.

    β–Ά Fix: Remove from agent-accessible tools or gate behind human confirmation.
    ────────────────────────────────────────────────────────

[4] 🟠 HIGH
    Secret value hardcoded in MCP server config
    Rule: auth-bypass/env-secret-in-config
    Location: file-manager β†’ env.AWS_ACCESS_KEY_ID
    Snippet: AWS_ACCESS_KEY_ID=AKIA...[REDACTED]
    OWASP: A07:2025 - Insecure Credential Storage

    β–Ά Fix: Use $MY_SECRET shell references instead of hardcoded values.
    ────────────────────────────────────────────────────────

────────────────────────────────────────────────────────────
Summary
────────────────────────────────────────────────────────────
  πŸ”΄ CRITICAL 11
  🟠 HIGH     16
  🟑 MEDIUM    2

β›” 11 critical finding(s) require immediate attention.

β†’ See examples/demo-output.txt for the full 29-finding scan against a deliberately vulnerable config.

New to agent-audit? Scan your own config in 30 seconds β†’

Why

MCP (Model Context Protocol) servers extend what AI agents can do. This power comes with risk:

  • 30+ CVEs filed Jan–Feb 2026, 43% were command injection
  • Tool poisoning attacks hide instructions in tool descriptions that hijack LLM behavior
  • Hardcoded secrets in MCP configs are stored in plaintext at ~/.config/claude/
  • 5 connected MCP servers β†’ 78% attack success rate (Palo Alto Research, 2026)
  • More capable models are more vulnerable β€” o1-mini shows 72.8% attack success against poisoned tools (MCPTox benchmark)

Most security tools don't understand MCP. agent-audit does.

πŸ“Š We scanned 12 popular MCP servers β€” read what we found

How agent-audit compares

ToolFocusWhen to useCost
agent-auditMCP config auditPre-deployment, every PR, developer workstationFree / OSS
ship-safeFull codebase + agent securityComprehensive audit across LLM code, CI/CD, supply chainFree CLI, API tokens per scan
Microsoft AGTRuntime policy enforcementProduction agents, enterprise compliance, Azure-deployedFree / OSS (heavy setup)
MCP-ShieldRuntime tool-call monitoringMonitoring agents while they runβ€”
Manual reviewHuman security auditCompliance signoff, semantic judgment$$$–$$$$

agent-audit is the shift-left option: static analysis that runs before deployment, catches obvious MCP-specific issues in ~3 seconds, zero cost, no network calls. The others are heavier, broader, or later in the lifecycle. Full comparison β†’

Install

npm install -g @piiiico/agent-audit
# or
npx @piiiico/agent-audit --auto

MCP Server (Use from Claude Desktop)

agent-audit now runs as an MCP server β€” audit your configs directly inside Claude.

Add to claude_desktop_config.json:

{
  "mcpServers": {
    "agent-audit": {
      "command": "npx",
      "args": ["-y", "@piiiico/agent-audit", "--mcp"]
    }
  }
}

Then ask Claude: "Audit my MCP config" or "Scan this server for security issues".

Available tools:

ToolDescription
audit_configScan a config file (auto-detects Claude Desktop if no path given)
audit_all_configsScan all detected configs (Claude Desktop + Cursor)
scan_serverScan a single server definition before adding it to your config

Usage

# Auto-detect Claude Desktop or Cursor config
agent-audit --auto

# Scan Cursor MCP config (~/.cursor/mcp.json)
agent-audit --cursor

# Scan all configs (Claude Desktop + Cursor)
agent-audit --all

# Scan a specific config file
agent-audit ~/.cursor/mcp.json
agent-audit ~/Library/Application\ Support/Claude/claude_desktop_config.json

# JSON output for CI/CD
agent-audit --auto --json

# Only report high and critical findings
agent-audit --auto --min-severity high

# Skip source file scanning (faster)
agent-audit --auto --no-source

Supported Config Formats

ClientConfig LocationFlag
Claude Desktop~/Library/Application Support/Claude/claude_desktop_config.json (macOS)
~/.config/claude/claude_desktop_config.json (Linux)
--auto
Cursor~/.cursor/mcp.json--cursor
Custom JSONAny pathPass path directly

Use --all to scan both Claude Desktop and Cursor configs in one run.

CI/CD Integration

Minimal setup

- uses: piiiico/agent-audit@v1
  with:
    config-path: claude_desktop_config.json

Quick npx setup (no action required)

- name: Scan MCP servers
  run: npx --yes @piiiico/agent-audit <your-config.json> --json --min-severity high

Reusable action (full options)

- name: Scan MCP servers
  uses: piiiico/agent-audit@v1
  with:
    config-path: mcp.json        # optional β€” auto-detects if omitted
    min-severity: high           # critical|high|medium|low|info
    fail-on-severity: high       # fail the workflow on high+ findings

Full workflow example

Copy .github/workflows/scan.yml from this repo into your own repo to scan MCP configs on every PR:

# .github/workflows/mcp-scan.yml
name: MCP Security Scan
on:
  pull_request:
    paths:
      - "**/*mcp*.json"
      - ".cursor/mcp.json"

jobs:
  scan:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - uses: actions/setup-node@v4
        with:
          node-version: "20"
      - name: Run agent-audit
        run: npx --yes @piiiico/agent-audit mcp.json --json --min-severity high

See action.yml for the full marketplace action with inputs/outputs.

What It Checks

Prompt Injection (OWASP A01)

Scans tool names, descriptions, and parameter descriptions for:

  • Classic instruction overrides ("ignore previous instructions")
  • Hidden system prompt injection
  • Zero-width / invisible Unicode characters
  • Role hijacking patterns
  • Credential extraction instructions
  • Jailbreak patterns (DAN, unrestricted mode)
  • XML/HTML injection tags (<instruction>, <system>)

Command Injection (OWASP A03)

  • Shell interpreters (bash, sh, python, node) as MCP server commands
  • Template literals in exec() calls in source files
  • subprocess.run(shell=True) in Python
  • eval() and new Function() usage
  • child_process without execFile()
  • Path traversal in server arguments (../)

Credential Exposure (OWASP A07)

  • Hardcoded secrets in MCP server env config
  • AWS Access Key IDs (AKIA...)
  • GitHub tokens (ghp_..., ghs_...)
  • npm tokens (npm_...)
  • Generic API keys, passwords, and bearer tokens in source files

Auth Bypass (OWASP A05)

  • Commented-out authentication checks
  • SSL/TLS verification disabled
  • Always-false conditionals blocking security checks

Excessive Permissions (OWASP A05)

  • Shell execution, filesystem, database, and network access tools
  • Missing input schemas (no validation possible)
  • Empty/permissive input schemas
  • High concentration of privileged tools in a single server

Database Safety (OWASP A05)

Inspired by the "AI agent deleted our production database" incident (HN, Apr 2026, 429pts) β€” caused by an agent with unscoped database write access and no safeguards.

  • database-write-without-readonly β€” Database tool allows mutations (INSERT, UPDATE, DELETE, etc.) with no read-only mode or flag. An agent can modify data without any safe-mode constraint.
  • database-destructive-operations β€” Tool exposes DROP TABLE, TRUNCATE, or DELETE ALL. These cannot be undone; an agent (or prompt injector) invoking this tool causes irreversible data loss.
  • database-no-confirmation β€” Server has multiple database write tools with no confirmation or approval step in any of them. A manipulated agent can chain them to make large-scale irreversible changes.
  • unscoped-database-access β€” Tool accepts arbitrary SQL queries (e.g., execute_sql, run_query) with no allowlist. Any statement β€” DROP TABLE, DELETE FROM, exfiltration queries β€” passes directly to the database.

If your MCP server exposes an execute_sql tool that takes a raw query string and no read-only flag, agent-audit flags it as CRITICAL. The fix: replace it with scoped, purpose-built tools (get_user_by_id) or add an allowlist with parameterized queries only.

Exit Codes

CodeMeaning
0No critical or high findings
1High severity findings detected
2Critical findings detected

Use with --json for CI/CD integration:

# GitHub Actions
- name: Audit MCP servers
  run: npx agent-audit --auto --json --min-severity high > mcp-audit.json
  continue-on-error: false

Programmatic API

import {
  scan,
  parseClaudeDesktopConfig,
  parseCursorConfig,
  parseAnyConfig,   // auto-detects format
  findAllConfigs,   // finds both Claude Desktop + Cursor configs
} from "@piiiico/agent-audit";

// Auto-detect format (Claude Desktop or Cursor)
const servers = parseAnyConfig("/path/to/mcp.json");

// Explicit Claude Desktop
const servers = parseClaudeDesktopConfig("/path/to/claude_desktop_config.json");

// Explicit Cursor
const servers = parseCursorConfig("~/.cursor/mcp.json");

const result = await scan(servers, "my-app");

console.log(result.summary);
// { critical: 0, high: 2, medium: 1, low: 3, info: 0 }

for (const finding of result.findings) {
  console.log(finding.rule, finding.severity, finding.title);
}

Give Your Agents a Real Identity

agent-audit is built by AgentLair β€” persistent identity, email, and credential vault for AI agents.

Get an API key and email address in two commands:

# 1. Get a free API key (no signup form, no OAuth β€” one POST)
curl -s -X POST https://agentlair.dev/v1/auth/keys \
  -H "Content-Type: application/json" -d '{}' | jq .

# 2. Claim an @agentlair.dev email for your agent
curl -s -X POST https://agentlair.dev/v1/email/claim \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"address": "[email protected]"}'

Your agent gets: email (send/receive via API), encrypted vault, audit trail, and spending caps β€” all on the free tier. Getting started guide β†’

References

License

MIT

Related Servers

NotebookLM Web Importer

Import web pages and YouTube videos to NotebookLM with one click. Trusted by 200,000+ users.

Install Chrome Extension