README.mdβ’10.3 kB
# π
ForexFactory MCP Server








An MCP (Model Context Protocol) server that exposes **ForexFactory economic calendar data** as resources and tools.
Designed for use in **agentic workflows**, LLMs, and trading assistants.
---
<details>
<summary>π <strong>Table of contents (click to expand)</strong></summary>
- [π
ForexFactory MCP Server](#-forexfactory-mcp-server)
- [](#)
- [π Features](#-features)
- [π Development Status](#-development-status)
- [π§ Installation](#-installation)
- [Requirements](#requirements)
- [Setup](#setup)
- [βΆοΈ Usage](#οΈ-usage)
- [β‘ Quickstart](#-quickstart)
- [SSE transport (β οΈ deprecated)](#sse-transport-οΈ-deprecated)
- [Environment variable defaults](#environment-variable-defaults)
- [π·οΈ Namespace](#οΈ-namespace)
- [π¦ Resources](#-resources)
- [π οΈ Tools](#οΈ-tools)
- [π Prompts](#-prompts)
- [π§© Prompt Styles](#-prompt-styles)
- [π» Client Examples](#-client-examples)
- [Example: Using MCP CLI](#example-using-mcp-cli)
- [Example: Using in Python](#example-using-in-python)
- [Example: LangChain Integration](#example-langchain-integration)
- [π Client Configuration Reference](#-client-configuration-reference)
- [βοΈ Configuration](#οΈ-configuration)
- [Example `.env`](#example-env)
- [π³ Docker Integration](#-docker-integration)
- [π 1. `uv` or dependency install fails](#-1-uv-or-dependency-install-fails)
- [β‘ 2. Server exits immediately](#-2-server-exits-immediately)
- [π 3. Port in use](#-3-port-in-use)
- [π 4. Browser fails](#-4-browser-fails)
- [π§ͺ Testing](#-testing)
- [π Roadmap](#-roadmap)
- [π€ Contributing](#-contributing)
- [π License](#-license)
</details>
---
## π Features
* β
Retrieve **economic calendar events** by time period (`today`, `this_week`, `custom`, etc.)
* β
Access via **MCP resources** (for subscription-style access)
* β
Access via **MCP tools** (direct calls from clients/agents)
* β
JSON-first responses for easy integration
* β‘ Integrates with LangChain, n8n, or any MCP-compatible client
---
### π Development Status
This project is **actively developed**.
The **core functionality is stable** (retrieving ForexFactory economic calendar events via MCP tools and resources), but we are still:
* Expanding features (prompts, deployment options)
* Improving documentation and examples
We welcome feedback and contributions while we continue building out the ecosystem.
---
<details>
<summary>π <strong>Project Structure (click to expand)</strong></summary>
```
forexfactory-mcp/
βββ src/forexfactory_mcp/ # Main package
β βββ models/ # Schemas & enums
β βββ services/ # Scraper + data normalization
β βββ tools/ # MCP tool definitions
β βββ resources/ # MCP resource definitions
β βββ prompts/ # Prompt templates (optional MCP prompts)
β βββ utils/ # Shared helpers & config
β βββ server.py # FastMCP server entrypoint
β
βββ examples/ # Example clients
βββ tests/ # Unit tests
βββ .env.example # Copy to .env for config
βββ pyproject.toml # Dependencies & metadata
βββ README.md # Documentation
βββ .python-version # Python version pin (3.12)
```
*(See repo for full details β this is a high-level layout for contributors.)*
</details>
---
## π§ Installation
### Requirements
* Python 3.12+
* [uv](https://github.com/astral-sh/uv) or pip
* A modern terminal or MCP-compatible client
### Setup
```bash
# Clone repo
git clone https://github.com/kjpou1/forexfactory-mcp.git
cd forexfactory-mcp
# Install dependencies
uv sync # or: pip install -e .
# Copy example environment and adjust if needed
cp .env.example .env
```
---
## βΆοΈ Usage
### β‘ Quickstart
Start the server with default settings (`stdio` transport):
```bash
uv run ffcal-server
```
Run with HTTP transport:
```bash
uv run ffcal-server --transport http --host 0.0.0.0 --port 8080
```
---
### SSE transport (β οΈ deprecated)
```bash
uv run ffcal-server --transport sse --host 127.0.0.1 --port 8001
```
---
### Environment variable defaults
```env
MCP_TRANSPORT=http
MCP_HOST=0.0.0.0
MCP_PORT=8080
```
---
## π·οΈ Namespace
Default namespace:
```
ffcal
```
Override via `.env`:
```env
NAMESPACE=ffcal
```
---
## π¦ Resources
| Name | Path | Description |
| -------------- | ------------------------------------ | -------------------- |
| `events_today` | `ffcal://events/today` | Todayβs events |
| `events_week` | `ffcal://events/week` | All events this week |
| `events_range` | `ffcal://events/range/{start}/{end}` | Custom date range |
---
## π οΈ Tools
| Name | Type | Description |
| --------------------------- | ---- | ---------------------------------- |
| `ffcal_get_calendar_events` | Tool | Retrieve events for a given period |
Supported values:
```
today, tomorrow, yesterday, this_week, next_week, last_week, this_month, next_month, last_month, custom
```
---
## π Prompts
| Name | Description |
| --------------------------- | -------------------------------- |
| `ffcal_daily_prep` | Trader prep note for today |
| `ffcal_weekly_outlook` | Weekly macro event summary |
| `ffcal_volatility_grid` | Weekly event-risk heatmap |
| `ffcal_trade_map_scenarios` | Scenario map for specific events |
---
### π§© Prompt Styles
All prompts support a **`style`** parameter to control formatting.
Default:
```python
style: str = "bullet points"
```
See the [Output Style Reference](docs/OUTPUT_STYLE_REFERENCE.md) for available formats.
---
## π» Client Examples
### Example: Using MCP CLI
```bash
mcp call ffcal:get_calendar_events time_period=this_week
```
### Example: Using in Python
```python
from mcp.client.session import Session
async with Session("ws://localhost:8000") as session:
result = await session.call_tool("ffcal:get_calendar_events", {"time_period": "today"})
print(result)
```
### Example: LangChain Integration
```python
from langchain.agents import initialize_agent
from langchain_mcp import MCPToolkit
toolkit = MCPToolkit.from_server_url("ws://localhost:8000", namespace="ffcal")
agent = initialize_agent(toolkit.tools)
response = agent.run("What are todayβs USD-related high impact events?")
print(response)
```
---
### π Client Configuration Reference
> [π docs/CLIENT_CONFIG_REFERENCE.md](docs/CLIENT_CONFIG_REFERENCE.md)
Includes:
* β
Example configs for **Claude Desktop (local + Docker)**
* π³ Docker build and setup
* π§© VS Code MCP integration (future)
* π§ͺ Testing + troubleshooting checklist
* π Inspector setup for visual debugging
---
<details>
<summary>βοΈ <strong>Configuration Reference (click to expand)</strong></summary>
## βοΈ Configuration
| Variable | Default | Description |
| -------------------- | ------------ | --------------------------------------- |
| `NAMESPACE` | `ffcal` | Namespace prefix |
| `MCP_TRANSPORT` | `stdio` | Transport type (`stdio`, `http`, `sse`) |
| `MCP_HOST` | `127.0.0.1` | Host for HTTP/SSE |
| `MCP_PORT` | `8000` | Port for HTTP/SSE |
| `SCRAPER_TIMEOUT_MS` | `5000` | Playwright timeout |
| `LOCAL_TIMEZONE` | System local | Timezone override |
---
### Example `.env`
```env
MCP_TRANSPORT=http
MCP_HOST=0.0.0.0
MCP_PORT=8080
NAMESPACE=ffcal
```
</details>
---
<details>
<summary>π³ <strong>Docker Integration (click to expand)</strong></summary>
## π³ Docker Integration
Supports both **stdio** (default) and **HTTP/SSE**.
```bash
docker compose build
docker compose up forexfactory_mcp
```
Runs MCP server and exposes it on **port 8000**.
</details>
---
<details>
<summary>π§° <strong>Makefile Targets (click to expand)</strong></summary>
| Target | Description |
| ---------------- | ------------------------- |
| `make build` | Build Docker image |
| `make run-http` | Run server in HTTP mode |
| `make run-stdio` | Run in stdio mode |
| `make dev-http` | Inspect via MCP Inspector |
| `make stop` | Stop containers |
</details>
---
<details>
<summary>π§© <strong>Troubleshooting Docker (click to expand)</strong></summary>
### π 1. `uv` or dependency install fails
Run:
```bash
docker compose build --no-cache forexfactory_mcp
```
### β‘ 2. Server exits immediately
Switch to:
```bash
make run-http
```
### π 3. Port in use
Change port:
```bash
docker compose run --rm -e MCP_PORT=8080 forexfactory_mcp
```
### π 4. Browser fails
Install Chromium:
```bash
docker compose run forexfactory_mcp playwright install chromium
```
</details>
---
<details>
<summary>π§ͺ <strong>Testing & Roadmap (click to expand)</strong></summary>
## π§ͺ Testing
```bash
pytest -v
```
## π Roadmap
* [ ] Event filters by **currency** and **impact**
* [ ] Historical backfill
* [ ] MCP prompt expansions
* [ ] Cloud-ready deployment
</details>
---
## π€ Contributing
1. Fork the repo
2. Create a feature branch
3. Commit with a clear message
4. Push and open a PR
---
## π License
MIT License β see [LICENSE](./LICENSE) for details.