Skip to main content

AI绘图插件 for NoneBot2,支持多种绘图API

Project description

AgnesDigitalLogo

NoneBotPluginText

nonebot_plugin_easy_aidraw 0.2.5

✨NoneBot & AI 绘图 插件 ✨

仓库   ·   反馈

python NoneBot pypi GitHub issues QQ Chat Group

介绍

本插件用于快速使用openai格式图像模型,兼容各种中转站或者其他openai兼容格式,只需要填写url/key/model三个参数即可快速使用

示例

快速开始

安装

nb plugin install nonebot-plugin-easy-aidraw

最小配置(仅 3 个参数即可使用)

只需要 draw_api_url / draw_api_key / draw_model,其余全部走默认值:

# .env 文件
draw_api_url = "https://api.openai.com/v1"   # 自定义中转站 base URL,必须以 /v1 类似结尾
draw_api_key = "your-api-key"                     # API 密钥
draw_model = "gpt-image-2"              # 模型名称
  • draw_api_url 留空时按 draw_backend 走官方默认(openai / gemini / sd)都不填写默认为openai
  • 填写时必须以 /v1 结尾,例如 https://api.openai.com/v1(插件会自动拼接 /images/generations)。若填写了 /v1/images/generations 也会被自动截断为 base URL。
  • 文生图与图生图共用同一个 base URL,结尾分别追加 /images/generations/images/edits
  • 若用户配置了中转站 draw_api_url,图生图端点会自动复用同一 base(中转站走同一代理),无需额外配置。

使用

  • /绘图 一只可爱的小猫
  • /绘图 --model gpt-image-2 --size 1024x1792 风景
  • /绘图 --n 2 同一提示词生成两张
  • 回复图片 + /绘图 画成动漫风(以图片为垫图,走 /images/edits
  • 回复消息 + /绘图 ...(从被回复消息中提取图片)

返回示例:

🎨 文生图 | 正在使用 gpt-image-2 生成中...
[图片]
⏱️ 耗时 12.3 秒 | 🎯 文生图 | 🖼️ 1 张 | 🧠 gpt-image-2

完整参数配置

在最小配置基础上,下列参数全部可选,按需启用。

后端选择

draw_backend = "openai"   # openai / gemini / sd

各后端默认端点:

后端 文生图 图生图
openai https://api.openai.com/v1/images/generations https://api.openai.com/v1/images/edits
gemini https://generativelanguage.googleapis.com/v1beta/images/generations https://generativelanguage.googleapis.com/v1beta/images/edits
sd http://localhost:7860/sdapi/v1/txt2img http://localhost:7860/sdapi/v1/img2img

端点覆盖

draw_api_url = "https://api.openai.com/v1"   # 文生图 base URL(必填其一或 draw_backend)
draw_api_url_edits = ""                          # 图生图 base URL(留空则与 draw_api_url 共享)

图生图采用 OpenAI 官方 multipart/form-data 规范(image 文件 + prompt + 其他表单字段),兼容中转站。 垫图统一以 bytes 形式传递,不透传 URL。

请求参数

draw_default_size = "1024x1024"   # 默认图片尺寸
draw_quality = "standard"         # openai 图片质量
draw_n = 1                        # openai 生成数量
draw_timeout = 120                # 请求超时(秒)
draw_proxy = ""                   # HTTP 代理,如 http://127.0.0.1:10808

访问控制

draw_user_cooldown = 60           # 单用户冷却时间(秒),0 禁用,超级用户无视
draw_concurrent = false           # 是否允许并发请求;false(默认)=前一个请求完成才继续下一个
draw_nsfw_enabled = false         # 启用 NSFW 关键词过滤(仅群聊)
draw_nsfw_keywords = []           # 敏感词列表(子串匹配,命中即拒绝)
draw_whitelist_mode = false       # 白名单模式(true 启用白名单,false 走黑名单)
draw_whitelist = []               # 白名单用户 ID(QQ 号),对群/私聊统一生效
draw_blacklist = []               # 黑名单用户 ID

图片缓存

draw_cache_enabled = false        # 是否将 b64 图片落盘缓存(默认关闭)
draw_cache_dir = "data/nonebot_plugin_easy_aidraw"  # 缓存目录
draw_cache_ttl = 86400            # 缓存过期时间(秒)

超级用户指令

/清理绘图缓存

清理超过 draw_cache_ttl 秒的缓存图片(按 mtime 判断),会一并清空子目录。仅在 draw_cache_enabled=true 时生效。

功能

  • 支持 OpenAI / Gemini / Stable Diffusion 多种后端
  • 请求队列:默认前一个请求完成才继续下一个;draw_concurrent=true 时允许并发
  • 用户冷却:单用户 N 秒内只能请求一次(可配置,超级用户无视)
  • 图生图:回复图片时自动走 /images/edits(OpenAI 官方 multipart/form-data),文生图与图生图端点可独立配置
  • 提示语带模式标签(文生图 / 图生图),并输出耗时、张数、模型
  • NSFW 敏感词过滤(仅群聊,子串匹配,命中即拒绝)
  • 黑白名单访问控制(按用户 ID,全局生效)
  • URL / base64 两种返回格式(URL 发送失败自动回退下载转 base64 重发)
  • 垫图统一以 bytes 形式上游传递(不向 API 透传 URL)
  • 可选图片缓存与一键清理
  • 子选项:--model / --size / --n 覆盖全局配置
  • 错误信息脱敏:401/429/4xx/5xx 走白名单友好提示
  • 内置调用指标:成功 / 失败 / 冷却 / 黑名单 / NSFW 等计数,每次请求结束写日志

0.2.1 变更

  • api.py 拆为 api/{backends,cache,client,config_loader,errors,filters}.py 子包
  • 提示语 🎨 文生图/图生图 | 正在使用 X 生成中...
  • 临时 b64 文件统一 try/finally 上下文管理器
  • 缓存清理覆盖 png/jpg/jpeg/webp/tmp,并清理空目录
  • NSFW 改子串匹配,可选 opencc 简繁归一
  • 错误信息脱敏白名单(401/429/4xx/5xx)
  • n>1 时返回并发送所有图片
  • 移除 draw_prompt_max_charsdraw_nsfw_patterns,由上游 API 决定
  • pydantic v2 ConfigDict 替换 class Config
  • 移除 arp.main_args 兼容代码

协议

MIT © @Agnes4m

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

nonebot_plugin_easy_aidraw-0.2.5.tar.gz (19.0 kB view details)

Uploaded Source

Built Distribution

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

nonebot_plugin_easy_aidraw-0.2.5-py3-none-any.whl (19.8 kB view details)

Uploaded Python 3

File details

Details for the file nonebot_plugin_easy_aidraw-0.2.5.tar.gz.

File metadata

  • Download URL: nonebot_plugin_easy_aidraw-0.2.5.tar.gz
  • Upload date:
  • Size: 19.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: pdm/2.27.0 CPython/3.12.3 Linux/6.17.0-1018-azure

File hashes

Hashes for nonebot_plugin_easy_aidraw-0.2.5.tar.gz
Algorithm Hash digest
SHA256 dedaf30b3692b45e3f3147684a177c4f521dd31cc2479fc6ad3137852ad538fc
MD5 add1c3a360b03a81716b0549ae8c7a6d
BLAKE2b-256 86cfce73cf22ed78395f43e32e809e291262f0ba44cfd99a5e384f5b88d5c693

See more details on using hashes here.

File details

Details for the file nonebot_plugin_easy_aidraw-0.2.5-py3-none-any.whl.

File metadata

File hashes

Hashes for nonebot_plugin_easy_aidraw-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 79171ae92ff886aa5bc63a3e1559d4cf39a5c9b84a7710b383581e569338626b
MD5 b871d79722df4c77a741b819ea281aed
BLAKE2b-256 ba4f4f269096b72fd6ae09b1bc5e0b842c893ae70032a8090065cb3a94c12757

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