Skip to main content

A NovelAI image generation tool as an MCP server

Project description

NovelAI 图片生成 MCP 服务器

这是一个基于 MCP (Multi-Capability Provider) 架构的 NovelAI 图片生成服务器。它允许 AI Agent 通过标准的 MCP 协议调用 NovelAI API 生成高质量的动漫风格图片。

本项目是将原有的 Node.js 插件 NovelAIGen 移植为符合规范的 Python FastAPI 应用。

功能特点

  • MCP 标准兼容: 实现了 /tools (能力宣告) 和 /invoke (能力执行) 两个核心端点。
  • 高质量图片生成: 使用可配置的 NovelAI Diffusion 模型生成图片。
  • 动态参数: 支持在调用时传入 prompt, resolution, negative_promptartist_string
  • ZIP 文件处理: 自动解压 NovelAI 返回的 ZIP 格式图片包。
  • 本地缓存: 生成的图片保存到本地并提供访问链接。
  • 代理支持: 可通过环境变量配置 HTTP/HTTPS 代理。
  • 调试模式: 可选的调试模式,提供详细执行日志。

系统要求

  • Python 3.8 或更高版本
  • uvpip 包管理工具

安装与运行

  1. 克隆或下载项目

  2. 创建并激活虚拟环境 (推荐)

    # 进入项目目录
    cd mcp_novelaigen
    
    # 使用 uv 创建虚拟环境
    uv venv
    source .venv/bin/activate  # 在 Windows 上是 .venv\Scripts\activate
    
  3. 安装依赖

    uv pip install -r requirements.txt 
    # 或者直接从 pyproject.toml 安装
    uv pip install .
    

    依赖项包括: fastapi, uvicorn, pydantic, httpx

  4. 配置环境变量 在运行服务器之前,必须设置以下环境变量:

    • NOVELAI_API_KEY: 必需。您的 NovelAI API 密钥。
    • PROJECT_BASE_PATH: (可选) 项目基础路径,用于存储图片。默认为当前目录。
    • IMAGESERVER_IMAGE_KEY: (可选) 图像服务器的访问密钥。
    • VarHttpUrl: (可选) Agent 访问的 HTTP URL。
    • VarHttpsUrl: (可选) Agent 访问的 HTTPS URL。
    • PROXY_SERVER: (可选) 代理服务器地址,例如 http://127.0.0.1:7897
    • DebugMode: (可选) 设置为 true 以启用详细日志。

    您可以创建一个 .env 文件来管理这些变量,并使用 python-dotenv 等库加载它们,或者在启动时直接设置。

  5. 运行服务器

    # 使用 pyproject.toml 中定义的脚本入口
    novelaigen-server
    

    或者直接使用 uvicorn:

    uvicorn main:app --host 127.0.0.1 --port 8000
    

    服务器将默认启动在 http://127.0.0.1:8000

API 端点

  • GET /tools: 返回服务器提供的工具定义列表。

  • POST /invoke: 执行一个工具。请求体格式如下:

    {
      "tool_name": "NovelAIGen",
      "arguments": {
        "prompt": "masterpiece, best quality, 1girl, solo, in a beautiful dress",
        "resolution": "832x1216",
        "negative_prompt": "lowres, bad anatomy",
        "artist_string": "artist:hiten"
      }
    }
    

许可证

本项目遵循 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

mcp_novelaigen-0.2.21.tar.gz (925.1 kB view details)

Uploaded Source

Built Distribution

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

mcp_novelaigen-0.2.21-py3-none-any.whl (11.3 kB view details)

Uploaded Python 3

File details

Details for the file mcp_novelaigen-0.2.21.tar.gz.

File metadata

  • Download URL: mcp_novelaigen-0.2.21.tar.gz
  • Upload date:
  • Size: 925.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for mcp_novelaigen-0.2.21.tar.gz
Algorithm Hash digest
SHA256 23705651b09d0b2ceb13f9f139d94ebd871fcfde5914c34af7de85e965cb7af5
MD5 aca91f6ae74d80402e5fb1ab60464d67
BLAKE2b-256 21edabed4eafb684152f3aead2ebe00828ab4a77665b6a842fcbf2913e55064a

See more details on using hashes here.

File details

Details for the file mcp_novelaigen-0.2.21-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_novelaigen-0.2.21-py3-none-any.whl
Algorithm Hash digest
SHA256 f607a6081ecd8e0121ea94945a45486c2e31c31813f835ebf5b9fa5fca9af180
MD5 3ca485f1ee0d1d0f3b3347feb0f3682b
BLAKE2b-256 b1038df4aeba04f9755ee74aee334daaff0c49120e1e55dd9c6f34b50569740f

See more details on using hashes here.

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