Merge pull request #2 from smithery-ai/smithery/config-oyns

🚀 Deployment: Dockerfile and Smithery config
This commit is contained in:
Fanyang Meng
2025-02-12 16:11:10 -05:00
committed by GitHub
3 changed files with 69 additions and 0 deletions

37
Dockerfile Normal file
View File

@@ -0,0 +1,37 @@
# 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
# Install the project into /app
WORKDIR /app
# Enable bytecode compilation
ENV UV_COMPILE_BYTECODE=1
# Copy from the cache instead of linking since it's a mounted volume
ENV UV_LINK_MODE=copy
# 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
# Then, add the rest of the project source code and install it
# Installing separately from its dependencies allows optimal layer caching
ADD . /app
RUN --mount=type=cache,target=/root/.cache/uv uv sync --frozen --no-dev --no-editable
FROM python:3.12-slim-bookworm
WORKDIR /app
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"
# Environment variables for Ghost CMS connection
ENV GHOST_API_URL=<YOUR_GHOST_API_URL>
ENV GHOST_STAFF_API_KEY=<YOUR_STAFF_API_KEY>
# when running the container, add --db-path and a bind mount to the host's db file
ENTRYPOINT ["uv", "--directory", "/app", "run", "src/main.py"]

View File

@@ -1,5 +1,7 @@
# Ghost MCP Server
[![smithery badge](https://smithery.ai/badge/@MFYDev/ghost-mcp)](https://smithery.ai/server/@MFYDev/ghost-mcp)
A Model Context Protocol (MCP) server for interacting with Ghost CMS through LLM interfaces like Claude. This server provides secure and comprehensive access to your Ghost blog, leveraging JWT authentication and a rich set of MCP tools for managing posts, users, members, tiers, offers, and newsletters.
![demo](./assets/ghost-mcp-demo.gif)
@@ -15,6 +17,15 @@ A Model Context Protocol (MCP) server for interacting with Ghost CMS through LLM
## Installation
### Installing via Smithery
To install Ghost MCP Server for Claude Desktop automatically via [Smithery](https://smithery.ai/server/@MFYDev/ghost-mcp):
```bash
npx -y @smithery/cli install @MFYDev/ghost-mcp --client claude
```
### Manual Installation
```bash
# Clone repository
git clone git@github.com/mfydev/ghost-mcp.git

21
smithery.yaml Normal file
View File

@@ -0,0 +1,21 @@
# Smithery configuration file: https://smithery.ai/docs/config#smitheryyaml
startCommand:
type: stdio
configSchema:
# JSON Schema defining the configuration options for the MCP.
type: object
required:
- ghostApiUrl
- ghostStaffApiKey
properties:
ghostApiUrl:
type: string
description: The URL of your Ghost Admin API
ghostStaffApiKey:
type: string
description: Your Ghost Staff API key
commandFunction:
# A function that produces the CLI command to start the MCP on stdio.
|-
config => ({ command: 'uv', args: ['--directory', '/app', 'run', 'src/main.py'], env: { GHOST_API_URL: config.ghostApiUrl, GHOST_STAFF_API_KEY: config.ghostStaffApiKey } })