Chunk MCP Server
OfficialClick on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Chunk MCP Serverwhat's the BTC/USD price?"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Chunk MCP Server
Production-ready MCP server exposing Chunk MedianFeeds tools over stdio.
Network: Chunk testnet (default RPC:
https://rpc.chunknet.org)Contract: MedianFeeds (default):
0x78D02A47fA898ffF4B37A9B414Eace5eed3e7fAD
Requirements
Node.js 18+ (ESM modules)
Quickstart
Install
cd mcp-servernpm install
Build
npm run build
Run (stdio transport)
npm start
Configuration
Environment variables
CHUNK_RPC— JSON-RPC endpoint (default:https://rpc.chunknet.org)CHUNK_MEDIAN_ADDR— MedianFeeds contract address (default:0x78D02A47fA898ffF4B37A9B414Eace5eed3e7fAD)METRICS_CACHE_TTL_MS— metrics cache TTL in milliseconds (default: 30000)
Production .env (overrides optional)
CHUNK_RPC=https://rpc.chunknet.org
CHUNK_MEDIAN_ADDR=0x78D02A47fA898ffF4B37A9B414Eace5eed3e7fAD
METRICS_CACHE_TTL_MS=30000Notes: You can omit .env entirely — these are the built-in defaults.
Tools
list_metrics— List metric definitions from MedianFeedsArgs:
{ chain?, rpcUrl?, contractAddress?, currency?, tagIncludes?, nameContains?, limit?, offset? }
quote_metrics— Get last quotes for given metric namesArgs:
{ names: string[], chain?, rpcUrl?, contractAddress?, format?: 'raw'|'int'|'decimal'|'all', decimals?: number }
get_signed_root— Get current signed Merkle tree root (epoch)Args:
{ chain?, rpcUrl?, contractAddress? }
get_metrics_count— Total metrics counthas_metric— Check if a metric exists by nameget_metrics_map— Mappingname -> id(index-based)quote_by_ids— Quote metrics by numeric idsArgs:
{ ids: number[], chain?, rpcUrl?, contractAddress?, format?, decimals? }
quote_metrics_at_block— Quote metrics at specific block numberArgs:
{ names: string[], blockNumber: number, chain?, rpcUrl?, contractAddress?, format?, decimals? }
quote_metrics_at_epoch_end— Quote metrics at the end of an epochArgs:
{ names: string[], epochDuration?: number, epochId?: number, chain?, rpcUrl?, contractAddress?, format?, decimals? }
quote_metrics_at_timestamp— Quote metrics at specific UNIX timestamp (seconds)Args:
{ names: string[], timestamp: number, chain?, rpcUrl?, contractAddress?, format?, decimals? }
get_health— RPC health info{ chainId, blockNumber }check_staleness— Check if metrics are stale w.r.tmaxAgeSecondscheck_thresholds— Threshold checks for rules of form{ name, op: 'lt'|'lte'|'gt'|'gte'|'eq'|'neq', value: string|number }
Formatting
Raw values are returned as on-chain 2**112-scaled integers.
Use
format: 'decimal'anddecimalsto get human-friendly strings with rounding.
Resources
chunk://median/{chain}/metrics— JSON array of metrics for a chain (chunksupported)chunk://median/{chain}/metric/{name}— JSON object with the latest quote for a metric
Subscriptions
The server registers
resources.subscribecapability.On epoch changes,
resources/updatednotifications are sent for subscribed URIs.
Client Example (Node.js)
import { Client } from '@modelcontextprotocol/sdk/client/index.js';
import { StdioClientTransport } from '@modelcontextprotocol/sdk/client/stdio.js';
const transport = new StdioClientTransport({
command: 'node',
args: ['dist/server.js'],
env: process.env,
});
const client = new Client({ name: 'chunk-mcp', version: '0.1.0' });
await client.connect(transport);
const list = await client.callTool({ name: 'list_metrics', arguments: { limit: 5 } });
const names = list.structuredContent.metrics.map(m => m.name).slice(0, 2);
const quotes = await client.callTool({ name: 'quote_metrics', arguments: { names, format: 'decimal', decimals: 6 } });
console.log(quotes.structuredContent.quotes);
await client.close();Claude Desktop (MCP) configuration (example)
Configure a stdio MCP server:
{
"mcpServers": {
"chunk-mcp": {
"command": "node",
"args": ["dist/server.js"],
"env": {
"CHUNK_RPC": "https://rpc.chunknet.org",
"CHUNK_MEDIAN_ADDR": "0x78D02A47fA898ffF4B37A9B414Eace5eed3e7fAD"
}
}
}
}Operational Notes
Timeouts and RPC limits depend on your provider.
Handle network errors and transient failures with retries on the client side.
For production, pin a stable RPC endpoint and contract address.
Project Structure
src/server.js— source (ESM)dist/server.js— bundled build (afternpm run build)No tests are included in this directory by design.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/chunknet/mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server