npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@riskmodels/mcp

v1.0.2

Published

MCP server for RiskModels: decompose US equities into four-bet variance shares with ETF hedge ratios

Readme

RiskModels API MCP Server

NPM package: @riskmodels/mcp

Release note: publish @riskmodels/sdk first, then add the published SDK version as a runtime dependency before publishing this package.

Decompose a US stock into market, sector, subsector, and residual risk — with SPY / sector / subsector ETF hedge ratios. One call, daily history since 2006.

MCP server that exposes RiskModels API inside Claude Desktop, Cursor, Zed, and any other MCP client. Two classes of tools:

  • Discovery tools — list endpoints, read capabilities, fetch response schemas (no API key required).
  • Data tools — fetch daily EOD risk decomposition, metrics snapshots, and portfolio risk reports (API key required).

Data tools return the same numbers the REST API and CLI return — GCP zarr for historical time series, Supabase security_history_latest for the latest snapshot. Data freshness: daily after US market close.


Resources (read-only, no auth)

| URI | Description | |-----|-------------| | riskmodels:///manifest | Agent Protocol manifest. Fetches from RISKMODELS_API_BASE when set; otherwise returns static capabilities. | | riskmodels:///capabilities | Full list of API capabilities (endpoints, parameters, pricing, examples). | | riskmodels:///schemas/list | List of available response schema paths. | | riskmodels:///schemas/{path} | JSON schema for a response (e.g. ticker-returns-v2.json). | | riskmodels:///openapi | OpenAPI 3.x spec (data/openapi.json). | | riskmodels://whitepaper/one-position-four-bets | Live-paper overview for the Medium article. | | riskmodels://whitepaper/chapter/01-core-claim | Short markdown chapter: one position is four bets. | | riskmodels://whitepaper/chapter/02-aapl-vs-nvda | Short markdown chapter for the AAPL vs NVDA comparison. | | riskmodels://whitepaper/chapter/03-hedging | Short markdown chapter for hedge-ratio scaling. | | riskmodels://examples/aapl-nvda-crwd | Short markdown example for a three-name comparison. |

Discovery tools (no auth)

| Tool | Description | |------|-------------| | riskmodels_list_endpoints | List all public API capabilities (id, name, method, endpoint, short description). | | riskmodels_get_capability | Get full capability by id (parameters, pricing, examples). | | riskmodels_get_schema | Get JSON schema by path (e.g. ticker-returns-v2.json). |

Data tools (API key required)

| Tool | Wraps | What it returns | |------|-------|-----------------| | get_l3_decomposition | GET /api/l3-decomposition | Daily EOD hierarchical decomposition (market → sector → subsector → residual) with parallel time-series arrays + L3 hedge ratios. | | get_metrics | GET /api/metrics/{ticker} | Latest snapshot from the _latest table: L1/L2/L3 hedge ratios, ER fractions, volatility, close price, market cap. | | get_portfolio_risk_snapshot | POST /api/portfolio/risk-snapshot | Portfolio variance decomposition (up to 100 positions), optional diversification analytics, Redis-cached per user/portfolio for 1h. | | riskmodels_decompose | POST /api/decompose via @riskmodels/sdk | Single-stock four-bet decomposition with chart_data, suggested_chart, plain_english, and api_call. | | riskmodels_compare | POST /api/batch/analyze via @riskmodels/sdk | Multi-ticker four-layer comparison. Clients should prefer grouped bar charts. | | riskmodels_hedge_position | POST /api/decompose via @riskmodels/sdk | Scales hedge ratios to ETF notionals for a dollar stock position. | | riskmodels_portfolio_decompose | POST /api/portfolio/risk-snapshot via @riskmodels/sdk | Portfolio-level market / sector / subsector / residual decomposition. | | riskmodels_whitepaper_example | @riskmodels/sdk.whitepaperExample() | Chapter text plus the live SDK/API example result. |

Prompts

| Prompt | Description | |--------|-------------| | follow_whitepaper | Reads the short white-paper resources, then runs the live examples in sequence. | | reproduce_aapl_nvda | Compares AAPL and NVDA and asks the client to render grouped chart_data. | | hedge_single_position | Scales hedge ratios to a chosen ticker and dollar position. | | explain_my_portfolio | Collects user holdings and calls riskmodels_portfolio_decompose. |

Whenever a tool response includes chart_data, clients should render the suggested_chart and explain the result in plain English.

Every data-tool response includes a meter envelope so agents can self-throttle:

{
  ...actual data...,
  "_cost_usd": 0.003,
  "_remaining_daily_usd": 4.997,
  "_rate_limit_remaining": 59,
  "_data_as_of": "2026-04-15",
  "_data_source": "zarr"
}

Credentials

The server resolves the API key in this order:

  1. RISKMODELS_API_KEY from the MCP client's env config (explicit override).
  2. apiKey field in ~/.config/riskmodels/config.json (shared with the riskmodels CLI).

Run riskmodels config init once — the CLI's stored key is automatically picked up by the MCP server. No need to duplicate the key in your claude_desktop_config.json.

Base URL resolution: RISKMODELS_API_BASE env → apiBaseUrl in CLI config → https://riskmodels.app default.


Python SDK on PyPI

This MCP server exposes discovery (capabilities, schemas, OpenAPI). For live /metrics, /batch/analyze, /l3-decomposition, and other data routes, call the REST API or install riskmodels-py from PyPI (sdk/README.md).


Setup

cd mcp
npm install
npm run build

This repo includes .cursor/mcp.json pointing at node + mcp/dist/index.js (relative to the RiskModels_API workspace root). After cd mcp && npm ci && npm run build, open RiskModels_API as a folder in Cursor (or add it in a multi-root workspace), then restart Cursor or reload MCP so riskmodels_list_endpoints appears.

Claude Desktop / npx (common mistakes)

  • There is no mcp subcommand on the npm package. The CLI binary is riskmodels. Do not run npx -y riskmodels-cli mcp — that legacy package does not provide the new installer flow.
  • Use one of these:
    • npx -y @riskmodels/mcp — future published stdio package target used by npx riskmodels install.
    • riskmodels mcp-config — prints a ready-to-paste mcpServers block for Claude Desktop (--client claude-desktop) or Cursor. Use riskmodels mcp-config --embed-key only if you want the key in the JSON env block.
    • riskmodels mcp — runs the stdio MCP server (same as node mcp/dist/index.js). Requires mcp/dist/index.js to exist (build mcp/ first), or set RISKMODELS_MCP_SERVER_PATH to that file.
    • node /absolute/path/to/RiskModels_API/mcp/dist/index.js — always works if the build exists.

Hosted endpoint (https://riskmodels.app/api/mcp/sse)

The hosted endpoint implements the MCP Streamable HTTP transport (current SDK spec, successor to legacy SSE+companion-POST). Stateless mode: each POST carries a JSON-RPC 2.0 message and returns the response synchronously. Auth via Authorization: Bearer <key> (primary) or ?api_key=<key> query param (fallback for clients that can't set headers, e.g. EventSource).

Paste into Claude Desktop / Cursor via the mcp-remote proxy:

{
  "mcpServers": {
    "riskmodels": {
      "command": "npx",
      "args": ["mcp-remote", "https://riskmodels.app/api/mcp/sse"],
      "env": { "AUTHORIZATION": "Bearer rm_agent_live_..." }
    }
  }
}

Tool calls bill per-invocation at the downstream REST endpoint (e.g. get_metrics costs the same as GET /metrics/{ticker}). Discovery tools (riskmodels_list_endpoints, etc.) are free.

Stdio remains available for local dev or air-gapped use (see below).

If you configure manually instead, add the server under Cursor Settings → MCP, or use a project file:

{
  "mcpServers": {
    "riskmodels-api": {
      "command": "node",
      "args": ["/absolute/path/to/RiskModels_API/mcp/dist/index.js"]
    }
  }
}

You can also point command at your riskmodels CLI and args at ["mcp"] if the CLI is on PATH and mcp/dist/index.js is discoverable (repo root or RISKMODELS_MCP_SERVER_PATH).

If RiskModels_API is the workspace root, a relative path is enough:

"args": ["mcp/dist/index.js"]

Restart Cursor after editing the config.

Optional: Set RISKMODELS_API_BASE=https://riskmodels.app so the manifest resource fetches the live agent manifest from the API.


Maintenance (for API / repo maintainers)

The MCP server serves static data from mcp/data/. When the live RiskModels API gains new endpoints, changes pricing, or updates response schemas, this data should be updated so Cursor and other MCP clients stay in sync.

What gets updated

  • data/capabilities.json — List of API capabilities (endpoints, methods, parameters, pricing, examples).
  • data/schema-paths.json — List of response schema paths.
  • data/schemas/*.json — JSON Schema files for each response type.
  • data/openapi.json — Optional; can mirror or summarize the repo’s OPENAPI_SPEC.yaml.

How to update

The canonical API and capabilities live in the Risk_Models platform repo. From that repo you can run npm run generate-mcp-data (in riskmodels_com/) to regenerate capabilities.json, schema-paths.json, and schemas/*.json from the app’s lib/agent registry; then copy the updated files into this repo’s mcp/data/. The openapi.json here is a subset of the full OPENAPI_SPEC.yaml and should be updated when new public endpoints are added.

  1. Obtain updated data from the canonical source (Risk_Models) or by hand from the API application’s capabilities and schema registry.
  2. Replace the contents of mcp/data/:
    • capabilities.json
    • schema-paths.json
    • schemas/*.json
    • openapi.json (if used)
  3. If server code changed (e.g. new resources or tools): update mcp/src/index.ts (and any other source files), then run npm run build inside mcp/.
  4. Commit and push so users who clone RiskModels_API get the latest MCP behavior and data.

When to update

  • New public API endpoints or capabilities.
  • Changes to existing endpoints (parameters, pricing, descriptions).
  • New or changed response schemas.
  • OpenAPI spec changes you want reflected in the riskmodels:///openapi resource.

Keeping data/ in sync with the live API after releases or significant API changes ensures the MCP server remains a reliable reference for developers and tools.