Market Inspector
Multi-asset market intelligence MCP server that monitors cryptocurrency movements, equity data, and ECB foreign-exchange reference rates to produce structured market briefs using Gemini.
README
Market Inspector
Market Inspector is a multi-asset market intelligence workflow built with Next.js 16, the Model Context Protocol (MCP), and Gemini 3.5 Flash. It monitors cryptocurrency movements, combines them with current equity data and ECB foreign-exchange reference rates, and produces structured market briefs.
The project was created for the Google × Kaggle AI Agents Intensive capstone, in the Agents for Business track.
System overview
Market Inspector exposes 11 MCP tools:
- 4 cryptocurrency tools
- 3 equity tools
- 3 foreign-exchange tools
- 1 zero-cost system status tool
Three coordinated roles divide the workflow:
| Role | Responsibility |
|---|---|
| Anomaly Detector | Scans the top cryptocurrency assets and classifies significant 24-hour movements. |
| Orchestrator | Serializes scans, stores the latest in-memory state, and publishes updates through Server-Sent Events. |
| Brief Generator | Provides Gemini with a seven-result market snapshot and eight optional MCP tools for additional context. |
Market-data fallbacks:
- Crypto price: CoinGecko → Binance when CoinGecko is rate-limited.
- Crypto global data and top movers: CoinGecko → CoinPaprika.
- Equity quotes and candles: Finnhub → Alpha Vantage → Yahoo Finance.
- Foreign exchange: Frankfurter using ECB reference rates.
Asset coverage
| Asset class | Dashboard | Automatic anomaly detection | Gemini snapshot |
|---|---|---|---|
| Cryptocurrency | Global metrics, top movers, ticker | Yes, every 60 seconds | Global market and top 10 assets |
| Equities | Six large-cap technology quotes and ticker | No | AAPL, MSFT, NVDA, GOOGL |
| Foreign exchange | Seven USD reference rates | No | USD against EUR, GBP, JPY, CHF |
Quick start
Requirements:
- Node.js 22.x
- pnpm 10.34.4
git clone https://github.com/dcosodev/market-inspector.git
cd market-inspector
corepack enable
pnpm install --frozen-lockfile
cp .env.local.example .env.local
pnpm dev
The application is available at http://localhost:3000.
Environment variables
| Variable | Purpose | Required |
|---|---|---|
GEMINI_API_KEY |
Manual AI briefs and the chat endpoint | For Gemini features |
FINNHUB_API_KEY |
Primary equity source | Recommended |
ALPHA_VANTAGE_API_KEY |
Secondary equity fallback | Optional |
LOG_LEVEL |
Structured JSON logging threshold | Optional (info) |
ENABLE_PUBLIC_CHAT |
Enables /api/chat in production when set to true |
Optional (false) |
Yahoo Finance provides the final no-key equity fallback. CoinGecko, CoinPaprika, Binance, and Frankfurter also require no key.
Main routes
| Route | Purpose |
|---|---|
/ |
Project overview |
/dashboard |
Market dashboard and architecture view |
/api/mcp |
MCP Streamable HTTP endpoint |
/api/anomalies |
Current state and manual AI scan stream |
/api/stream |
Continuous anomaly-state SSE stream |
/api/chat |
Optional Gemini chat backed by the MCP tool catalog; disabled in production unless ENABLE_PUBLIC_CHAT=true |
/api/health |
Zero-cost service health response; no external API calls |
Agent workflow
- The deterministic detector scans cryptocurrency movements without calling Gemini.
- A manual AI scan refreshes anomalies and preloads seven market-data results.
- Gemini receives the snapshot and can request one or more of eight selected MCP tools when additional context is needed.
- Execution progress, requested tools, and the final informational brief are streamed to the dashboard.
- Source-level rate limits, caching, circuit breaking, and fallbacks reduce the effect of upstream failures.
The dashboard stores a four-scan daily demonstration quota in localStorage. The server applies a matching four-scan in-memory per-client limit over a 24-hour window. Each notable-anomaly scan uses one to five Gemini requests, so the visible worst-case budget is twenty calls. This deliberately lightweight control conserves the demo allowance; it is a demo mitigation, not authentication, billing enforcement, or a hard global limit.
Generated briefs are informational only and are not personalized financial advice. Provider data, tool output, and user text are delimited as untrusted model context.
Verification
pnpm lint
pnpm typecheck
pnpm test
pnpm build
pnpm exec playwright install chromium
pnpm test:e2e
Gemini evaluation is manual and never runs in CI:
RUN_GEMINI_EVALS=1 EVAL_CASE=broad-crypto-selloff pnpm eval:gemini
Documentation
- Documentation overview
- Architecture
- Code reference
- Product specification
- BDD acceptance scenarios
- Design contract
- Repository agent rules
- Deterministic engineering protocol
- Project context skill
- Code conventions skill
- MCP tool pattern skill
- Market data API clients skill
- Gemini integration skill
- Multi-agent pattern skill
- React/Next dashboard design skill
- Code review and evaluation skill
- Manual Gemini evaluation rubric
- Code-review evaluation rubric
- Synthetic code-review calibration cases
Deployment
The repository includes a Vercel configuration for the Frankfurt region. Configure the required environment variables in the deployment platform; API keys must not be committed to the repository.
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.