agnt
Supports auto-detection of Astro development servers and proxying of Astro applications with URL pattern matching for local server addresses.
Provides tunnel management capabilities using Cloudflare tunnels for mobile testing and remote access to local development environments.
Supports configuration and management of Gin-based Go applications through the daemon process manager with environment variable configuration.
Supports auto-detection of Hugo development servers and proxying of Hugo applications with URL pattern matching for web server addresses.
Supports auto-detection of Jekyll development servers and proxying of Jekyll applications with URL pattern matching for server addresses.
Supports auto-detection of Next.js development servers and proxying of Next.js applications with URL pattern matching for local and network addresses.
Provides tunnel management capabilities using ngrok tunnels for mobile testing and remote access to local development environments.
Supports auto-detection of React development servers and proxying of React applications with URL pattern matching, including enhanced error consolidation for React stack traces.
Supports auto-detection of Vite development servers and proxying of Vite applications with URL pattern matching for local and network addresses.
Supports auto-detection of Wails development servers and proxying of Wails applications with URL pattern matching for DevServer URLs.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@agnttake a screenshot of the current page and highlight the broken button"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
agnt
Give your AI coding agent browser superpowers.
What is agnt?
agnt is a new kind of tool designed for the age of AI-assisted development. It acts as a bridge between your AI coding agent and the browser, extending what's possible during vibe coding sessions.
When you're in the flow with Claude Code, Cursor, or other AI coding tools, agnt lets your agent:
See what you see - Screenshots, DOM inspection, and visual debugging
Hear from you directly - Send messages from the browser to your agent
Sketch ideas together - Draw wireframes directly on your UI
Debug in real-time - Capture errors, network traffic, and performance metrics
Test on any device - Tunnel to phones and BrowserStack with full instrumentation
Extend its thinking window - Structured data uses fewer tokens than your descriptions
Related MCP server: Curupira
Demo

Draw wireframes directly on your running app, then send them to your AI agent
The Vision: Extending Your Agent's Capabilities
Traditional AI coding assistants are blind to what's happening in the browser. They can write code, but they can't:
See the visual result of their changes
Know when JavaScript errors occur
Understand layout issues you're experiencing
Receive feedback without you typing it out
agnt changes this. It creates a bidirectional channel between your browser and your AI agent:
┌─────────────────┐ ┌─────────────────┐ ┌─────────────────┐
│ Your Browser │ ←──► │ agnt │ ←──► │ AI Agent │
│ │ │ │ │ │
│ - See changes │ │ - Proxy traffic│ │ - Receives │
│ - Send notes │ │ - Capture errors│ │ context │
│ - Draw sketches│ │ - Inject tools │ │ - Acts on │
│ - Click to log │ │ - Route messages│ │ feedback │
└─────────────────┘ └─────────────────┘ └─────────────────┘Quick Start
Installation
npm (recommended):
npm install -g @standardbeagle/agntpip/uv:
pip install agnt
# or
uv pip install agntFrom source:
git clone https://github.com/standardbeagle/agnt.git
cd agnt
make build && make install-localAs MCP Server (Claude Code, Cursor, etc.)
Add to your MCP configuration:
{
"mcpServers": {
"agnt": {
"command": "agnt",
"args": ["mcp"]
}
}
}Or install as a Claude Code plugin:
/plugin marketplace add standardbeagle/agnt
/plugin install agnt@agntOne-shot: agnt skills — install the agnt agent skills and register the
MCP server in a single command. It uses Vercel's open skills CLI
to fetch the skills, then wires up MCP:
agnt skills # install for Claude Code + register the MCP server
agnt skills --agent cursor # install the skills for a different agentUnder the hood it runs npx -y skills add standardbeagle-tools/agnt --all -a claude-code, then claude mcp add agnt -s user -- agnt mcp (for other agents
it prints the MCP config to add). Requires Node.js (npx) on PATH.
As PTY Wrapper (Enhanced Terminal)
Wrap your AI tool for overlay features:
agnt run claude --dangerously-skip-permissions
agnt run cursor
agnt run aiderThis adds a terminal overlay menu (Ctrl+P) and enables the browser-to-terminal message bridge.
First-Run Setup (auto-configures a new project)
The first time you run agnt run claude in a project that has no .agnt.kdl,
agnt drives a one-time setup run before your coding session:
cd my-new-project # no .agnt.kdl yet
agnt run claudeWhat happens:
Setup phase — Claude launches in setup mode and configures the project: it detects the stack (Go / Node / Python / …), registers your dev-server script(s) and a reverse proxy, and writes a
.agnt.kdl. If theagnt:setup-projectskill isn't installed, Claude tells you the exact install step (/plugin marketplace add standardbeagle/agntthen/plugin install agnt).Relaunch — when setup exits, agnt relaunches Claude into a normal coding session with autostart enabled, replaying your original arguments. Your dev servers and proxy come up automatically.
# Pass a task through — it's replayed verbatim into the relaunched session:
agnt run claude -- "add a /healthz endpoint"If you decline setup (no .agnt.kdl gets written), agnt records a timestamped
marker and won't nudge again until the re-nudge window elapses (default 7 days,
configurable via setup { renudge-ttl-days 7 } in .agnt.kdl). A successful
setup is remembered permanently.
Setup also works for other agents — each gets install instructions tailored to its own skill/command mechanism (see docs/agent-support-matrix.md).
agnt init — configure without launching a session
Prefer to set the project up on its own? agnt init runs only the setup phase
(no relaunch) and exits once .agnt.kdl is written:
agnt init # configure with claude
agnt init gemini # configure with a different agentA successful agnt init records the permanent marker too, so a later
agnt run skips straight to the coding session.
Channel Mode (Beta — Claude Code only)
Beta / Experimental: Channel mode requires a forked MCP SDK and a development flag in Claude Code. Behavior and schema may change.
Claude Code v2.1.80+ can receive real-time browser errors, diagnostics, and user interactions as push events in context -- without the PTY wrapper. Add channel { enabled true } to .agnt.kdl and launch with claude --dangerously-load-development-channels server:agnt. See the Channel Mode section in CLAUDE.md for full schema, event format, and the channel_reply tool for sending messages back to the browser overlay.
Core Features
1. Browser Superpowers
Start a proxy and your agent gains eyes into the browser:
proxy {action: "start", id: "app", target_url: "http://localhost:3000"}Now your agent can:
// Take screenshots
proxy {action: "exec", id: "app", code: "__devtool.screenshot('current-state')"}
// Inspect any element
proxy {action: "exec", id: "app", code: "__devtool.inspect('#submit-button')"}
// Audit accessibility
proxy {action: "exec", id: "app", code: "__devtool.auditAccessibility()"}
// Check what the user clicked
proxy {action: "exec", id: "app", code: "__devtool.interactions.getLastClickContext()"}2. The Floating Indicator
Every proxied page gets a small floating bug icon. Click it to:
Send messages directly to your AI agent
Take screenshots of specific areas
Select elements to log their details
Open sketch mode for wireframing
No more alt-tabbing to describe what you see - just click and send.
3. Sketch Mode
Press the sketch button and draw directly on your UI:
Rectangles, circles, arrows, and freehand drawing
Wireframe elements: buttons, inputs, sticky notes
Save and send to your agent with one click
Perfect for saying "I want a button here" or "this layout is wrong" without typing a word.
4. Real-Time Error Capture
JavaScript errors are automatically captured and available to your agent:
proxylog {proxy_id: "app", types: ["error"]}
→ {message: "TypeError: Cannot read property 'map' of undefined",
stack: "at ProductList (products.js:42)",
timestamp: "..."}Your agent sees errors as they happen, not when you remember to mention them.
5. Extending the Thinking Window
Structured data consumes fewer tokens than natural language descriptions:
Error summaries -
proxylog {types: ["error"]}vs. "I'm seeing a TypeError on line 42 that says..."Click context -
interactions.getLastClickContext()vs. "I clicked the blue button in the header..."DOM state -
inspect('#element')vs. "there's a div with some nested spans and..."Consolidated stack traces - Pre-processed React error walls into actionable summaries
Status at a glance - Structured JSON your agent can parse efficiently
Instead of dumping 100 lines of nested React errors into the context, agnt consolidates verbose output into concise, actionable data.
MCP Tools
Tool | Description |
| Auto-detect project type and available scripts |
| Execute scripts or commands (background/foreground) |
| Manage processes: status, output, stop, list |
| Reverse proxy: start, stop, exec, status |
| Query logs: http, error, screenshot, sketch, panel_message |
| View active page sessions with grouped resources |
| Incident inbox pull when incident pipeline enabled |
| Responsive audit across viewport sizes (layout/overflow/a11y) |
| API-efficiency audit: waterfall, N+1, duplicate, chatty-load |
| Loading-UX audit: spinner cascade + concurrent fragmentation |
| Visual regression: baseline/compare screenshots |
| Tunnel management: cloudflare/ngrok for mobile testing |
| Manage background daemon service |
| Stream daemon events via |
| Send messages to developer's browser overlay (channel mode only) |
Browser API (50+ Functions)
The proxy injects window.__devtool with powerful diagnostics:
Element Inspection
__devtool.inspect('#element') // Full element analysis
__devtool.getPosition('#element') // Bounding box and position
__devtool.isVisible('#element') // Visibility checkVisual Debugging
__devtool.highlight('.items') // Highlight elements
__devtool.mutations.highlightRecent() // Show recent DOM changes
__devtool.screenshot('name') // Capture screenshotAccessibility
__devtool.auditAccessibility() // Full a11y audit with score
__devtool.getContrast('#text') // Color contrast check
__devtool.getTabOrder() // Tab navigation orderInteractions
__devtool.interactions.getLastClick() // Last click details
__devtool.interactions.getLastClickContext() // Full click context
__devtool.selectElement() // Interactive pickerSketch Mode
__devtool.sketch.open() // Enter sketch mode
__devtool.sketch.save() // Save and send to agent
__devtool.sketch.toJSON() // Export sketch dataResponsive Mode
__devtool.responsive.open() // Open the interactive width workbench
__devtool.responsive.setWidth(414) // Drive the frame to a width (320–1920)
__devtool.responsive.getState() // Read current width + detected layout shiftsScored Audits
__devtool.auditAll() // 8 weighted audits: dom, css, perf, security, seo,
// a11y, API efficiency, loading/spinner → overall gradeConfiguration
Create .agnt.kdl in your project root to auto-start scripts, proxies, and configure browser notifications:
// Scripts to run via daemon process manager
scripts {
dev {
run "npm run dev" // Shell command (recommended)
autostart true
url-matchers "(Local|Network):\\s*{url}"
}
api {
command "go" // Or use command + args
args "run" "./cmd/server"
autostart true
env {
GIN_MODE "debug"
}
cwd "./backend"
}
}
// Reverse proxies with traffic logging
proxies {
frontend {
script "dev" // Link to script for URL auto-detection
}
backend {
target "http://localhost:8080"
autostart true
max-log-size 2000
}
}
// Browser notifications when AI responds
hooks {
on-response {
toast true // Show toast notification
indicator true // Flash bug indicator
sound false // Play notification sound
}
}
// Toast appearance
toast {
duration 4000
position "bottom-right" // top-right, top-left, bottom-right, bottom-left
max-visible 3
}Run /setup-project in Claude Code to interactively generate this configuration.
Framework-specific URL matchers:
Framework | url-matchers |
Next.js / Vite / React |
|
Wails |
|
Astro |
|
Jekyll |
|
Hugo |
|
Architecture
agnt uses a daemon architecture for persistent state:
┌─────────────────────┐ ┌─────────────────────────────────────┐
│ AI Agent │ │ agnt │
│ (Claude Code, etc.)│◄─────►│ │
│ │ MCP │ ┌────────────────┐ │
└─────────────────────┘ │ │ MCP Server │ │
│ └───────┬────────┘ │
│ │ socket │
│ ▼ │
┌─────────────────────┐ │ ┌────────────────────────────────┐ │
│ Browser │◄──────┼──│ Daemon │ │
│ │ proxy │ │ ProcessManager │ ProxyManager │ │
│ __devtool API │ │ └────────────────────────────────┘ │
│ Floating Indicator │ └─────────────────────────────────────┘
│ Sketch Mode │
└─────────────────────┘Key design decisions:
Lock-free concurrency with
sync.Mapand atomicsBounded memory with ring buffers
Processes and proxies survive client disconnections
Zero-dependency frontend JavaScript
Documentation
# Run docs locally
cd docs-site
npm install && npm startUse Cases
Vibe coding - Stay in flow while your agent sees everything
Visual debugging - Show don't tell - sketch what's wrong
Mobile testing - Tunnel your dev server for real device testing with Cloudflare/ngrok + BrowserStack integration
Accessibility testing - Automated a11y audits during development
Error tracking - Catch frontend errors before users do
UI reviews - Annotate designs directly on the live app
Remote collaboration - Share visual context with your agent
Requirements
Node.js 18+ or Go 1.24+
MCP-compatible AI assistant
Migrating from devtool-mcp
agnt is the new name for devtool-mcp. Existing users:
# npm
npm uninstall -g @standardbeagle/devtool-mcp
npm install -g @standardbeagle/agnt
# pip
pip uninstall devtool-mcp
pip install agntUpdate your MCP config to use agnt command with ["mcp"] args.
License
MIT
Contributing
Contributions welcome! See the documentation for architecture details.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Appeared in Searches
Latest Blog Posts
- Your AI Chatbot Just Exposed Your CEO's Salary to an InternBy Om-Shree-0709 on .Agent IdentityMCP SecurityOAuth Delegation
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/standardbeagle/agnt'
If you have feedback or need assistance with the MCP directory API, please join our Discord server