MCP server that stops AI agents from overpaying. Drops into Claude Desktop, Cursor, Continue, Windsurf, Zed, ChatGPT desktop, and Gemini CLI to give any agent live fair-market-value lookups, a green/amber/red prepay verdict, and cryptographically-signed (Ed25519) receipts for every x402 / MPP / agentic-payment quote.
Project description
ari-mcp · Python
MCP server for Agentic Rate Indicators. Gives any MCP-aware agent (Claude Desktop, Cursor, Continue, Windsurf, Zed, ChatGPT desktop, Gemini CLI) live fair-market-value lookups, leaderboards, observation history, and signed-receipt verification for x402 + MPP services.
pipx install ari-mcp-server # PyPI package name
ari-mcp install # installed bin is `ari-mcp` (matches the npm command)
Package name vs command name. On PyPI this package is published as
ari-mcp-server(the short nameari-mcpwas rejected as too similar to an existing project). The installed CLI is stillari-mcpso MCP host config blocks are identical to the npm version below.
Functionally identical to ari-mcp on npm. Use whichever you prefer · both expose the same 20 tools, the same JSON shapes, and verify receipts with the same Ed25519 wire format (pinned by cross-language fixture tests).
Why
LLM agents that pay for things need a pricing oracle they can cite, not a number a seller asserts. ARI indexes services that charge over x402 (Coinbase HTTP 402) and MPP (Stripe + Tempo Machine Payments Protocol), tracks observed prices, computes a Fair Market Value with a low/high band, and returns a green/amber/red verdict before any agent pays. Every JSON response is signed with an Ed25519 key and stamped with a citable receipt id, so an agent can refuse to overpay and a human auditor can re-verify any decision weeks later.
Install in 30 seconds
Claude Desktop
~/Library/Application Support/Claude/claude_desktop_config.json (macOS) · %APPDATA%/Claude/claude_desktop_config.json (Windows)
{
"mcpServers": {
"ari": {
"command": "ari-mcp",
"args": []
}
}
}
Cursor
~/.cursor/mcp.json
{
"mcpServers": {
"ari": {
"command": "ari-mcp",
"args": []
}
}
}
Continue, Windsurf, Zed, ChatGPT desktop, Gemini CLI
Run ari-mcp install to print the right config block for each host. Add --client cursor (or any other slug) to print only one.
The 20 tools
The full surface in v0.2.0 · all 20 are wired in both ari-mcp-server (PyPI) and ari-mcp (npm) with byte-identical wire semantics.
Pricing & verdicts
| Tool | What it does |
|---|---|
is_fair_price |
Green/amber/red verdict for a quoted price |
is_fair_price_batch |
Grade up to 50 quotes in one round-trip |
refuse_if_overpriced |
Convenience wrapper to call right before honoring a 402 quote |
prepay_verdict |
Universal Fairness Skill · refuse-to-overpay check that wraps any agent wallet (Coinbase Agent Wallet, AgentCash, ATXP, 1Pay.ing) before settling x402 / MPP |
prepay_verdict_batch |
Same Universal Fairness Skill, applied to up to 50 candidate URLs at once |
get_fmv |
Median + low/high band + sample size for a service (returns strict null when there's no data — never a hallucinated price) |
historical_fmv |
Per-UTC-day median + sample count over the last N days (max 180) |
category_benchmark |
Unweighted median + p10/p90 band across every indexed service in one category |
detect_anomaly |
Flag the latest observation as anomalous when its robust z-score crosses 3 over a 14-day window |
Discovery & routing
| Tool | What it does |
|---|---|
list_services |
Browse or filter the index by protocol, category, or freshness |
get_service |
Full detail row · sources, related services, last observation |
get_leaderboard |
Cheapest, most expensive, biggest movers |
recent_observations |
Raw observed price history for a service |
find_substitutes |
Cheapest indexed peers in the same category, ranked by FMV ascending |
smart_route |
One-call helper that returns the cheapest peer in a category plus a short alternates list |
Receipts & audit
| Tool | What it does |
|---|---|
verify_receipt |
Re-verify a previously issued receipt id (Ed25519, fail-closed) |
get_signed_receipt |
Re-fetch the signed body for a receipt |
why |
Re-fetch a receipt and render the human-readable evidence trail the FMV engine relied on |
Plumbing
| Tool | What it does |
|---|---|
subscribe_alert |
Set up a webhook or email price alert |
mcp_health_ping |
Best-effort heartbeat that bumps last_seen_at on the install row · never blocks, never collects identifying data |
What's new in v0.2.0
- Receipt spec v3 with confidence-tiered verdicts (
high/medium/low). Apayverdict is only demoted toabstainon an explicitlowconfidence — older v1/v2 routes verify unchanged. - Honest-null contract ·
get_fmvreturns a fully null-shapedfairPriceblock instead of a guessed number when a service has no observations, andrefuse_if_overpricedreturns{ ok: true, reason: "no_data" }instead of pretending. Python integration tests for the no-data path nowskipcleanly (not fail) when the configured base URL doesn't carry the fixture. - Cross-language parity · 83 Python tests + 74 TS unit + 15 TS integration tests, all pinned to a shared
SIGNED_HEADER_NAMESorder so the wire format can't drift between runtimes.
Why signed receipts
An agent that pays for things needs to trust two parties at once · the seller quoting a price, and any oracle telling it whether that price is fair. ARI signs every response with an Ed25519 key whose public half ships embedded in this client at build time. There is no first-call trust window · the very first request a fresh install makes is verified against the pinned key id ari-aedbd75d43c8, and any mismatch fails closed with a clear error. If the publisher rotates keys, the new id is added to an accepted-id list one release before the old one is removed, so stale installs keep verifying correctly until they upgrade.
Pass --insecure-skip-pin to accept any key id the server returns (use this only during a rotation). Pass --insecure-skip-verify to skip Ed25519 verification entirely (test setups only).
Self-hosting
ari-mcp --api-base-url https://ari.example.corp
When the base URL is overridden, the client falls back to fetching the publisher key from <base>/.well-known/ari-pubkey.pem on first call · a single trust-on-first-use step that the operator opted in to by choosing the mirror.
CLI reference
ari-mcp [serve] Start the MCP stdio server (default)
ari-mcp install Print install snippets for popular MCP hosts
ari-mcp ping Send a one-shot opt-in install ping
ari-mcp --version Print the server version
OPTIONS
--api-base-url URL Override the ARI API base URL
--api-key KEY Bearer token for paid tiers (optional)
--transport stdio|http Transport for `serve`. Default: stdio
--port N HTTP port (with --transport http). Default: 8765
--host HOST HTTP bind host. Default: 127.0.0.1
--insecure-skip-verify Skip Ed25519 receipt verification
--insecure-skip-pin Skip the build-time key-id pin (allow rotation)
Documentation
- Hosted docs · agentrateindicators.com/docs/mcp
- Receipt format · github.com/Antmanbuilds/ARI/blob/main/spec/signed-receipts.md
- OpenAPI · github.com/Antmanbuilds/ARI/blob/main/spec/openapi.yaml
Framework adapters
ari-mcp exposes its 20 tools as plain Tool dataclasses in
ari_mcp.tools.TOOLS so you can wire them into any Python agent framework
without subclassing. Pick the snippet that matches your stack.
Pydantic AI
from pydantic_ai import Agent, Tool
from ari_mcp.client import AriClient
from ari_mcp.tools import TOOLS
client = AriClient(base_url="https://api.agentrateindicators.com")
def _wrap(t):
async def _run(**kwargs):
return t.run(kwargs, client)
_run.__name__ = t.name
_run.__doc__ = t.description
return Tool(_run, name=t.name, description=t.description)
agent = Agent("openai:gpt-4o", tools=[_wrap(t) for t in TOOLS])
LangGraph (LangChain Python)
from langchain_core.tools import StructuredTool
from ari_mcp.client import AriClient
from ari_mcp.tools import TOOLS
client = AriClient(base_url="https://api.agentrateindicators.com")
ari_langchain_tools = [
StructuredTool.from_function(
func=(lambda t=t: lambda **kw: t.run(kw, client))(),
name=t.name,
description=t.description,
args_schema=t.input_model,
)
for t in TOOLS
]
LlamaIndex (Python)
from llama_index.core.tools import FunctionTool
from ari_mcp.client import AriClient
from ari_mcp.tools import TOOLS
client = AriClient(base_url="https://api.agentrateindicators.com")
ari_llama_tools = [
FunctionTool.from_defaults(
fn=(lambda t=t: lambda **kw: t.run(kw, client))(),
name=t.name,
description=t.description,
fn_schema=t.input_model,
)
for t in TOOLS
]
Vercel AI SDK (TS-side bridge)
The Vercel AI SDK runs in Node/Edge. From Python, expose the MCP server over stdio so a TS host can consume it as a remote MCP server:
ari-mcp serve --transport stdio
import { experimental_createMCPClient as createMCPClient } from "ai";
const mcp = await createMCPClient({ transport: { type: "stdio", command: "ari-mcp", args: ["serve"] } });
const tools = await mcp.tools();
License
Apache-2.0 · contact hello@agenticrates.org.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ari_mcp_server-0.2.0.tar.gz.
File metadata
- Download URL: ari_mcp_server-0.2.0.tar.gz
- Upload date:
- Size: 49.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cfafbf8a09726a65f0681930e0dba6eff6da9a29123e5d6e8f1c49262f60c51a
|
|
| MD5 |
b8cd7279795680f44f80c9aec2c6f1d2
|
|
| BLAKE2b-256 |
b3568c3e93003153887d5569cf2fe5433e5d1f9dec4adf6138a0817385d1bdbb
|
File details
Details for the file ari_mcp_server-0.2.0-py3-none-any.whl.
File metadata
- Download URL: ari_mcp_server-0.2.0-py3-none-any.whl
- Upload date:
- Size: 38.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e7e6176d11c10f774ec1c460ffdd34e429b9af185a57f37153740eec90fdeb2b
|
|
| MD5 |
863a120fa971bb45f6513e1b20c015d0
|
|
| BLAKE2b-256 |
3835303d86b9329cf2f139a4367dd3faf86a344bb72044fa3e21348cc30a624a
|