Skip to main content

WRG MCP server - exposes WinstonRedGuard tools to Claude and AI agents

Project description

wrg_mcp_server

PyPI MCP Registry

MCP (Model Context Protocol) server exposing the WinstonRedGuard monorepo to Claude and other MCP-compatible AI agents. Built on FastMCP — registers tools from every active WRG app so an agent can inspect the repo, run pipelines, query memory, and call remote services without shelling out.

Published:

Transports

wrg-mcp-server --transport stdio              # Claude Desktop / Claude Code
wrg-mcp-server --transport streamable-http    # default HTTP (recommended)
wrg-mcp-server --transport sse                # legacy HTTP

Flags: --host 0.0.0.0 · --port 8080 · --mcp-path /mcp

Install

cd apps/wrg_mcp_server
pip install -e .             # core: MCP + local tools only
pip install -e ".[remote]"   # adds httpx for site_* / pulseboard_* tools
pip install -e ".[dev]"      # pytest + pytest-asyncio

Tools exposed

Local (subprocess-backed, always available)

Tool What it does
connector_status Report which remote services are configured
app_list, app_info Query app_registry/data/registry.json
governance_run Execute governance_check across one or all apps
release_check Run the tools/release_check.ps1 gate
pipeline_list, pipeline_show, pipeline_run wrg_pipeline DAG operations
pulse_check Invoke wrg-pulse check
memory_get, memory_set, memory_list, memory_search wrg_memory key-value access
research_history, research_report, research_scan, research_watch, research_scan_summary research_motor runs and artifacts
research_motor_healthz, research_motor_scan_create, research_motor_scan_get research_motor HTTP API v1 over localhost
vault_audit wrg_vault audit ledger inspection
scheduler_task_list, scheduler_tick_dry_run wrg_scheduler inspection

Remote (HTTP, opt-in via env)

Tool Upstream
site_health, site_get, site_post Company site API (WRG_SITE_BASE_URL)
pulseboard_health, pulseboard_list_repos, pulseboard_add_repo, pulseboard_delete_repo, pulseboard_get_pulse pulseboard dashboard (WRG_PULSEBOARD_BASE_URL)

Remote tools return {"ok": false, "error": "httpx not installed — remote tools unavailable"} when the [remote] extra is not installed.

research_motor HTTP API tools

Start the research_motor API separately, then point the MCP server at it:

cd apps/research_motor
pip install -e ".[api]"
set RESEARCH_MOTOR_API_KEY=replace-me
research-motor serve --host 127.0.0.1 --port 8080

Configure the MCP server environment:

set WRG_RM_API_BASE_URL=http://127.0.0.1:8080
set WRG_RM_API_KEY=replace-me

Example MCP tool payloads:

{"target": "example.com", "mode": "domain"}
{"scan_id": "sample-scan-abc123"}

Environment

Repo discovery

Variable Default Purpose
WRG_REPO_ROOT auto-detect (walk up until apps/ + CLAUDE.md) Required when installed from wheel outside the monorepo

Mutation gate (default: off)

State-changing tools (memory_set, pipeline_run) refuse to execute unless:

WRG_MCP_ALLOW_MUTATIONS=1

This prevents an MCP client from silently writing memory or launching pipelines on a read-only connection.

Remote service config

Per service (SITE / PULSEBOARD), prefix with WRG_<SERVICE>_:

Variable Default Purpose
*_BASE_URL Enables the service (unset = service disabled)
*_TOKEN Bearer token for Authorization header
*_AUTH_HEADER Authorization Override header name
*_AUTH_SCHEME Bearer Override token scheme
*_SESSION_COOKIE Optional Cookie header
*_EXTRA_HEADERS JSON object of extra headers
*_TIMEOUT_SECONDS WRG_HTTP_TIMEOUT_SECONDS (20.0) Per-request timeout
*_VERIFY_TLS WRG_HTTP_VERIFY_TLS (true) TLS verification

Claude Code / Claude Desktop integration

Add to your MCP client config:

{
  "mcpServers": {
    "wrg": {
      "command": "wrg-mcp-server",
      "args": ["--transport", "stdio"],
      "env": {
        "WRG_REPO_ROOT": "D:\\dev\\WinstonRedGuard",
        "WRG_MCP_ALLOW_MUTATIONS": "0"
      }
    }
  }
}

Architecture

FastMCP server
├── server.py            — tool registration, remote HTTP dispatch
├── config.py            — ServiceConfig / AppConfig from env (frozen dataclasses)
├── http_utils.py        — URL builder, response parser
├── local_tools.py       — subprocess wrappers for WRG CLIs (~20 tools)
└── cli.py               — argparse entry point

Local tools use subprocess.run with stdin=DEVNULL (not asyncio subprocess) — avoids a Windows pipe-blocking deadlock under anyio. Tool dispatch is wrapped in anyio.to_thread.run_sync so the MCP event loop stays responsive.

Tests

pytest -q

Status

Production — 1045 lines, covers every active WRG app, drives the mcp__wrg__* tools visible in connected Claude sessions.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wrg_mcp_server-1.0.2.tar.gz (36.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

wrg_mcp_server-1.0.2-py3-none-any.whl (19.3 kB view details)

Uploaded Python 3

File details

Details for the file wrg_mcp_server-1.0.2.tar.gz.

File metadata

  • Download URL: wrg_mcp_server-1.0.2.tar.gz
  • Upload date:
  • Size: 36.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for wrg_mcp_server-1.0.2.tar.gz
Algorithm Hash digest
SHA256 4cabe27d943af86a51a3e8dd8d4bf250c934b197a0fd0f2501999472c62b9137
MD5 bb1e71ccc74de7b156c1900be44d2bbe
BLAKE2b-256 7bde07db582390e6d7da4eb7a8916b818b8c92ad632594075ac8329cedcc1f6c

See more details on using hashes here.

Provenance

The following attestation bundles were made for wrg_mcp_server-1.0.2.tar.gz:

Publisher: pypi-publish-mcp-server.yml on yakuphanycl/WinstonRedGuard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file wrg_mcp_server-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: wrg_mcp_server-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 19.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for wrg_mcp_server-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 99e8fd9474e705453c319abfed443953a0a55665c7a92159ce0f558ae53ebc6e
MD5 1c14247e06adde26a9bf25f152b4c622
BLAKE2b-256 0b425339a2962991593c443e37a705287cbe82c084d88118752596718de583a3

See more details on using hashes here.

Provenance

The following attestation bundles were made for wrg_mcp_server-1.0.2-py3-none-any.whl:

Publisher: pypi-publish-mcp-server.yml on yakuphanycl/WinstonRedGuard

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page