Config is the same across clients — only the file and path differ.
{
"mcpServers": {
"trace-forge": {
"args": [
"trace-forge-mcp"
],
"command": "npx"
}
}
}Are you the author?
Add this badge to your README to show your security score and help users find safe servers.
MCP server for writing structured traces, spans, and decisions. The only write-path observability MCP — all 9 existing observability MCPs are read-only.
Run this in your terminal to verify the server starts. Then let us know if it worked — your result helps other developers.
npx -y 'trace-forge-mcp' 2>&1 | head -1 && echo "✓ Server started successfully"
After testing, let us know if it worked:
Five weighted categories — click any category to see the underlying evidence.
No known CVEs.
Checked trace-forge-mcp against OSV.dev.
Be the first to review
Have you used this server?
Share your experience — it helps other developers decide.
Sign in to write a review.
Others in devops
MCP server for using the GitLab API
All-in-One Sandbox for AI Agents that combines Browser, Shell, File, MCP and VSCode Server in a single Docker container.
A Unified MCP Server Management App (MCP Manager).
MCP Server for kubernetes management commands
MCP Security Weekly
Get CVE alerts and security updates for io.github.mdfifty50-boop/trace-forge and similar servers.
Start a conversation
Ask a question, share a tip, or report an issue.
Sign in to join the discussion.
MCP server for writing structured traces, spans, and decisions. The only write-path observability MCP — all 9 existing observability MCPs are read-only.
Built for EU AI Act traceability compliance (Article 14, due August 2026).
npx trace-forge-mcp
Add to claude_desktop_config.json:
{
"mcpServers": {
"trace-forge": {
"command": "npx",
"args": ["trace-forge-mcp"]
}
}
}
git clone https://github.com/mdfifty50-boop/trace-forge-mcp.git
cd trace-forge-mcp
npm install
node src/index.js
Begin a new trace for an agent task.
| Param | Type | Required | Description |
|---|---|---|---|
agent_id | string | yes | Unique agent identifier |
task_description | string | yes | What the agent is doing |
metadata | object | no | Optional metadata (model, department, priority) |
Returns: { trace_id, started_at }
Create a span within a trace. Spans can be nested via parent_span_id.
| Param | Type | Required | Description |
|---|---|---|---|
trace_id | string | yes | Trace to attach to |
span_name | string | yes | Span name (e.g. "research", "validation") |
parent_span_id | string | no | Parent span for nesting |
metadata | object | no | Optional span metadata |
Returns: { span_id, trace_id }
Log a tool call within a trace. Auto-calculates cost estimate from token count.
| Param | Type | Required | Description |
|---|---|---|---|
trace_id | string | yes | Trace this belongs to |
span_id | string | no | Span this belongs to |
tool_name | string | yes | Tool that was called |
args | object | yes | Arguments passed |
result_preview | string | yes | Result preview (max 500 chars) |
tokens_used | number | no | Token count (enables cost estimation) |
duration_ms | number | yes | Call duration in milliseconds |
status | string | yes | "success", "error", or "timeout" |
Returns: { event_id, logged: true }
Log an agent decision point with reasoning and alternatives considered.
| Param | Type | Required | Description |
|---|---|---|---|
trace_id | string | yes | Trace this belongs to |
reasoning | string | yes | Why the agent made this decision |
alternatives_considered | string[] | yes | Other options evaluated |
chosen_action | string | yes | What was decided |
confidence | number | yes | Confidence 0.0 to 1.0 |
Returns: { event_id, logged: true }
Complete a trace. Auto-calculates total duration, event counts, and span counts.
| Param | Type | Required | Description |
|---|---|---|---|
trace_id | string | yes | Trace to complete |
outcome | string | yes | "success", "failure", "partial", or "timeout" |
summary | string | no | Optional summary |
Returns: { trace_id, duration_ms, events_count, spans_count, tool_calls_count }
Retrieve a complete trace tree with all spans, events, tool calls, and decisions.
| Param | Type | Required | Description |
|---|---|---|---|
trace_id | string | yes | Trace ID to retrieve |
Returns: Full trace object with nested span tree, all events, and computed totals.
Find traces by agent ID and/or status.
| Param | Type | Default | Description |
|---|---|---|---|
agent_id | string | - | Filter by agent |
status | string | - | Filter by status |
limit | number | 20 | Max results (1-100) |
Returns: Matching traces sorted by recency with summary stats.
| URI | Description |
|---|---|
traces://recent | Last 20 traces with summary |
traces://stats | Aggregate statistics (total, avg duration, success rate) |