DEV Community

connerlambden
connerlambden

Posted on

MCP servers are just REST APIs in a polite wrapper - here's 5 lines of Python

If you've been watching the MCP (Model Context Protocol) ecosystem from the sidelines, here's a quietly important detail: a lot of MCP servers are also just plain REST APIs underneath. The MCP layer is a polite wrapper that says "Claude, here are tools you can call." But the underlying HTTP endpoints are right there, ready to be called from requests.get(...) like any other JSON API.

That matters because the most interesting MCP servers are useful even if you've never opened Claude Desktop or Cursor. You can drop them into a Streamlit app, a Jupyter notebook, a Lambda function, a Discord bot, an Airflow DAG, or a cron job. The MCP integration is gravy on top.

I'll show this with a concrete example: pulling per-symbol ML option fair values and 31-dimension news-bias scores into pandas in 5 lines.

The setup

I run Helium MCP, which started as an MCP server and recently grew a plain REST surface. Both speak the same data:

  • Per-symbol ML options pricing - predicted fair value, probability ITM, Greeks
  • 31-dimension news-bias scoring across 3.2M articles and 5,000 sources
  • Real-time market data, top trading strategies, semantic meme search, source bias profiles

The MCP endpoint is https://heliumtrades.com/mcp. The REST endpoints live under https://heliumtrades.com/ with paths like /mcp_search/, /mcp_option_price/, /mcp_ticker/, /mcp_url_bias/. 50 free queries per IP. No signup, no API key needed for the free tier.

Five lines of Python

import requests

r = requests.get(
    "https://heliumtrades.com/mcp_search/",
    params={"q": "apple earnings", "limit": 3},
    timeout=30,
)
print(r.json())
Enter fullscreen mode Exit fullscreen mode

You get back a JSON list of articles with full bias scoring across all 31 dimensions per article: credibility, sensationalism, overconfidence, opinion_vs_fact, scapegoating, ai_authorship_probability, covering_responses, oversimplification, and 23 more.

Loading into pandas

This is where it gets fun. The JSON is already flat enough that pandas just works:

import pandas as pd, requests

resp = requests.get(
    "https://heliumtrades.com/mcp_search/",
    params={"q": "federal reserve", "limit": 50},
)
df = pd.json_normalize(resp.json())
print(df[["source", "credibility", "sensationalism", "opinion_vs_fact"]].head())
Enter fullscreen mode Exit fullscreen mode

Now you can do everything pandas does: groupby source, compute mean credibility, plot a credibility-vs-sensationalism scatter, filter to high-AI-authorship-probability articles, etc.

Option fair values, also 5 lines

import requests

r = requests.get(
    "https://heliumtrades.com/mcp_option_price/",
    params={
        "symbol": "AAPL",
        "strike": 200,
        "expiration": "2026-06-19",
        "option_type": "call",
    },
)
print(r.json())
# {'predicted_price': 20.64, 'prob_itm': 0.52, 'delta': 0.55, 'gamma': 0.02, 'vega': 0.41, ...}
Enter fullscreen mode Exit fullscreen mode

You get back a model-derived fair value and prob_ITM next to market price. The diff between the two is a (testable, scorable) prediction.

A small Streamlit app

Once the API returns JSON, building a Streamlit app is essentially a wrapper exercise:

import streamlit as st, requests, pandas as pd

q = st.text_input("Search query", "tariffs")
limit = st.slider("Results", 1, 50, 10)

if st.button("Go"):
    resp = requests.get(
        "https://heliumtrades.com/mcp_search/",
        params={"q": q, "limit": limit},
    )
    df = pd.json_normalize(resp.json())
    st.dataframe(df[["title", "source", "credibility", "sensationalism", "ai_authorship_probability"]])
    st.bar_chart(df.groupby("source")["credibility"].mean())
Enter fullscreen mode Exit fullscreen mode

This is the smallest realistic media-bias dashboard I've ever written. It's about 12 lines.

Where this fits in your stack

The point isn't that this one API is special. The point is that MCP servers with REST surfaces are a quietly powerful new class of API. They are:

  • LLM-native by design - built so an LLM can call them without a custom integration
  • Schema-rich - the MCP tool spec doubles as auto-generated API documentation
  • Free-tiered aggressively - because the operator wants discoverability in LLM clients
  • Composable from anything HTTP - Python, JS, curl, Go, n8n, Zapier, Make

If you're a data scientist who's never installed Claude Desktop and never wants to: that's fine. Treat MCP servers as a directory of unusually well-curated free REST APIs and start with the ones that solve a problem you already have.

For finance and news intelligence specifically, the full Helium MCP REST endpoint list is:

Endpoint Purpose Params
/mcp_search/ News search across 3.2M articles q, limit
/mcp_balanced_search/ Multi-perspective news synthesis q, limit
/mcp_source_bias/ 31-dim bias profile for one source source
/mcp_url_bias/ 31-dim bias profile for one article URL url
/mcp_all_source_biases/ All scored sources -
/mcp_ticker/ Real-time market data for a symbol ticker
/mcp_option_price/ ML option fair value + Greeks symbol, strike, expiration, option_type
/mcp_historical_options/ Full options chain with ML fair values symbol, date
/mcp_top_strategies/ AI-ranked options strategies limit, sort
/mcp_meme_search/ Semantic meme search q, limit

The MCP server config (for Cursor / Claude Desktop / Windsurf) is:

{ "mcpServers": { "helium": { "url": "https://heliumtrades.com/mcp" } } }
Enter fullscreen mode Exit fullscreen mode

But honestly - if Python is your thing - just open a notebook and requests.get. The whole point of a public REST surface is that you don't have to care about anything else.

Source, schema, full tool spec: github.com/connerlambden/helium-mcp. Page: heliumtrades.com/mcp-page.

If you build something with it, I'd love to see it. Open an issue, or send a notebook - happy to feature good demos.

Top comments (0)