plugins/data-providers/skills/funda-data/SKILL.md
Query Funda AI financial data via two surfaces: the MCP server at https://funda.ai/api/mcp for analyst-grade research synthesis (DCF, comps, earnings previews/recaps, sector deep-dives, SEC filings, transcripts, supply-chain mapping, ownership flow, macro framing) via the agent_chat tool — OR the REST API at https://api.funda.ai/v1 with FUNDA_API_KEY for raw data (real-time quotes, intraday candles, EOD prices, financial statements, options chains/greeks/GEX, supply-chain KG, social sentiment, news, calendars, FRED, ESG, congressional trades, AI hiring signals). Triggers: "funda", "funda.ai", real-time quote, stock price, intraday, balance sheet, income statement, options chain, DCF, comps, earnings preview/recap, analyst estimates, 10-K/10-Q/8-K, transcript, ownership flow, gamma exposure, supply chain, sector deep-dive, congressional trades, FRED. Prefer MCP for synthesis/analysis questions; use REST for raw structured data the MCP declines.
npx skillsauth add himself65/finance-skills funda-dataInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Funda AI exposes two complementary surfaces backed by the same data:
| Surface | Best for | Auth | Output |
|---|---|---|---|
| MCP agent_chat at https://funda.ai/api/mcp | Research, analysis, synthesis | OAuth (auto via claude mcp add) | Synthesized text with disclaimer |
| REST /v1/* at https://api.funda.ai | Raw structured data | FUNDA_API_KEY Bearer | JSON |
Both require an active Funda AI subscription.
| User wants | Surface | |---|---| | DCF / comps walkthrough, sector view, transcript synthesis, company primer | MCP | | Earnings preview/recap with judgment, beat-miss decomposition, narrative framing | MCP | | Real-time or intraday quote, EOD price history | REST | | Raw options chain snapshot, greeks, GEX time series | REST | | Specific line item from a financial statement (single number, JSON) | REST | | 13F filings, insider trades, congressional trades as rows | REST | | News with structured sentiment / event timeline (JSON) | REST | | Bulk dataset downloads | REST | | AI-company hiring signals (OpenAI, Anthropic, Google, xAI) | REST |
Default to MCP for ambiguous research-style questions. Use REST when the user wants machine-readable structured data — or when the MCP refuses (real-time prices, raw quotes).
The MCP also refuses buy/sell calls, price targets, personalized portfolio advice, tax/legal advice, and trade execution. Those are out of scope for both surfaces — decline politely and don't fall through to REST hoping for a different answer.
!`claude mcp list 2>/dev/null | grep -iE "^funda:" || echo "FUNDA_MCP_NOT_CONNECTED"`
funda: → registered. The tool is callable as mcp__funda__agent_chat. Continue.FUNDA_MCP_NOT_CONNECTED → ask the user to install:
claude mcp add --transport http funda https://funda.ai/api/mcp
A browser tab opens for OAuth approval (1-hour token + 30-day refresh, auto-managed). The Claude Code session may need to be restarted before the tool registers.agent_chat is a fresh research turn with no cross-call memory — bake
the ticker, time horizon, and assumptions into the question text itself.
| User wants | Question shape | |---|---| | Earnings preview | "Preview MSFT's Q3 print Thursday — segment trends, where consensus is aggressive/conservative, beat/miss pattern." | | Earnings recap | "Walk through NVDA Q2: beat/miss by segment, guide vs consensus, transcript Q&A on data-center demand." | | Sector deep-dive | "Summarize the 2026 hyperscaler capex cycle — spending tiers by name, supplier exposure, gross-margin implications." | | Supply chain | "Map TSMC's customer concentration and N2 ramp risks — top three exposures by revenue." | | Filing summary | "Diff the new risk factors in PLTR's latest 10-K versus the prior year." | | DCF | "Walk through a DCF for NVDA assuming 25% data-center growth, 10% terminal margin, 9% WACC — surface the sensitivity table." | | Macro | "Where in the Dalio long-term debt cycle is the US, and what does that imply for duration positioning?" | | Ownership | "Has institutional ownership of CRWD shifted in the latest 13F filings — net buyers vs sellers?" |
If the user gave only a ticker, ask one clarifying question to scope the turn (preview? recap? primer? DCF?) before calling — vague questions burn a turn and return vague answers.
If the user is following up on a prior Funda response, quote the relevant paragraph back inside the new question; the agent has no memory of prior calls.
For more example questions per topic, see references/research-topics.md.
mcp__funda__agent_chat(question: "<full research question>")
Typical run is 15–60 seconds; the server streams progress notifications throughout, so the client doesn't time out.
Response shape:
content[0].text — answer prefixed with [Funda research output — fundamental analysis, informational only…]. Keep the prefix._meta["funda.io/conversation_id"] — UUID. The in-app history page is https://funda.ai/agent-chat?c=<id> (the /agent-chat route redirects to /agent-chat-v2?c=<id>)._meta["funda.io/timed_out"] — true if the agent hit its run budget. Answer is partial; offer to retry with a tighter scope.If the call returns 403 subscription_required, the MCP is registered
but the account isn't subscribed — direct the user to https://funda.ai
to activate.
Each call costs a research turn. Don't speculatively re-call with a rephrased question if the first answer was reasonable.
The skill resolves FUNDA_API_KEY in this order:
FUNDA_API_KEY environment variableFUNDA_API_KEY in .env in the current directoryFUNDA_API_KEY in .env at the git repo root (so a worktree inherits the key from the main checkout)!`if [ -n "$FUNDA_API_KEY" ]; then echo "KEY_FROM_ENV_VAR"; elif [ -f .env ] && grep -qE "^FUNDA_API_KEY=" .env; then echo "KEY_FROM_LOCAL_DOTENV:$(pwd)/.env"; else GIT_COMMON=$(git rev-parse --path-format=absolute --git-common-dir 2>/dev/null); if [ -n "$GIT_COMMON" ]; then ROOT=$(dirname "$GIT_COMMON"); if [ -f "$ROOT/.env" ] && grep -qE "^FUNDA_API_KEY=" "$ROOT/.env"; then echo "KEY_FROM_ROOT_DOTENV:$ROOT/.env"; else echo "KEY_NOT_SET"; fi; else echo "KEY_NOT_SET"; fi; fi`
Then act on the result:
KEY_FROM_ENV_VAR — use $FUNDA_API_KEY directly in curl calls.KEY_FROM_LOCAL_DOTENV:<path> / KEY_FROM_ROOT_DOTENV:<path> — load once before calling:
export FUNDA_API_KEY=$(grep -E "^FUNDA_API_KEY=" <path> | head -1 | cut -d= -f2- | sed 's/^["'\'']//;s/["'\'']$//')
KEY_NOT_SET — ask the user for their key. They can either export FUNDA_API_KEY="..." or add FUNDA_API_KEY=... to .env at the repo root (preferred for worktrees).Match the user's request to a category and read the corresponding reference file for full parameters and response schemas.
| Category | Endpoint family | Reference |
|---|---|---|
| Real-time / batch / aftermarket quotes | /v1/quotes?type=... | references/market-data.md |
| Historical EOD, intraday candles, technical indicators | /v1/stock-price, /v1/charts | references/market-data.md |
| Commodity / forex / crypto quotes | /v1/quotes?type=commodity-quotes | references/market-data.md |
| Income / balance / cash flow / metrics / ratios | /v1/financial-statements | references/fundamentals.md |
| Company profile, peers, shares float, search, screener, list | /v1/company-profile, /v1/company-details, /v1/search, /v1/companies | references/fundamentals.md |
| Analyst estimates, price targets, grades, DCF, ratings | /v1/analyst?type=... | references/fundamentals.md |
| Options chain, greeks, GEX, IV, max pain, flow, screener | /v1/options/... | references/options.md |
| Supply-chain KG: suppliers, customers, competitors, partners | /v1/supply-chain/... | references/supply-chain.md |
| Twitter, Reddit, Polymarket, government trading, ownership | /v1/twitter-posts, /v1/reddit-posts, /v1/polymarket/..., /v1/government-trading, /v1/ownership | references/alternative-data.md |
| AI-enriched news + aggregated sentiment + event timeline | /v1/news/ticker, /v1/news/timeline, /v1/news/sentiment | references/news-enriched.md |
| SEC filings, earnings/podcast transcripts, research reports | /v1/sec-filings, /v1/transcripts, /v1/investment-research-reports | references/filings-transcripts.md |
| Earnings / dividend / IPO / splits / economic calendar | /v1/calendar?type=... | references/calendar-economics.md |
| Treasury rates, GDP/CPI indicators, FRED, risk premium | /v1/economics, /v1/fred | references/calendar-economics.md |
| Stock news, gainers/losers, ETF holdings, ESG, COT, bulk, market hours | /v1/news, /v1/market-performance, /v1/funds, /v1/esg, /v1/cot-report, /v1/bulk, /v1/market-hours | references/other-data.md |
| AI-company hiring signals (OpenAI, Anthropic, Google, xAI, Mercor, SurgeAI) | /v1/recruit-... | references/recruit.md |
| Claude API proxy via Bedrock | /v1/claude/v1/messages | references/claude-proxy.md |
curl -s -H "Authorization: Bearer $FUNDA_API_KEY" \
"https://api.funda.ai/v1/<endpoint>?<params>" | python3 -m json.tool
All responses are {"code": "0", "message": "", "data": ...}. A non-zero
code is an error — read message.
List endpoints paginate: {"items": [...], "page": 0, "page_size": 20, "next_page": 1, "total_count": N}. Pages are 0-based; next_page is -1 when exhausted.
For broad ticker overviews ("tell me about AAPL"), combine a few REST
calls: /v1/company-profile for sector/CEO/mcap/price + /v1/financial-statements?type=key-metrics-ttm + /v1/analyst?type=price-target-summary.
https://funda.ai/agent-chat?c={conversation_id} so the user can inspect the agent's full timeline.$2.8T). Use tables for comparative data; summarize trends rather than dumping time series.MCP path:
references/research-topics.md — categorized example questions and tips for framing agent_chat queries.REST path:
references/market-data.md — quotes, historical prices, charts, technical indicatorsreferences/fundamentals.md — financial statements, company profile/details, search/screener, analyst, companies listreferences/options.md — chains, greeks, GEX, flow, IV, screener, contract-level datareferences/supply-chain.md — supply-chain KG, relationships, graph traversalreferences/alternative-data.md — Twitter, Reddit, Polymarket, government trading, ownershipreferences/news-enriched.md — AI-enriched news, event timeline, aggregated sentimentreferences/filings-transcripts.md — SEC filings, earnings/podcast transcripts, research reportsreferences/calendar-economics.md — calendars, economics, treasury, FREDreferences/other-data.md — news, market performance, funds, ESG, COT, bulk, market hoursreferences/recruit.md — AI-company hiring signals, JD classifications, product clusters, launch probabilitiesreferences/claude-proxy.md — Claude API proxy via Bedrocktools
Read Hyperliquid (app.hyperliquid.xyz) perp + spot market data via opencli (read-only, public info API). Use whenever the user wants Hyperliquid perpetual or spot markets, mark/oracle/mid prices, 24h change, funding rates (hourly or annualized APR), open interest, volume, the L2 order book, OHLCV candles, historical funding, or a cross-venue funding comparison (Hyperliquid vs Binance vs Bybit) for funding arbitrage. Triggers: "Hyperliquid funding for BTC", "HL perp markets", "funding on BTC perp", "Hyperliquid order book", "HL open interest", "funding arb Hyperliquid vs Binance", "Hyperliquid candles for SOL", "Hyperliquid spot markets", "PURR price on Hyperliquid", "hyperliquid", "hyperliquid.xyz", "HL DEX". READ-ONLY market data — no account, order, or trade operations.
tools
Generic read-only fallback for any source opencli covers but this repo has no dedicated reader for — Yahoo Finance, Bloomberg, Reuters, Barchart, Eastmoney, Xueqiu, Sinafinance, Reddit, HackerNews, Substack, Medium, Weibo, Bilibili, Xiaohongshu, Zhihu, arXiv, Google Scholar, Apple Podcasts, Xiaoyuzhou, Spotify, YouTube, Weixin, Amazon, and more. Triggers: "use opencli to read", "grab the frontpage from hackernews", "read reddit r/wallstreetbets", "fetch Eastmoney hot stocks", "pull Xueqiu feed", "get Bloomberg markets headlines", "search arXiv for", any request to read from a site where a specialized skill does not exist but opencli does. FALLBACK — prefer twitter-reader, linkedin-reader, discord-reader, telegram-reader, or yc-reader when the source matches. READ-ONLY — never invoke write operations.
development
Look up Y Combinator companies, batches, and startup ecosystem data using the yc-oss API (read-only). Use this skill whenever the user wants to research YC-backed startups, find companies in a specific batch or industry, check which YC companies are hiring, explore top YC companies, or analyze startup trends by sector or tag. Triggers include: "YC companies in fintech", "who's in the latest YC batch", "YC startups hiring", "top Y Combinator companies", "find YC companies tagged AI", "W25 batch", "S24 companies", "YC stats", "Y Combinator portfolio", "startup research", "which YC companies do X", "venture research on YC", any mention of Y Combinator, YC batch, or YC-backed companies in the context of startup research, venture analysis, or market intelligence. This is a read-only data source — the API is a static JSON dataset updated daily.
tools
Read Twitter/X for financial research using opencli (read-only). Use this skill whenever the user wants to read their Twitter feed, search for financial tweets, view bookmarks, look up user profiles, or gather market sentiment from Twitter/X. Triggers include: "check my feed", "search Twitter for", "show my bookmarks", "who follows", "look up @user", "what's trending about", "market sentiment on Twitter", "what are people saying about AAPL", "recent tweets from @elonmusk", "show me @user's posts", "fintwit", any mention of Twitter/X in context of reading financial news or market research. This skill is READ-ONLY — it does NOT support posting, liking, retweeting, or any write operations.