loading…
Search for a command to run...
loading…
A MCP server for interacting with FogBugz issue tracker through LLMs such as Claude. Supports both the XML API (/api.asp) and the JSON API (/f/api/0/jsonapi) wi
A MCP server for interacting with FogBugz issue tracker through LLMs such as Claude. Supports both the XML API (/api.asp) and the JSON API (/f/api/0/jsonapi) with automatic version detection at startup. Works with on-premise and on-demand FogBugz installations.
A Model Context Protocol (MCP) server that connects AI assistants to a live FogBugz instance. Search and manage cases, track history, assign and resolve — all from a natural language conversation. Works with on-premise and on-demand FogBugz installations.
project:Website status:Active)You need an API token to authenticate the MCP server with FogBugz. There are two ways to obtain one:
Go to Account & Settings → User Options and click the Create API Token link.
See the official guide: Create API Token using the FogBugz UI
Send the following request (replace placeholders with your values):
https://[your-fogbugz-server]/api.asp?cmd=logon&email=[your-email]&password=[your-password]
The response will contain your API token.
See the official guide: Get an API Token using FogBugz API commands
MCP is an open standard — this server works with any MCP-compatible AI client. Configuration varies by client.
One-click install: Download the latest .mcpb package from the Releases page and open it — Claude Desktop will install and configure the server automatically, prompting you for your FogBugz URL and API token.
Manual configuration: Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"fogbugz": {
"command": "npx",
"args": ["-y", "@todevs/fogbugz-mcp"],
"env": {
"FOGBUGZ_URL": "https://your-fogbugz-server.com",
"FOGBUGZ_API_KEY": "your-api-token"
}
}
}
}
Add to .mcp.json in your project root:
{
"mcpServers": {
"fogbugz": {
"command": "npx",
"args": ["-y", "@todevs/fogbugz-mcp"],
"env": {
"FOGBUGZ_URL": "https://your-fogbugz-server.com",
"FOGBUGZ_API_KEY": "your-api-token"
}
}
}
}
Any client that supports MCP stdio servers should work. Consult your client's documentation for how to register a stdio MCP server with environment variables. The server entry point is npx @todevs/fogbugz-mcp (or node /path/to/dist/index.js for a local build).
| Tool | Description |
|---|---|
create_case |
Create a new case |
update_case |
Update an existing case (title, comment, project, area, milestone, priority) |
assign_case |
Assign a case to a user |
resolve_case |
Resolve (mark as fixed/completed) a case |
reopen_case |
Reopen a resolved or closed case |
close_case |
Close a case |
| Tool | Description |
|---|---|
search_cases |
Search using FogBugz query syntax (e.g. project:Website status:Active) |
list_my_cases |
List cases assigned to a user (defaults to current user) |
get_case |
Get detailed case info including full event/comment history |
get_case_link |
Get a direct URL to a case |
| Tool | Description |
|---|---|
list_people |
List all users with IDs, names, and emails |
list_categories |
List case categories (Bug, Feature Request, etc.) |
list_projects |
List all active projects with IDs and names |
list_milestones |
List milestones/fix-fors, optionally by project |
list_statuses |
List case statuses with resolved flags, optionally by category |
view_project |
Get detailed project information |
view_area |
Get detailed area information |
create_project |
Create a new project |
| Tool | Description |
|---|---|
api_request |
Generic XML API escape-hatch for commands not covered by dedicated tools. ⚠️ WARNING: can execute any API command the configured key permits, including destructive operations (delete, edit users, bulk modify). |
You: "Show me all open bugs in the Website project assigned to nobody."
Claude calls: search_cases with query project:Website status:Active assignedTo:nobody category:Bug.
Result: A list of unassigned bugs with their IDs, titles, and creation dates — ready to triage or assign.
You: "Create a bug in the Mobile project titled 'Login button unresponsive on iOS 17', assign it to alice, and set priority to 2."
Claude calls: create_case with project, title, assignee, and priority set in a single call, then get_case_link to return a direct URL.
Result: New case created. Claude confirms the case number and provides a link.
You: "Resolve case 1042 and add a comment saying the fix was deployed in v3.5.1."
Claude calls: resolve_case with the case ID and a comment describing the fix.
Result: Case resolved. Claude confirms the status change and the comment was saved.
You: "What open cases does bob have right now?"
Claude calls: list_people to find Bob's user ID, then list_my_cases filtered to that user.
Result: A summary of Bob's active cases grouped by project, with priorities and due dates.
You: "Move case 987 to the Backend project, change the milestone to v4.0, and leave a comment saying it was re-scoped after the architecture review."
Claude calls: update_case with the new project, milestone, and comment all set in one call.
Result: Case updated. Claude confirms each field change.
This server implements the Model Context Protocol over stdio. The AI client translates natural language requests into FogBugz queries or API calls, invokes the appropriate tool, and presents the results. The server is a thin proxy — it passes requests directly to your FogBugz instance and returns the response.
At startup the server automatically selects the right API client for your FogBugz instance:
/api.xml to read the FogBugz version number./f/api/0/jsonapi) — uses FogBugzJsonClient on success.FogBugzXmlClient (XML API via /api.asp) for version < 9 or if the JSON endpoint is unreachable.| FogBugz version | API used |
|---|---|
| ≥ 9 (JSON API available) | JSON API (/f/api/0/jsonapi) |
| < 9 or JSON API unreachable | XML API (/api.asp) |
Note on text formatting: Plain text only is supported in descriptions and comments when connected to FogBugz 8.x via the XML API. HTML and Markdown are stored and displayed literally.
| Variable | Required | Description |
|---|---|---|
FOGBUGZ_URL |
Yes | Base URL of your FogBugz instance (e.g. https://company.fogbugz.com) |
FOGBUGZ_API_KEY |
Yes | FogBugz API token |
# Latest stable release
npx @todevs/fogbugz-mcp
# Latest dev build (pre-release)
npx @todevs/fogbugz-mcp@dev
git clone https://github.com/todevelopers/fogbugz-mcp.git
cd fogbugz-mcp
npm install
npm run build
node dist/index.js https://your-fogbugz-server.com your-api-token
npm run dev # run via ts-node (no build needed)
npm run build # compile TypeScript to dist/
npm test # run all Jest tests
This server does not collect, store, or transmit any data to ToDevelopers or any third party. All communication is directly between your AI client and your own FogBugz instance using the URL and credentials you provide. No usage data, case content, or credentials are sent anywhere other than your configured FogBugz server.
For complete privacy information, see the FogBugz Privacy Policy.
This project is based on the original work by Sarasvati Akari Lara-Almeida — thank you for the foundation.
MIT © Tomáš Gažovič, ToDevelopers s.r.o.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"fogbugz": {
"command": "npx",
"args": []
}
}
}