Migrate to uv and FastMCP architecture with comprehensive tooling

- Replace pip/requirements.txt with uv and pyproject.toml
- Restructure as single-file MCP server using FastMCP
- Add comprehensive Unraid management tools (containers, VMs, storage, logs)
- Implement multiple transport support (streamable-http, SSE, stdio)
- Add robust error handling and timeout management
- Include project documentation and API feature tracking
- Remove outdated cline documentation structure

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
Jacob Magar
2025-08-09 07:34:00 -04:00
parent 00e07fad38
commit f355511fe6
13 changed files with 2941 additions and 115 deletions

View File

@@ -1,17 +1,18 @@
# Use an official Python runtime as a parent image
FROM python:3.9-slim
FROM python:3.11-slim
# Set the working directory in the container
WORKDIR /app
# Copy the dependencies file to the working directory
COPY requirements.txt .
# Install uv
COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /usr/local/bin/
# Install any needed packages specified in requirements.txt
RUN pip install --no-cache-dir -r requirements.txt
# Copy the project files
COPY pyproject.toml .
COPY unraid_mcp_server.py .
# Copy the rest of the application's code to the working directory
COPY . .
# Install dependencies
RUN uv sync --frozen --no-dev
# Make port UNRAID_MCP_PORT available to the world outside this container
# Defaulting to 6970, but can be overridden by environment variable
@@ -27,4 +28,4 @@ ENV UNRAID_VERIFY_SSL="true"
ENV UNRAID_MCP_LOG_LEVEL="INFO"
# Run unraid-mcp-server.py when the container launches
CMD ["python", "unraid-mcp-server.py"]
CMD ["uv", "run", "unraid-mcp-server"]