examples/integrations/agent-spec/README.md
This is a starter template for building AI agents using Agent Spec and CopilotKit. It provides a modern Next.js application wired to a FastAPI backend that serves an Agent Spec agent with A2UI-powered frontend tool rendering (calendar, inbox, email compose, daily brief dashboard).
Before installing, please clone the AG-UI repository into the same directory as this repo, with-agent-spec.
# Using npm (default)
npm install
# Using pnpm
pnpm install
# Using yarn
yarn install
# Using bun
bun install
Note: This automatically sets up the Python environment for the agent (via
postinstall). If you encounter issues, you can run:bashnpm run install:agent
Note: this install both LangGraph and WayFlow runtimes for running your Agent Spec agents. The runtime can be selected when loading the agent in main.py, setting either langgraph or wayflow.
Create a .env file inside the agent folder if you need to override defaults:
OPENAI_API_KEY=sk-...your-api-key...
OPENAI_BASE_URL=https://api.your-provider.com/v1 # optional
OPENAI_MODEL=gpt-5.2 # optional
The backend loads this .env automatically (via python-dotenv). You can also set:
PORT to change the FastAPI server port (defaults to 8000 in this template)# Using npm (default)
npm run dev
# Using pnpm
pnpm dev
# Using yarn
yarn dev
# Using bun
bun run dev
This starts both the UI and the agent concurrently. The agent runs at http://localhost:8000/, and the UI runs at http://localhost:3000. The UI proxies requests to the agent (no extra env required by default).
To run only the UI or only the backend:
# Only UI
npm run dev:ui
# Only backend
npm run dev:agent
src/app/page.tsx - Main chat UI with frontend tool renderers (calendar, inbox, email, daily brief)src/components/ - React components for CalendarView, InboxView, EmailComposeViewsrc/app/theme.ts - A2UI theme configurationagent/src/a2ui_agentspec_agent.py - Agent spec definition with system prompt, tools, and demo dataagent/src/main.py - FastAPI server entry pointYou can run these with any package manager:
dev - Starts both UI and agent servers in development modedev:debug - Starts development servers with debug logging enableddev:ui - Starts only the Next.js UI serverdev:agent - Starts only the Agent Spec FastAPI serverbuild - Builds the Next.js application for productionstart - Starts the production serverinstall:agent - Installs Python dependencies for the agentFeel free to submit issues and enhancement requests! This starter is designed to be easily extensible.
This project is licensed under the MIT License - see the LICENSE file for details.
If A2UI cards (e.g. those with bottom action buttons) get clipped in the chat UI, we keep a temporary patch under:
src/app/patches/@copilotkit/a2ui-renderer/dist/A2UIMessageRenderer.jsTo apply it locally (this edits node_modules and will be overwritten by reinstalling dependencies):
npm run patch:ui
After copying, restart npm run dev.
If you see React warnings about duplicate keys related to custom message rendering (keys like ${message.id}-custom-before / ${message.id}-custom-after), we keep a temporary patch under:
src/app/patches/@copilotkit/react-core/dist/index.mjsTo apply it locally (this edits node_modules and will be overwritten by reinstalling dependencies):
npm run patch:ui
After copying, restart npm run dev.
If you see "I'm having trouble connecting to my tools", make sure:
NEXT_PUBLIC_COPILOTKIT_SERVER_URLIf you encounter Python import errors:
cd agent
uv sync
uv run src/main.py