Skip to main content
ClaudeWave

Add a responsible-AI safety layer to any agent in one URL. Remote MCP server: 8-dimension evaluation, prompt-injection detection, tool-call gating, PII scanning, and India DPDP compliance.

MCP ServersOfficial Registry0 stars0 forksPythonMITUpdated today
ClaudeWave Trust Score
87/100
Trusted
Passed
  • Open-source license (MIT)
  • Actively maintained (<30d)
  • Clear description
  • Topics declared
Last scanned: 6/11/2026
Install in Claude Code / Claude Desktop
Method: pip / Python · -r
Claude Code CLI
claude mcp add rail-score-mcp -- python -m -r
claude_desktop_config.json (Claude Desktop)
{
  "mcpServers": {
    "rail-score-mcp": {
      "command": "python",
      "args": ["-m", "venv"]
    }
  }
}
1. Run the command above in your terminal (Claude Code), or paste the JSON config into claude_desktop_config.json (Claude Desktop).
2. Replace any <placeholder> values with your API keys or paths.
3. Restart Claude. The MCP server and its tools appear automatically.
💡 Install first: pip install -r
Use cases

MCP Servers overview

# RAIL Score MCP Server

Add a responsible-AI safety layer to any agent in one URL.

A remote, hosted [Model Context Protocol](https://modelcontextprotocol.io) server
that exposes RAIL Score's evaluation, agent-guardrail, and India DPDP compliance
capabilities to any MCP client — Claude, ChatGPT, Cursor, Copilot, Replit Agent,
LangGraph, CrewAI, or a custom stack — with zero SDK integration.

```
https://mcp.responsibleailabs.ai/mcp
```

The server is a thin, hardened gateway in front of the existing REST API at
`api.responsibleailabs.ai/railscore/v1/`. It reimplements no scoring logic: it
validates the caller, shapes requests and responses for agent ergonomics, and
forwards to the engine. Credits, tenancy, and rate limits are identical via MCP
and REST.

## Quickstart

You need a RAIL API key (`rail_...`) from the [dashboard](https://responsibleailabs.ai/dashboard).

**Claude Code**

```bash
claude mcp add --transport http rail https://mcp.responsibleailabs.ai/mcp \
  --header "Authorization: Bearer ${RAIL_API_KEY}"
```

**Cursor / Windsurf** (`.cursor/mcp.json`)

```json
{
  "mcpServers": {
    "rail": {
      "url": "https://mcp.responsibleailabs.ai/mcp",
      "headers": { "Authorization": "Bearer rail_YOUR_KEY" }
    }
  }
}
```

**Claude.ai / Desktop** — Settings → Connectors → Add custom connector → URL
`https://mcp.responsibleailabs.ai/mcp`, then paste your `rail_` key.

More clients (OpenAI Responses API, LangGraph, Replit) are documented at
[docs.responsibleailabs.ai/mcp](https://docs.responsibleailabs.ai/mcp/connect).

## Tools

Nine tools, all `rail_`-prefixed. Descriptions state cost, latency, and when not
to use a tool, because agents select tools from descriptions alone.

| Tool | Purpose | Credits |
|---|---|---|
| `rail_evaluate` | Score content across the 8 RAIL dimensions (optional `policy` enforcement) | 1.0 basic / 3.0 deep |
| `rail_check_compliance` | Check against gdpr, ccpa, hipaa, eu_ai_act, india_dpdp, india_ai_gov | 5–10 |
| `rail_detect_injection` | Detect prompt injection in untrusted text | 0.5 |
| `rail_evaluate_tool_call` | Allow/warn/block a tool call before it runs | 1.5–3.0 |
| `rail_scan_tool_result` | Scan a tool's output for PII + injection, return redacted text | 0.5–1.0 |
| `rail_safe_regenerate` | Iteratively regenerate content until it passes (slow) | 1–9 |
| `rail_dpdp_scan` | Scan for Indian personal data under the DPDP Act 2023 | 0.5 |
| `rail_dpdp_gate` | Real-time DPDP processing gate (allow/block/require_action) | 0.3 |
| `rail_dpdp_compliance` | DPDP workflow: emit, require, evidence, session, timers | varies |

Three read-only **resources** (free, zero credits): `rail://framework/dimensions`,
`rail://account/capabilities`, and `rail://framework/policy-schema` (the JSON
Schema for the `policy` parameter).

## Policy enforcement

`rail_evaluate` accepts an optional `policy` of per-dimension threshold rules and
returns a `policy_outcome`. A rule fires when a dimension scores **below** its
threshold; `action` is the most severe fired action (`block` > `flag` > `warn` >
`allow`), mirroring the `rail-score-sdk` `Policy`/`Rule` shape.

```json
{ "rules": [
  { "dimension": "safety",   "threshold": 7.0, "action": "block" },
  { "dimension": "fairness", "threshold": 6.0, "action": "flag" }
] }
```

Precedence: if the API key's **application has a dashboard policy enforced**, that
takes precedence (`policy_outcome.source: "application"`); otherwise the request
`policy` is applied in-gateway (`source: "request"`). No extra credits.

## The guarded agent loop

The canonical use is to wrap an agent's reasoning end to end:

1. `rail_detect_injection` on untrusted input before acting on it
2. `rail_evaluate_tool_call` before executing any tool call (block = hard stop)
3. `rail_scan_tool_result` on the tool's output (prefer the redacted text)
4. `rail_evaluate` (deep) on the draft answer, or `rail_safe_regenerate` to fix it
5. `rail_dpdp_scan` (mask) on anything leaving the boundary in India deployments

## Security model

A safety product that is itself unsafe is a credibility failure. The launch
blockers (enforced and regression-tested):

- **Verdicts are structured data, never advisory prose** an agent can ignore.
- **No reflection of analyzed content.** Tools return verdicts, scores, spans,
  and masked excerpts — never the raw analyzed text (second-order injection).
- **No raw PII.** Detection returns masked values and offsets only.
- **Tenant isolation by construction.** Identity comes from the validated key in
  the auth middleware, never from a tool parameter.
- **No token passthrough** in phase 2: client tokens are validated and dropped;
  downstream calls use the gateway's service credential. In phase 1 the bearer
  `rail_` key *is* the customer's RAIL credential, so it is forwarded upstream to
  preserve per-tenant credits and isolation.
- **Input caps, timeouts, rate limits, and audit logging** (no content bodies).

See `tests/test_no_reflection.py` and `tests/test_pii_masking.py` — these run as
a hard CI gate.

## Architecture

- **Transport:** Streamable HTTP only, single `/mcp` endpoint (SSE is sunset).
- **State:** `stateless_http=True`, `json_response=True` — scales horizontally
  behind a normal load balancer; aligns with the MCP 2026-07-28 stateless core.
- **Auth (phase 1):** `rail_` key via `Authorization: Bearer rail_...` **or**
  `X-API-Key: rail_...` (the latter is gateway-friendly — no Bearer prefix),
  validated once against `POST /verify` (cached 5 min) by
  `auth.RailKeyMiddleware`, then bound to the request context.
- **Discovery:** `GET /.well-known/mcp/server-card.json` (public) lets registries
  that scan behind an auth wall (e.g. Smithery) enumerate the tools without a key.
- **Auth (phase 2):** OAuth 2.1 resource server (RFC 9728 metadata, RFC 8707
  audience binding) via the SDK's `TokenVerifier`.

```
rail_client.py   thin httpx client to api.responsibleailabs.ai (forwards key, propagates X-Request-ID)
auth.py          RailKeyMiddleware: validate rail_ keys, bind tenant
request_context.py  per-request ContextVars (key, tenant, request id)
server.py        FastMCP app: 9 tools + 3 resources + landing (/) + /health + server-card
server.json      official MCP registry manifest (ai.responsibleailabs/rail-score)
```

## Local development

```bash
python -m venv .venv && source .venv/bin/activate
pip install -r requirements-dev.txt
ruff check . && pytest          # unit + safety regression tests
RAIL_API_BASE=https://api.responsibleailabs.ai python server.py   # serves on :8080
```

Protocol smoke test against a running server (needs a real key):

```bash
npx @modelcontextprotocol/inspector --cli \
  http://localhost:8080/mcp --method tools/list \
  --header "Authorization: Bearer ${RAIL_API_KEY}"
```

### Configuration

| Env var | Default | Purpose |
|---|---|---|
| `RAIL_API_BASE` | `https://api.responsibleailabs.ai` | Upstream REST API |
| `MCP_PORT` | `8080` | Bind port |
| `RAIL_UPSTREAM_TIMEOUT` | `60` | Upstream call timeout (s) |
| `RAIL_KEY_CACHE_TTL` | `300` | Validated-key cache TTL (s) |

## Hosting

Responsible AI Labs operates the hosted server at
`https://mcp.responsibleailabs.ai/mcp` — for almost everyone, just connect to
that URL; you do not need to run anything.

To self-host, build the image and run it anywhere that serves HTTP; point it at
the public REST API with `RAIL_API_BASE` (its default). No secrets are required:
the customer's RAIL key arrives on each request.

```bash
docker build -t rail-score-mcp .
docker run -p 8080:8080 -e RAIL_API_BASE=https://api.responsibleailabs.ai rail-score-mcp
```

## Registry

Published to the official MCP registry as `ai.responsibleailabs/rail-score` via
`server.json` and the `mcp-publisher` CLI (DNS-authenticated `responsibleailabs.ai`
namespace); a tagged GitHub release runs the `publish-registry` job automatically.

Third-party directories (Smithery, Glama, PulseMCP, mcp.so) index the repository
and the official registry independently. Each is claimed and refreshed
separately rather than syncing automatically, so listings can lag a release.
agentai-complianceai-governanceai-safetydpdpguardrailsllmmcpmodel-context-protocolprompt-injectionred-teamingresponsible-ai

What people ask about rail-score-mcp

What is Responsible-AI-Labs/rail-score-mcp?

+

Responsible-AI-Labs/rail-score-mcp is mcp servers for the Claude AI ecosystem. Add a responsible-AI safety layer to any agent in one URL. Remote MCP server: 8-dimension evaluation, prompt-injection detection, tool-call gating, PII scanning, and India DPDP compliance. It has 0 GitHub stars and was last updated today.

How do I install rail-score-mcp?

+

You can install rail-score-mcp by cloning the repository (https://github.com/Responsible-AI-Labs/rail-score-mcp) or following the README instructions on GitHub. ClaudeWave also provides quick install blocks on this page.

Is Responsible-AI-Labs/rail-score-mcp safe to use?

+

Our security agent has analyzed Responsible-AI-Labs/rail-score-mcp and assigned a Trust Score of 87/100 (tier: Trusted). See the full breakdown of passed checks and flags on this page.

Who maintains Responsible-AI-Labs/rail-score-mcp?

+

Responsible-AI-Labs/rail-score-mcp is maintained by Responsible-AI-Labs. The last recorded GitHub activity is from today, with 0 open issues.

Are there alternatives to rail-score-mcp?

+

Yes. On ClaudeWave you can browse similar mcp servers at /categories/mcp, sorted by popularity or recent activity.

Deploy rail-score-mcp to your cloud

Ship this repo to production in minutes. Each platform spins up its own environment with editable env vars.

Maintain this repo? Add a badge to your README

Drop the badge into your GitHub README to show it's tracked on ClaudeWave. Each badge links back to this page and reflects the live Trust Score.

Featured on ClaudeWave: Responsible-AI-Labs/rail-score-mcp
[![Featured on ClaudeWave](https://claudewave.com/api/badge/responsible-ai-labs-rail-score-mcp)](https://claudewave.com/repo/responsible-ai-labs-rail-score-mcp)
<a href="https://claudewave.com/repo/responsible-ai-labs-rail-score-mcp"><img src="https://claudewave.com/api/badge/responsible-ai-labs-rail-score-mcp" alt="Featured on ClaudeWave: Responsible-AI-Labs/rail-score-mcp" width="320" height="64" /></a>

More MCP Servers

rail-score-mcp alternatives