The energy commodity MCP server. Real-time oil, gas, and commodity prices for Claude, Cursor, VS Code, and any MCP-compatible client.
- 14 Tools — spot prices, history, futures, marine fuels, rig counts, diesel by state, storage, OPEC production, forecasts
- 5 Resources — subscribable price snapshots for Brent, WTI, Natural Gas, Diesel, and all commodities
- 6 Prompts — pre-built analyst templates (daily briefing, spread analysis, gas markets, commodity report, diesel costs, supply analysis)
- Natural language — ask for "brent oil" or "natural gas", not codes
- 70+ commodities — oil, gas, coal, refined products, metals, forex, bunker fuels, state diesel
- Smart errors — unrecognized commodities get suggestions, not silent fallbacks
npx oilpriceapi-mcpAdd to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"oilpriceapi": {
"command": "npx",
"args": ["-y", "oilpriceapi-mcp"],
"env": {
"OILPRICEAPI_KEY": "your-api-key-here"
}
}
}
}Add to your project's .mcp.json:
{
"mcpServers": {
"oilpriceapi": {
"command": "npx",
"args": ["-y", "oilpriceapi-mcp"],
"env": {
"OILPRICEAPI_KEY": "your-api-key-here"
}
}
}
}Add to .cursor/mcp.json in your project root:
{
"mcpServers": {
"oilpriceapi": {
"command": "npx",
"args": ["-y", "oilpriceapi-mcp"],
"env": {
"OILPRICEAPI_KEY": "your-api-key-here"
}
}
}
}Add to .vscode/mcp.json:
{
"servers": {
"oilpriceapi": {
"type": "stdio",
"command": "npx",
"args": ["-y", "oilpriceapi-mcp"],
"env": {
"OILPRICEAPI_KEY": "your-api-key-here"
}
}
}
}Add to ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"oilpriceapi": {
"command": "npx",
"args": ["-y", "oilpriceapi-mcp"],
"env": {
"OILPRICEAPI_KEY": "your-api-key-here"
}
}
}
}npm install -g oilpriceapi-mcp| Variable | Required | Description |
|---|---|---|
OILPRICEAPI_KEY |
Yes | API key from oilpriceapi.com/signup. Free tier: 200 requests/month. |
OILPRICEAPI_BASE_URL |
No | Override API base URL (for staging/testing). Default: https://api.oilpriceapi.com |
All tools are prefixed with opa_ to avoid name collisions when multiple MCP servers are loaded.
| Tool | Description |
|---|---|
opa_get_price |
Current spot price for a single commodity |
opa_market_overview |
All commodity prices in one call, grouped by category |
opa_compare_prices |
Side-by-side comparison of 2-5 commodities with spread |
opa_list_commodities |
Full commodity catalog (fetched live from API) |
opa_get_history |
Historical prices with high/low/avg/change (day/week/month/year) |
opa_get_futures |
Front-month futures price (Brent BZ or WTI CL) |
opa_get_futures_curve |
Full forward curve with contango/backwardation analysis |
opa_get_marine_fuels |
Bunker fuel prices by port and fuel type (VLSFO/MGO/IFO380) |
opa_get_rig_counts |
Baker Hughes US rig count with week-over-week change |
opa_get_drilling |
Drilling intelligence: wells, permits, completions by region |
opa_get_diesel_by_state |
AAA retail diesel price for any US state (50 states + DC) |
opa_get_storage |
Cushing and SPR oil storage/inventory levels |
opa_get_opec_production |
OPEC country-level production data |
opa_get_forecasts |
EIA STEO energy price forecasts |
"What's the current Brent oil price?"
"Compare Brent and WTI crude"
"Show me oil prices for the past month"
"What's diesel cost in California vs Texas?"
"Give me a market overview of refined products"
"What's the Brent futures curve look like?"
"How many oil rigs are active in the US?"
"What are OPEC production levels?"
"What are bunker fuel prices in Singapore?"
"Show me Cushing storage levels"
Subscribable price data (JSON):
| Resource | URI | Description |
|---|---|---|
| Brent Crude | price://brent |
Global benchmark crude oil price |
| WTI Crude | price://wti |
US benchmark crude oil price |
| Natural Gas | price://natural-gas |
US Henry Hub natural gas price |
| Diesel | price://diesel |
US national average diesel price |
| All Prices | price://all |
All tracked commodity prices |
Pre-built analyst templates:
| Prompt | Description |
|---|---|
daily-briefing |
Energy market daily briefing with key prices and movers |
brent-wti-spread |
Analyze the Brent-WTI crude oil spread |
gas-market-analysis |
Compare US vs European natural gas markets |
commodity-report |
Detailed report on a specific commodity (parameterized) |
diesel-cost-analysis |
Compare diesel prices across US states for fleet planning |
supply-analysis |
Analyze supply using OPEC production, rig counts, storage |
| You say | We understand |
|---|---|
| "brent oil", "brent crude" | BRENT_CRUDE_USD |
| "wti", "us oil" | WTI_USD |
| "natural gas", "henry hub" | NATURAL_GAS_USD |
| "european gas", "ttf" | DUTCH_TTF_EUR |
| "diesel" | DIESEL_USD |
| "gold" | GOLD_USD |
| "jet fuel", "aviation fuel" | JET_FUEL_USD |
| "carbon", "carbon credits" | EU_CARBON_EUR |
npm install
npm run build
npm test
OILPRICEAPI_KEY=your-key node build/index.js- All tool names now use
opa_prefix (e.g.,get_commodity_price->opa_get_price) - Unrecognized commodity names now return an error with suggestions instead of silently defaulting to Brent
list_commoditiesnow fetches live from the API (falls back to static list if unavailable)
MIT
- Python SDK - Python client with Pandas integration
- Node.js SDK - TypeScript/JavaScript SDK
- Go SDK - Idiomatic Go client
- OpenBB Integration - OpenBB Platform provider