Turn your existing system into an AI-agent-ready platform โ in seconds.
AgentBridge uses an AI analysis agent to understand your project code, then generates a complete Agent Integration Kit that works with MCP, Claude, OpenAI, and Vercel AI SDK out of the box.
Deterministic scanners still collect candidate evidence from OpenAPI, GraphQL, SQL, and source routes, but they are not the source of truth. The AI agent reads the project context, reasons about business objects and side effects, then creates tools, skills, prompts, guardrails, tests, and protocol metadata.
- โจ Features
- ๐ Quick Start
- ๐ CLI Reference
- ๐ How AgentBridge Analyzes Projects
- ๐ Candidate Evidence Sources
- ๐ Stable Kit Protocol
- ๐ค AI Agent Generation
- ๐ก๏ธ Safety Model
- ๐๏ธ Architecture
- ๐ Documentation
- ๐งฉ Extending AgentBridge
- ๐ฆ Publishing & Installation
- ๐ค Contributing
- ๐ License
|
๐ AI-first code analysis Uses an AI agent to interpret business objects, workflows, permissions, and side effects from project code |
๐ง Multi-format Generation Outputs MCP, Claude, OpenAI, and Vercel AI SDK tool definitions simultaneously |
|
๐ค AI-Powered Generation Uses Claude Agent SDK (primary) or Anthropic API (fallback) to dynamically generate tools, skills, and prompts |
๐ง Agent as a Service Runs as an interactive agent for your existing project via Claude Agent SDK |
|
๐ก๏ธ Safety-first Classifies operations by risk level with human-in-the-loop confirmation for dangerous actions |
๐งช Dry-run Validation Test tool invocations against generated guardrails before executing |
|
๐ Custom LLM Providers Supports DeepSeek, OpenRouter, and any Anthropic-compatible endpoint |
๐ชถ Rules as evidence OpenAPI, GraphQL, SQL, and route scanners provide candidate signals for the AI agent to verify or override |
pip install agbrFor project-directory analysis, install the Agent SDK extra. This is the recommended path because it lets AgentBridge use the Claude Agent SDK to explore the project incrementally and stream tool/progress events:
pip install "agbr[agent]"๐ฆ Install with optional features
# AI-powered generation + agent sessions (recommended)
pip install "agbr[agent]"
# Lightweight AI generation (no Claude Agent SDK)
pip install "agbr[ai]"
# Everything
pip install "agbr[all]"
# Install from source (for development)
git clone git@github.com:jastfkjg/AgentBridge.git
cd AgentBridge
pip install -e ".[all]"AgentBridge relies on an AI backend for existing-project understanding. Deterministic scanners and regex/rule signals are used as evidence for the AI agent, not as the final project model. The schema-only OpenAPI-to-MCP path can run with --no-ai; directory-level project analysis should use Claude Agent SDK. Anthropic-compatible endpoints such as DeepSeek and OpenRouter can be configured through ANTHROPIC_BASE_URL.
# Required for project directory analysis
export ANTHROPIC_API_KEY="sk-ant-..."
# Optional: Custom API endpoint
export ANTHROPIC_BASE_URL="https://api.deepseek.com/anthropic" # DeepSeek
# export ANTHROPIC_BASE_URL="https://openrouter.ai/api/v1" # OpenRouter
# Optional: Custom model name
export ANTHROPIC_MODEL="deepseek-v4-flash"๐ Or pass via CLI flags
agentbridge generate examples/writing_system --output build/kit \
--api-key "sk-..." \
--base-url "https://api.deepseek.com/anthropic" \
--model "deepseek-v4-flash" \
--analysis-mode agenticNote:
--analysis-mode autoprefers Claude Agent SDK wheneverclaude-agent-sdkis installed, even whenANTHROPIC_BASE_URLpoints to a compatible endpoint. Use--analysis-mode promptto force the direct Anthropic-compatible prompt route.
# Project directory analysis uses AI. Generated files are written only to --output.
agentbridge generate examples/writing_system \
--output .agentbridge/writing-kit \
--analysis-mode agentic \
--batch-size 10 \
--resume \
--progress-interval 5For large projects, AgentBridge analyzes the primary capability batch first, then asks whether to continue enhancing the remaining capabilities. If you stop after the first batch, the kit is still generated with deterministic metadata for the rest; rerun with --resume to fill in remaining AI-enhanced batches.
agentbridge generate openapi.json --output .agentbridge/openapi-kit --no-ai
# Dry-run by default, with no target-system side effects
agentbridge serve .agentbridge/openapi-kit
# Execute real HTTP calls against the target system
agentbridge serve .agentbridge/openapi-kit \
--base-url http://localhost:8080 \
--bearer-env API_TOKEN \
--executeGenerate MCP client snippets for Claude Desktop, Claude Code, Codex CLI, or generic stdio clients:
agentbridge mcp-config .agentbridge/openapi-kit \
--base-url http://localhost:8080 \
--bearer-env API_TOKEN \
--executeagentbridge chat .agentbridge/writing-kit
# Browser chat UI
agentbridge web .agentbridge/writing-kit --port 8765PYTHONPATH=src python -m unittest discover -s tests| Command | Description |
|---|---|
agentbridge discover <paths> |
Discover and print capabilities as JSON |
agentbridge init <paths> -o <dir> |
Generate, validate, and print next steps for a new kit |
agentbridge generate <paths> -o <dir> |
Generate an Agent Integration Kit; uses AI enhancement when configured, with --analysis-mode, --resume, and batch progress support |
agentbridge validate <kit> |
Validate kit protocol, guardrails, transports, and secret hygiene |
agentbridge doctor <kit> |
Diagnose kit readiness for dry-run or execution mode |
agentbridge mcp-config <kit> |
Print or write Claude/Codex/generic MCP client snippets |
agentbridge serve <kit> |
Run a generated kit as a stdio MCP Server |
agentbridge dry-run <kit> <tool> |
Dry-run a tool invocation |
agentbridge chat <kit> |
Start an interactive CLI chat over the kit runtime |
agentbridge web <kit> |
Start a browser chat UI over the kit runtime |
๐ Full command details
agentbridge discover examples/writing_systemagentbridge init examples/writing_system/openapi.json --output build/openapi-kit --no-ai
agentbridge generate examples/writing_system --output build/agent-kit
# No LLM, useful for schema-only OpenAPI-to-MCP Server kits
agentbridge generate examples/writing_system/openapi.json --output build/openapi-kit --no-ai
# With custom name
agentbridge generate examples/writing_system --output build/agent-kit --name my-kit
# With custom LLM provider
agentbridge generate examples/writing_system --output build/agent-kit \
--api-key "sk-..." \
--base-url "https://api.deepseek.com/anthropic" \
--model "deepseek-v4-flash" \
--analysis-mode agentic \
--batch-size 10 \
--resume \
--progress-interval 5
# Force the direct prompt route instead of Claude Agent SDK
agentbridge generate examples/writing_system --output build/agent-kit \
--analysis-mode prompt \
--batch-size 10 \
--resume# Normal invocation
agentbridge dry-run build/agent-kit create_chapter --args '{"project_id":"p1","title":"Opening"}'
# High-risk operation (requires confirmation)
agentbridge dry-run build/agent-kit delete_character \
--args '{"project_id":"p1","character_id":"c1"}' --confirmedagentbridge validate build/agent-kit
agentbridge doctor build/agent-kit --execute --base-url http://localhost:8080# stdio MCP Server, dry-run by default
agentbridge serve build/openapi-kit
# Execute real HTTP calls against the target system
agentbridge serve build/openapi-kit \
--base-url http://localhost:8080 \
--header "X-Tenant=demo" \
--bearer-env API_TOKEN \
--execute \
--audit-log .agentbridge/audit.jsonl
# Conservative runtime policy
agentbridge serve build/openapi-kit --read-only
agentbridge serve build/openapi-kit --deny-risk destructive --deny-risk external_side_effectagentbridge chat build/agent-kit
# Execute real HTTP calls, with session memory
agentbridge chat build/agent-kit \
--base-url http://localhost:8080 \
--bearer-env API_TOKEN \
--execute \
--audit-log .agentbridge/audit.jsonl \
--user alice \
--session demoInside chat, use /tools, /run <tool> key=value, confirm, cancel, and /history.
agentbridge web build/agent-kit --port 8765
# Execute real HTTP calls in the Web UI
agentbridge web build/agent-kit \
--base-url http://localhost:8080 \
--bearer-env API_TOKEN \
--execute \
--read-onlyagentbridge mcp-config build/openapi-kit \
--base-url http://localhost:8080 \
--bearer-env API_TOKEN \
--execute
# Write snippets back into the kit
agentbridge mcp-config build/openapi-kit --writeAgentBridge is designed so the AI agent performs the main project understanding step. Rule-based discovery is intentionally conservative and acts as evidence collection.
| Stage | Role |
|---|---|
| Candidate scanning | Extract OpenAPI operations, GraphQL fields, SQL tables, and route handlers |
| AI project analysis | Claude Agent SDK explores project files read-only, then infers business objects, workflows, permission boundaries, side effects, missing operations, and assumptions |
| Capability normalization | Convert the AI-enhanced analysis into stable tool-ready capabilities |
| Kit generation | Emit tools, skills, prompts, resource schemas, guardrails, dry-run plans, and tests |
AgentBridge does not modify the target project during discovery or generation. All generated artifacts are written under the caller-provided output directory, preferably outside the project or under a dedicated ignored directory such as .agentbridge/.
The generated kit preserves both layers:
analysis/rule_signals.json: deterministic candidate evidenceanalysis/agent_analysis.json: AI agent project analysis and reasoninganalysis/resume_state.jsonandanalysis/batches/*.json: optional batch-enhancement checkpoints used by--resume
| Source Type | Formats |
|---|---|
| ๐ API Schemas | OpenAPI JSON/YAML, GraphQL schemas |
| ๐๏ธ Database Schemas | SQL CREATE TABLE statements |
| ๐ Python Routes | FastAPI @router.get/post/..., Flask @app.route |
| ๐ JavaScript Routes | Express app.get/post/... |
| โ Java Routes | Spring @GetMapping/@PostMapping/... |
All sources are normalized into a common capability model with:
| Field | Description |
|---|---|
domain + resource |
Logical grouping |
action |
What the capability does |
input_schema |
JSON Schema parameters |
risk |
read / write / destructive / external_side_effect |
confirm_required |
Whether human approval is needed |
source |
Full traceability back to the origin file |
Current protocol: agentbridge-kit/v1. See docs/kit-protocol.md.
agent-kit/
โโโ manifest.json # Kit metadata and summary
โโโ capabilities.json # AI-enhanced normalized capabilities
โโโ analysis/
โ โโโ rule_signals.json # Scanner evidence used as AI context
โ โโโ agent_analysis.json # AI project analysis and risk reasoning
โโโ spec/
โ โโโ kit-protocol.md # Protocol contract copied into the kit
โโโ tools/
โ โโโ mcp_tools.json # MCP tool definitions
โ โโโ openai_tools.json # OpenAI function calling format
โ โโโ claude_tools.json # Claude tool use format
โ โโโ vercel_ai_tools.ts # Vercel AI SDK TypeScript tools
โโโ skills/
โ โโโ writing.md # Domain-specific skill definitions
โโโ prompts/
โ โโโ system.md # Agent system prompt
โโโ resources/
โ โโโ schema.json # Resource schema summary
โโโ guardrails/
โ โโโ permissions.json # Risk policy and confirmation rules
โโโ tests/
โ โโโ tool_invocation_tests.json # Auto-generated invocation tests
โ โโโ test_generated_tools.py # Python unit tests for tool contracts
โโโ clients/
โ โโโ mcp-client-configs.json # Claude/Codex/generic MCP config snippets
โ โโโ README.md # Client setup notes
โโโ dry_run_plan.json # Dry-run execution plan
AgentBridge uses an AI analysis agent to generate the semantic parts of the kit: project analysis, tool descriptions, skills, system prompts, risk assessments, and inferred tools. Rule-based analysis is passed to the agent as candidate evidence and safety hints, not copied directly as final output.
| What | Description |
|---|---|
| ๐งญ Project analysis | Business objects, workflows, permission boundaries, side effects, and assumptions |
| ๐ Enhanced tool descriptions | Context-aware descriptions that capture business semantics |
| ๐ฏ Domain-specific skills | Workflow prompts tailored to your domain with best practices |
| ๐ง Intelligent system prompts | Prompts that understand resource relationships and suggest safe sequences |
| ๐ Inferred additional tools | Tools implied by your schema but not explicitly present |
| LLM evaluates risk with rule-based hints as context |
| Backend | Package | Use Case |
|---|---|---|
| Claude Agent SDK (primary) | claude-agent-sdk |
Agentic project analysis, kit content generation, streamed tool/progress events, and interactive agent sessions |
| Anthropic API (prompt route) | anthropic |
Direct prompt-based generation, useful when SDK is unavailable or when forcing --analysis-mode prompt |
When claude-agent-sdk is installed, --analysis-mode auto uses it automatically for project directories. ANTHROPIC_BASE_URL is passed through for compatible endpoints such as DeepSeek. If the SDK is not installed, AgentBridge recommends installing agbr[agent] and falls back to the direct prompt route when possible. Use --analysis-mode agentic to require SDK analysis, or --analysis-mode prompt to force prompt-only analysis.
Large projects are enhanced in batches. The first batch is ranked to cover the main capabilities; in an interactive terminal AgentBridge then asks whether to continue. Completed batch results are written under analysis/batches/, and --resume skips batches that already completed.
from pathlib import Path
from agentbridge.generator import AgentKitGenerator
from agentbridge.agent import AIGenerator, AgentRunner
# Generate with default provider (Anthropic Claude)
ai = AIGenerator(api_key="sk-ant-...")
kit = AgentKitGenerator(ai_generator=ai).generate(
[Path("examples/writing_system")],
Path("build/agent-kit"),
)
# Custom LLM provider (e.g., DeepSeek)
ai = AIGenerator(
api_key="sk-d831ecabc21842fdae6f30c24dd3b052",
base_url="https://api.deepseek.com/anthropic",
model="deepseek-v4-flash",
analysis_mode="agentic",
)
# Agent session
import asyncio
async def main():
runner = AgentRunner(kit_dir="build/agent-kit", api_key="sk-ant-...")
async for message in runner.query("List all chapters in project p1"):
print(message)
asyncio.run(main())| Risk Level | Confirmation | Examples |
|---|---|---|
๐ข read |
Not required | GET, list, search, find |
๐ก write |
Optional by policy | POST, create, update, rewrite |
๐ด destructive |
Required | DELETE, remove, destroy, drop, cancel |
๐ external_side_effect |
Required | publish, send, email, pay, deploy, export |
The safety model is applied consistently. Rule-based risk classification provides initial context, and the LLM may override when justified.
โโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโ
โ Rule Signals โโโโโโถโ AI Analysis โโโโโโถโ Kit Generator โ
โ (schemas, โ โ Agent โ โ (protocol v1) โ
โ routes, SQL)โ โ โ โ โ
โโโโโโโโโโโโโโโ โโโโโโโโฌโโโโโโโ โโโโโโโโโโฌโโโโโโโโโ
โ โ
โโโโโโโโผโโโโโโโ โโโโโโโโผโโโโโโโโโ
โ Capabilitiesโ โ Agent Runtime โ
โ Skills โ โ Dry-run + โ
โ Guardrails โ โ Guardrails โ
โโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโ
- Architecture
- Kit protocol
- OpenAPI to MCP Server
- Chat entrypoints
- TODO / Roadmap
- ไธญๆ README
- ไธญๆๆถๆ่ฏดๆ
- ไธญๆๅฅไปถๅ่ฎฎ
- ไธญๆ OpenAPI ๅฐ MCP Server
- ไธญๆ่ๅคฉๅ ฅๅฃ
| Extension | How |
|---|---|
| New schema parser | Implement a discoverer in discovery.py |
| New tool format | Add a builder function in generator.py |
| Custom AI prompts | Override prompts in agent.py |
| Custom risk policy | Modify policy.py |
| Custom agent tools | Extend AgentRunner._build_kit_tools() |
๐ง How does `pip install "agbr"` work?
AgentBridge is packaged as a standard Python package using pyproject.toml + setuptools. Here's the mechanism:
AgentBridge/
โโโ pyproject.toml # Package metadata, dependencies, entry points
โโโ src/
โ โโโ agentbridge/ # Actual Python package
โ โโโ __init__.py
โ โโโ cli.py # CLI entry point
โ โโโ agent.py
โ โโโ generator.py
โ โโโ ...
โโโ tests/
[project]
name = "agbr" # pip install agbr
version = "0.2.0"
[project.optional-dependencies] # pip install "agbr[agent]"
agent = ["claude-agent-sdk>=0.1.0"]
ai = ["anthropic>=0.30.0"]
[project.scripts]
agentbridge = "agentbridge.cli:main" # CLI entry point
[tool.setuptools.packages.find]
where = ["src"] # Code lives in src/- Build:
pipreadspyproject.toml, usessetuptoolsto build a wheel (.whl) - Install: The wheel is installed into your Python environment's
site-packages/ - CLI: The
[project.scripts]section creates aagentbridgeexecutable in your PATH that callsagentbridge.cli:main
# Build the package
pip install build
python -m build
# Upload to TestPyPI (for testing)
pip install twine
twine upload --repository testpypi dist/*
# Upload to PyPI (for real)
twine upload dist/*After publishing, anyone can run pip install "agbr".
Until the package is published on PyPI, users can install it in these ways:
# Install from local source (editable mode, for development)
pip install -e .
# Install from GitHub repository
pip install git+ssh://git@github.com/jastfkjg/AgentBridge.git
# Install from a local wheel
pip install dist/agentbridge-0.2.0-py3-none-any.whlContributions are welcome! Here's how you can help:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Please make sure tests pass:
PYTHONPATH=src python -m unittest discover -s tests -vThis project is licensed under the MIT License โ see the LICENSE file for details.