From 74063280a1fa67321024b13f0cd5eb1af4aeae0f Mon Sep 17 00:00:00 2001 From: Henry Mao <1828968+calclavia@users.noreply.github.com> Date: Thu, 30 Jan 2025 01:03:17 +0800 Subject: [PATCH 1/3] Add Dockerfile --- Dockerfile | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 Dockerfile diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..a26b983 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,32 @@ +# Generated by https://smithery.ai. See: https://smithery.ai/docs/config#dockerfile +# Use a Python image with uv pre-installed +FROM ghcr.io/astral-sh/uv:python3.12-bookworm-slim AS uv + +# Set working directory +WORKDIR /app + +# Copy pyproject.toml and uv.lock for installing dependencies +COPY pyproject.toml uv.lock ./ + +# Install the project's dependencies using the lockfile and settings +RUN --mount=type=cache,target=/root/.cache/uv --mount=type=bind,source=uv.lock,target=uv.lock --mount=type=bind,source=pyproject.toml,target=pyproject.toml uv sync --frozen --no-install-project --no-dev --no-editable + +# Add the rest of the project source code +COPY . . + +# Installing the package separately from its dependencies for optimal layer caching +RUN --mount=type=cache,target=/root/.cache/uv uv sync --frozen --no-dev --no-editable + +FROM python:3.12-slim-bookworm + +WORKDIR /app + +# Copy installed packages and compiled bytecode +COPY --from=uv /root/.local /root/.local +COPY --from=uv --chown=app:app /app/.venv /app/.venv + +# Place executables in the environment at the front of the path +ENV PATH="/app/.venv/bin:$PATH" + +# Set the entrypoint for the container +ENTRYPOINT ["python", "src/server.py"] From 03ace9e7a41860f1015fe1b8d1a0792aeebbd988 Mon Sep 17 00:00:00 2001 From: Henry Mao <1828968+calclavia@users.noreply.github.com> Date: Thu, 30 Jan 2025 01:03:17 +0800 Subject: [PATCH 2/3] Add Smithery configuration --- smithery.yaml | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 smithery.yaml diff --git a/smithery.yaml b/smithery.yaml new file mode 100644 index 0000000..ef12755 --- /dev/null +++ b/smithery.yaml @@ -0,0 +1,12 @@ +# Smithery configuration file: https://smithery.ai/docs/config#smitheryyaml + +startCommand: + type: stdio + configSchema: + # JSON Schema defining the configuration options for the MCP. + type: object + properties: {} + commandFunction: + # A function that produces the CLI command to start the MCP on stdio. + |- + (config) => ({command: 'python', args: ['src/server.py']}) From d944987924eee8f4201b7e499cf487f59df40ad6 Mon Sep 17 00:00:00 2001 From: Henry Mao <1828968+calclavia@users.noreply.github.com> Date: Thu, 30 Jan 2025 01:03:18 +0800 Subject: [PATCH 3/3] Update README --- README.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/README.md b/README.md index 53f9e9a..aad620d 100644 --- a/README.md +++ b/README.md @@ -5,6 +5,7 @@ A Model Context Protocol (MCP) server that provides real-time and historical cry [![MCP](https://img.shields.io/badge/MCP-Compatible-blue)](https://modelcontextprotocol.io) [![Python](https://img.shields.io/badge/Python-3.9%2B-blue)](https://www.python.org) [![CCXT](https://img.shields.io/badge/CCXT-Powered-green)](https://github.com/ccxt/ccxt) +[![smithery badge](https://smithery.ai/badge/mcp-server-ccxt)](https://smithery.ai/server/mcp-server-ccxt) Cryptocurrency Market Data Server MCP server @@ -36,6 +37,16 @@ A Model Context Protocol (MCP) server that provides real-time and historical cry ## Installation +### Installing via Smithery + +To install Cryptocurrency Market Data Server for Claude Desktop automatically via [Smithery](https://smithery.ai/server/mcp-server-ccxt): + +```bash +npx -y @smithery/cli install mcp-server-ccxt --client claude +``` + +### Installing Manually + ```bash # Using uv (recommended) uv pip install mcp ccxt