Skip to main content

Python stdio MCP server for CBRT EVDS time series data

Project description

cbrt-mcp

cbrt-mcp is a stdio MCP server for the CBRT EVDS time series API.

It gives MCP clients offline discovery over a bundled CBRT metadata snapshot and live data retrieval from EVDS when an API token is available.

Install

End users do not need to clone this repository. They need:

  • uv available on PATH, which provides uvx
  • an MCP client that can run stdio servers
  • an EVDS token only if they want live data from get_series_data()

Check that uvx is available:

uvx --version

Codex

The recommended Codex setup is the CLI command below. It installs nothing into the repository; it writes the MCP registration to ~/.codex/config.toml.

codex mcp add cbrt \
  --env EVDS_TOKEN=paste-your-token-here \
  -- uvx cbrt-mcp

Then restart Codex, or check the registration from a terminal:

codex mcp list

If you only want metadata tools, omit the token:

codex mcp add cbrt -- uvx cbrt-mcp

Manual Codex configuration is also possible. Edit ~/.codex/config.toml and add:

[mcp_servers.cbrt]
command = "uvx"
args = ["cbrt-mcp"]

[mcp_servers.cbrt.env]
EVDS_TOKEN = "paste-your-token-here"

For metadata-only usage, remove the [mcp_servers.cbrt.env] section.

Claude Desktop and Claude Code

If your client does not have an MCP add command, edit its MCP config file.

Common config paths:

Client macOS / Linux Windows
Claude Desktop ~/Library/Application Support/Claude/claude_desktop_config.json %APPDATA%\Claude\claude_desktop_config.json
Claude Code ~/.claude.json %USERPROFILE%\.claude.json

Add this server entry under mcpServers:

{
  "mcpServers": {
    "cbrt": {
      "command": "uvx",
      "args": ["cbrt-mcp"],
      "env": {
        "EVDS_TOKEN": "paste-your-token-here"
      }
    }
  }
}

For metadata-only usage, remove the env block.

After changing a config file, restart the MCP client so it reloads the server configuration.

Use From Source

To run the current GitHub version before a PyPI release:

codex mcp add cbrt \
  --env EVDS_TOKEN=paste-your-token-here \
  -- uvx --from git+https://github.com/emraher/cbrt-mcp cbrt-mcp

To run a local checkout:

codex mcp add cbrt \
  --env EVDS_TOKEN=paste-your-token-here \
  -- uvx --from /absolute/path/to/cbrt-mcp cbrt-mcp

EVDS Token

Most tools work offline from the bundled metadata. Only get_series_data() needs EVDS_TOKEN.

Get a free token from https://evds3.tcmb.gov.tr/ and pass it through your MCP client configuration. Do not commit tokens to the repository.

Tools

Tool Description Needs token?
suggest_series(query, limit) Suggest likely series codes with ranking and match context No
search_series(query, limit) Search bundled series metadata by keyword No
get_common_topic_series(topic) Return curated starter codes for common macro topics No
get_cbrt_reference(topic) Return built-in workflow and reference guidance No
get_series_brief(series_codes) Return compact descriptions with source and tag preview No
get_series_availability(series_codes) Return frequency and date-range summaries No
get_series_compare_ready(series_codes) Check whether multiple series are suitable for direct comparison No
get_series_metadata(series_codes) Look up metadata for exact series codes No
get_series_data(series_codes, start_date, end_date, formulas, preview, summary, max_rows) Download EVDS observations Yes

The bundled metadata snapshot contains 31,713 EVDS series. Live data requests are chunked for long date ranges to reduce the risk of truncated EVDS responses.

Example Prompts

Search for series related to usd exchange rate
Suggest the best CBRT series codes for Turkish policy rate data
Show me the built-in guidance for formula codes
Check the availability range for TP.DK.USD.A and TP.DK.EUR.A
Can TP.DK.USD.A and TP.FE.OKTG01 be compared directly?
Preview the first 5 rows of TP.DK.USD.A for 2023
Summarize TP.DK.USD.A coverage for 2023 without returning row data
Give me starter CBRT series for reserves

Workflow

Use discovery tools before fetching data:

get_common_topic_series("fx")
suggest_series("usd exchange rate")
get_series_metadata(["TP.DK.USD.A"])
get_series_data(["TP.DK.USD.A"], "01-01-2023", "31-12-2023")

Use get_series_compare_ready() before comparing two or more exact series. Use summary=True when you need coverage and shape information without row records. Dates must use dd-mm-yyyy format.

Development

uv run --frozen --extra dev pytest
uv build --no-sources
uvx twine check dist/*

The server entry point is:

uv run --frozen cbrt-mcp

See Publishing for the PyPI release workflow.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cbrt_mcp-0.2.0.tar.gz (834.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cbrt_mcp-0.2.0-py3-none-any.whl (769.8 kB view details)

Uploaded Python 3

File details

Details for the file cbrt_mcp-0.2.0.tar.gz.

File metadata

  • Download URL: cbrt_mcp-0.2.0.tar.gz
  • Upload date:
  • Size: 834.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cbrt_mcp-0.2.0.tar.gz
Algorithm Hash digest
SHA256 36201bcc62c04b235234b742fc131a5bc6663761418869a49f7fb36637bf682b
MD5 af6079ca2a976ce4716bcaf6b15edad5
BLAKE2b-256 9638febe82558b4f23018a54487704ec7be60696e8a7d6128e01d3ebda2569da

See more details on using hashes here.

Provenance

The following attestation bundles were made for cbrt_mcp-0.2.0.tar.gz:

Publisher: publish.yml on emraher/cbrt-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cbrt_mcp-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: cbrt_mcp-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 769.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cbrt_mcp-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 77d83c70f54d05d4dbb2e232542b7838a249c0ee44eb13d997af0253123692b1
MD5 43e07fc096fed92be2e6553841ac5e13
BLAKE2b-256 0c8eebc975b0b8c5486221a70e37ec7ca3c5eef422629d31da7cb41556a23b2b

See more details on using hashes here.

Provenance

The following attestation bundles were made for cbrt_mcp-0.2.0-py3-none-any.whl:

Publisher: publish.yml on emraher/cbrt-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page