Metadata-Version: 2.4
Name: nonebot-plugin-multincm
Version: 1.3.1.post1
Summary: NCM Song Searcher
Project-URL: homepage, https://github.com/lgc-NB2Dev/nonebot-plugin-multincm
Author-email: LgCookie <lgc2333@126.com>
License: MIT
License-File: LICENSE
Requires-Python: <4.0,>=3.10
Requires-Dist: cachetools>=6.2.1
Requires-Dist: cookit[jinja,loguru,nonebot-alconna,nonebot-localstore,pydantic]>=0.13.2
Requires-Dist: httpx>=0.28.1
Requires-Dist: jinja2>=3.1.6
Requires-Dist: nonebot-plugin-alconna>=0.60.3
Requires-Dist: nonebot-plugin-htmlrender>=0.6.8
Requires-Dist: nonebot-plugin-localstore>=0.7.4
Requires-Dist: nonebot-plugin-waiter>=0.8.1
Requires-Dist: nonebot2>=2.4.4
Requires-Dist: pyncm>=1.8.1
Requires-Dist: qrcode>=8.2
Requires-Dist: silk-python>=0.2.7
Requires-Dist: typing-extensions>=4.15.0
Requires-Dist: yarl>=1.22.0
Description-Content-Type: text/markdown

<!-- markdownlint-disable MD031 MD033 MD036 MD041 -->

<div align="center">

<a href="https://v2.nonebot.dev/store">
  <img src="https://raw.githubusercontent.com/A-kirami/nonebot-plugin-template/resources/nbp_logo.png" width="180" height="180" alt="NoneBotPluginLogo">
</a>

<p>
  <img src="https://raw.githubusercontent.com/lgc-NB2Dev/readme/main/template/plugin.svg" alt="NoneBotPluginText">
</p>

# NoneBot-Plugin-MultiNCM

_✨ 网易云多选点歌 ✨_

<img src="https://img.shields.io/badge/python-3.10+-blue.svg" alt="python">
<a href="https://github.com/astral-sh/uv">
  <img src="https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/uv/main/assets/badge/v0.json" alt="uv">
</a>
<a href="https://wakatime.com/badge/user/b61b0f9a-f40b-4c82-bc51-0a75c67bfccf/project/eaa9f440-3ac4-4489-863e-6cbf7c0106aa">
  <img src="https://wakatime.com/badge/user/b61b0f9a-f40b-4c82-bc51-0a75c67bfccf/project/eaa9f440-3ac4-4489-863e-6cbf7c0106aa.svg" alt="wakatime">
</a>

<br />

<a href="https://pydantic.dev">
  <img src="https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/lgc-NB2Dev/readme/main/template/pyd-v1-or-v2.json" alt="Pydantic Version 1 Or 2" >
</a>
<a href="./LICENSE">
  <img src="https://img.shields.io/github/license/lgc-NB2Dev/nonebot-plugin-multincm.svg" alt="license">
</a>
<a href="https://pypi.python.org/pypi/nonebot-plugin-multincm">
  <img src="https://img.shields.io/pypi/v/nonebot-plugin-multincm.svg" alt="pypi">
</a>
<a href="https://pypi.python.org/pypi/nonebot-plugin-multincm">
  <img src="https://img.shields.io/pypi/dm/nonebot-plugin-multincm" alt="pypi download">
</a>

<br />

<a href="https://registry.nonebot.dev/plugin/nonebot-plugin-multincm:nonebot_plugin_multincm">
  <img src="https://img.shields.io/endpoint?url=https%3A%2F%2Fnbbdg.lgc2333.top%2Fplugin%2Fnonebot-plugin-multincm" alt="NoneBot Registry">
</a>
<a href="https://registry.nonebot.dev/plugin/nonebot-plugin-multincm:nonebot_plugin_multincm">
  <img src="https://img.shields.io/endpoint?url=https%3A%2F%2Fnbbdg.lgc2333.top%2Fplugin-adapters%2Fnonebot-plugin-multincm" alt="Supported Adapters">
</a>

</div>

## 📖 介绍

一个网易云多选点歌插件（也可以设置成单选，看下面），可以翻页，可以登录网易云账号点 vip 歌曲听（插件发送的是自定义音乐卡片），没了

插件获取的是音乐播放链接，不会消耗会员每月下载次数

### 效果图

<details>
<summary>歌曲列表效果图（点击展开）</summary>

![pic](https://raw.githubusercontent.com/lgc-NB2Dev/readme/main/multincm/song.jpg)

</details>

<details>
<summary>歌词效果图（点击展开）</summary>

![pic](https://raw.githubusercontent.com/lgc-NB2Dev/readme/main/multincm/lyrics.png)

</details>

## 💿 安装

以下提到的方法 任选**其一** 即可

<details open>
<summary>[推荐] 使用 nb-cli 安装</summary>
在 nonebot2 项目的根目录下打开命令行, 输入以下指令即可安装

```bash
nb plugin install nonebot-plugin-multincm
```

</details>

<details>
<summary>使用包管理器安装</summary>
在 nonebot2 项目的插件目录下, 打开命令行, 根据你使用的包管理器, 输入相应的安装命令

<details>
<summary>pip</summary>

```bash
pip install nonebot-plugin-multincm
```

</details>
<details>
<summary>pdm</summary>

```bash
pdm add nonebot-plugin-multincm
```

</details>
<details>
<summary>poetry</summary>

```bash
poetry add nonebot-plugin-multincm
```

</details>
<details>
<summary>conda</summary>

```bash
conda install nonebot-plugin-multincm
```

</details>

打开 nonebot2 项目根目录下的 `pyproject.toml` 文件, 在 `[tool.nonebot]` 部分的 `plugins` 项里追加写入

```toml
[tool.nonebot]
plugins = [
    # ...
    "nonebot_plugin_multincm"
]
```

</details>

## ⚙️ 配置

### 登录相关配置填写说明

如果你安装了 [nonebot-plugin-ncm](https://github.com/kitUIN/nonebot-plugin-ncm) 或者其他使用到 pyncm 的插件并且全局 Session 已登录，本插件会与它们共用全局 Session，就可以不用管这一节

- 如果想要使用 Cookie 登录
  - **必填** `NCM_COOKIE_MUSIC_U`，获取方式见下文
- 如果只想要使用 游客 登录
  - **必填** `NCM_ANONYMOUS=True`

以下登录方式可能已经无法使用，仅供参考

- 如果想要使用 二维码 登录，则 **所有** 登录相关配置项都 **不要填写**
- 如果想要使用 短信验证码 登录
  - **必填** `NCM_PHONE`
  - 选填 `NCM_CTCODE`（默认为 `86`）
- 如果想要使用 手机号与密码 登录
  - **必填** `NCM_PHONE`
  - **必填** `NCM_PASSWORD` 或 `NCM_PASSWORD_HASH` 其中一个
  - 选填 `NCM_CTCODE`（默认为 `86`）
- 如果想要使用 邮箱与密码 登录
  - **必填** `NCM_EMAIL`
  - **必填** `NCM_PASSWORD` 或 `NCM_PASSWORD_HASH` 其中一个

### `MUSIC_U` 获取方式

**先登录网页版网易云音乐**，之后打开浏览器开发者工具（按 F12），按下图步骤操作  
复制第五步中框内的所有内容，填入配置项

![pic](https://raw.githubusercontent.com/lgc-NB2Dev/readme/main/multincm/cookie_music_u.png)

### 所有配置项定义

在 nonebot2 项目的 `.env` 文件中添加下表中的必填配置

|                配置项                 | 必填 |    默认值    |                                                   说明                                                    |
| :-----------------------------------: | :--: | :----------: | :-------------------------------------------------------------------------------------------------------: |
|             **登录相关**              |      |              |                                                                                                           |
|         `NCM_COOKIE_MUSIC_U`          |  否  |    `None`    |                                   Cookie 登录用，Cookie 中的 MUSIC_U 值                                   |
|             `NCM_CTCODE`              |  否  |     `86`     |                                        手机号登录用，登录手机区号                                         |
|              `NCM_PHONE`              |  否  |      无      |                                         手机号登录用，登录手机号                                          |
|              `NCM_EMAIL`              |  否  |      无      |                                           邮箱登录用，登录邮箱                                            |
|            `NCM_PASSWORD`             |  否  |      无      |                                    帐号明文密码，邮箱登录时为邮箱密码                                     |
|          `NCM_PASSWORD_HASH`          |  否  |      无      |                                  帐号密码 MD5 哈希，邮箱登录时为邮箱密码                                  |
|            `NCM_ANONYMOUS`            |  否  |   `False`    |                                             是否强制游客登录                                              |
|              **UI 相关**              |      |              |                                                                                                           |
|           `NCM_LIST_LIMIT`            |  否  |     `20`     |                                          歌曲列表每页的最大数量                                           |
|            `NCM_LIST_FONT`            |  否  |      无      |                                          渲染歌曲列表使用的字体                                           |
|         `NCM_LRC_EMPTY_LINE`          |  否  |     `-`      |                                            填充歌词空行的字符                                             |
|             **交互相关**              |      |              |                                                                                                           |
|          `NCM_AUTO_RESOLVE`           |  否  |   `False`    |                             当用户发送音乐链接时，是否自动解析并发送音乐卡片                              |
|        `NCM_RESOLVE_COOL_DOWN`        |  否  |     `30`     |                                   自动解析同一链接的冷却时间（单位秒）                                    |
|      `NCM_RESOLVE_PLAYABLE_CARD`      |  否  |   `False`    |                                   开启自动解析时，是否解析可播放的卡片                                    |
|       `NCM_ILLEGAL_CMD_FINISH`        |  否  |   `False`    |                              当用户在点歌时输入了非法指令，是否直接退出点歌                               |
|        `NCM_ILLEGAL_CMD_LIMIT`        |  否  |     `3`      | 当未启用 `NCM_ILLEGAL_CMD_FINISH` 时，用户在点歌时输入了多少次非法指令后直接退出点歌，填 `0` 以禁用此功能 |
|           `NCM_DELETE_MSG`            |  否  |    `True`    |                            是否在退出点歌模式后自动撤回歌曲列表与操作提示信息                             |
|        `NCM_DELETE_MSG_DELAY`         |  否  | `[0.5, 2.0]` |                                      自动撤回消息间隔时间（单位秒）                                       |
|        `NCM_INFO_CONTAINS_URL`        |  否  |    `True`    |                                        发送歌曲信息时一并发送 URL                                         |
|         `NCM_SEND_MEDIA_TIP`          |  否  |   `False`    |                                       发送歌曲文件前，是否提醒用户                                        |
|             **行为相关**              |      |              |                                                                                                           |
|          `NCM_SEND_AS_CARD`           |  否  |    `True`    |                      在支持的平台下，发送歌曲卡片，此行为不受 `NCM_SEND_MEDIA` 控制                       |
|    `NCM_IGNORE_SEND_CARD_FAILURE`     |  否  |    `True`    |                          当卡片发送出错后，是否忽略出错后发送歌曲文件的回落流程                           |
|           `NCM_SEND_MEDIA`            |  否  |    `True`    |                          是否发送歌曲文件，如关闭将始终提示使用命令获取播放链接                           |
|  `NCM_SEND_MEDIA_NO_UNIMSG_FALLBACK`  |  否  |    `True`    |                  如存在平台特定的文件发送逻辑，是否禁止回落到通用的 UniMessage 发送方式                   |
|          `NCM_SEND_AS_FILE`           |  否  |   `False`    |                      默认发送歌曲文件的方式是发送语音，启动此项则修改行为为上传文件                       |
|        `NCM_OB_V11_LOCAL_MODE`        |  否  |    `True`    |                      在 OneBot V11 适配器下，是否下载歌曲后使用本地文件路径上传歌曲                       |
| `NCM_OB_V11_IGNORE_SEND_FILE_FAILURE` |  否  |   `False`    |         在 OneBot V11 适配器下且在用以文件形式发送歌曲时，是否禁用出错时回落到使用语音发送的行为          |
|             **其他配置**              |      |              |                                                                                                           |
|         `NCM_MSG_CACHE_TIME`          |  否  |   `43200`    |                                    缓存 用户最近一次操作 的时长（秒）                                     |
|         `NCM_MSG_CACHE_SIZE`          |  否  |    `1024`    |                                   缓存所有 用户最近一次操作 的总计数量                                    |
|  `NCM_RESOLVE_COOL_DOWN_CACHE_SIZE`   |  否  |    `1024`    |                                    缓存 歌曲解析的冷却时间 的总计数量                                     |
|          `NCM_CARD_SIGN_URL`          |  否  |    `None`    |          音卡签名地址（与 LLOneBot 或 NapCat 共用），填写此 URL 后将会把音卡的签名工作交给本插件          |
|        `NCM_CARD_SIGN_TIMEOUT`        |  否  |     `5`      |                                        请求音卡签名地址的超时时间                                         |
|        `NCM_FFMPEG_EXECUTABLE`        |  否  |   `ffmpeg`   |        FFmpeg 可执行文件路径，已经加进环境变量可以不用配置，在 OneBot V11 适配器下发送语音需要使用        |
|          `NCM_SAFE_FILENAME`          |  否  |   `False`    |                                    是否将歌曲文件名中的非法字符替换掉                                     |
|     `NCM_CLEAN_CACHE_ON_STARTUP`      |  否  |    `True`    |                                      是否在启动时清空歌曲缓存文件夹                                       |

## 🎉 使用

### 指令

#### 搜索指令

- 点歌 [歌曲名 / 音乐 ID]
  - 介绍：搜索歌曲。当输入音乐 ID 时会直接发送对应音乐
  - 别名：`网易云`、`wyy`、`网易点歌`、`wydg`、`wysong`
- 网易声音 [声音名 / 节目 ID]
  - 介绍：搜索声音。当输入声音 ID 时会直接发送对应声音
  - 别名：`wysy`、`wyprog`
- 网易电台 [电台名 / 电台 ID]
  - 介绍：搜索电台。当输入电台 ID 时会直接发送对应电台
  - 别名：`wydt`、`wydj`
- 网易歌单 [歌单名 / 歌单 ID]
  - 介绍：搜索歌单。当输入歌单 ID 时会直接发送对应歌单
  - 别名：`wygd`、`wypli`
- 网易专辑 [专辑名 / 专辑 ID]
  - 介绍：搜索专辑。当输入专辑 ID 时会直接发送对应专辑
  - 别名：`wyzj`、`wyal`

#### 操作指令

- 解析 [回复 音乐卡片 / 链接]
  - 介绍：获取该音乐信息并发送，也可以解析歌单等
  - 别名：`resolve`、`parse`、`get`
- 直链 [回复 音乐卡片 / 链接]
  - 介绍：获取该音乐的下载链接
  - 别名：`direct`
- 上传 [回复 音乐卡片 / 链接]
  - 介绍：下载该音乐并上传到群文件
  - 别名：`upload`
- 歌词 [回复 音乐卡片 / 链接]
  - 介绍：获取该音乐的歌词，以图片形式发送
  - 别名：`lrc`、`lyric`、`lyrics`

### Tip

- 当启用 `NCM_AUTO_RESOLVE` 时，Bot 会自动解析你发送的网易云歌曲或电台节目链接
- 点击 Bot 发送的音乐卡片会跳转到官网歌曲页
- 使用需要回复音乐卡片的指令时，如果没有回复，会自动使用你触发发送的最近一个音乐卡片的信息

## 🤔 Q & A

### Q: 我可以把插件变成单选点歌吗？

A: 可以，把配置项 `NCM_LIST_LIMIT` 设置为 `1` 即可。因为插件在检测到搜索结果仅有一个时，会将它直接发送出来。

## 📞 联系

QQ：3076823485  
Telegram：[@lgc2333](https://t.me/lgc2333)  
吹水群：[168603371](https://qm.qq.com/q/EikuZ5sP4G)  
邮箱：<lgc2333@126.com>

## 💡 鸣谢

### [mos9527/pyncm](https://github.com/mos9527/pyncm)

项目使用的网易云 API 调用库

### [Binaryify/NeteaseCloudMusicApi](https://github.com/Binaryify/NeteaseCloudMusicApi)

项目一些相关 API 来源

## 💰 赞助

**[赞助我](https://blog.lgc2333.top/donate)**

感谢大家的赞助！你们的赞助将是我继续创作的动力！

## 📝 更新日志

### 1.3.1

- 添加配置项 `NCM_SEND_MEDIA_NO_UNIMSG_FALLBACK`、`NCM_IGNORE_SEND_CARD_FAILURE`、`NCM_OB_V11_IGNORE_SEND_FILE_FAILURE`
- 调整 `NCM_OB_V11_LOCAL_MODE` 的默认值为 `True`

### 1.3.0

- 单独适配 `QQ` 平台歌曲的发送（[#45](https://github.com/lgc-NB2Dev/nonebot-plugin-multincm/pull/45)）  
  从该 PR 中解构出以下配置项：
  - `NCM_INFO_CONTAINS_URL`
  - `NCM_SEND_MEDIA_TIP`
- 加入 `NCM_SAFE_FILENAME` 配置以修复 [#46](https://github.com/lgc-NB2Dev/nonebot-plugin-multincm/pull/46)
- 支持在启动时清空缓存文件夹（配置 `NCM_CLEAN_CACHE_ON_STARTUP`）

### 1.2.8

- 现可使用 Cookie 登录

### 1.2.7

- 兼容 alconna 0.59

### 1.2.6

- [#43](https://github.com/lgc-NB2Dev/nonebot-plugin-multincm/pull/43)

### 1.2.5

- 修复小问题

### 1.2.4

- 修复二维码登录出现错误登录状态不会报错退出登录的问题
- 登录协程不会阻塞应用启动了

### 1.2.3

- 修复文件后缀名的获取

### 1.2.2

- 迁移到 `localstore`

### 1.2.1

- 修改了歌词图片的样式，现在罗马音会显示在日语歌词上方

### 1.2.0

- 支持更多登录方式

### 1.1.5

- 修复选择未缓存的某列表项时总是会选择到项目所在页第一项的 Bug

### 1.1.4

- 修复一个歌词合并的小问题

### 1.1.3

- 修复过长歌词多行不居中的问题

### 1.1.2

- 修复 OneBot V11 的音乐卡片无法发送的问题

### 1.1.1

- 修复图文消息 cover 发不出的问题

### 1.1.0

- 换用 alconna 构建卡片消息
- 修复手动使用指令解析也有冷却的问题

### 1.0.0

项目重构

- 支持多平台  
  目前多平台发歌逻辑还不是很完善，如果有建议欢迎提出
- UI 大改
- 支持电台与专辑的搜索与解析
- 自动解析对同一歌曲有冷却了，防多 Bot 刷屏
- 配置项变动
  - 增加配置项 `NCM_RESOLVE_COOL_DOWN`、`NCM_RESOLVE_COOL_DOWN_CACHE_SIZE`  
    按需更改，可防止多 Bot 刷屏
  - 增加配置项 `NCM_SEND_MEDIA`、`NCM_SEND_AS_CARD`、`NCM_SEND_AS_FILE`  
    控制插件发送音乐的方式，现在不止支持卡片了
  - 增加配置项 `NCM_CARD_SIGN_URL`、`NCM_CARD_SIGN_TIMEOUT`  
    可以把音卡的签名工作交给插件而不是协议端，自行寻找音卡签名服务填写于此
  - 增加配置项 `NCM_FFMPEG_EXECUTABLE`  
    发送语音时可以将 silk 的编码工作交给插件而不是协议端
  - 重命名配置项 `NCM_DOWNLOAD_LOCALLY` -> `NCM_OB_V11_LOCAL_MODE`
  - 移除配置项 `NCM_MAX_NAME_LEN`、`NCM_MAX_ARTIST_LEN`、`NCM_USE_PLAYWRIGHT`  
    现始终使用 `playwright` 进行图片渲染

<details>
<summary>点击展开 / 收起 v0 版本更新日志</summary>

### 0.5.0

- 适配 Pydantic V1 & V2
- 支持歌单的解析
- 点歌指令可以回复一条文本消息作为搜索内容了
- resolve [#14](https://github.com/lgc-NB2Dev/nonebot-plugin-multincm/issues/14)
- 弃用 Pillow
- 重构部分代码

### 0.4.4

- 添加配置项 `NCM_ILLEGAL_CMD_LIMIT`

### 0.4.3

- 可以退出搜索模式了

### 0.4.2

- resolve [#13](https://github.com/lgc-NB2Dev/nonebot-plugin-multincm/issues/13)

### 0.4.1

- 支持了 `163cn.tv` 短链（Thanks to [@XieXiLin2](https://github.com/XieXiLin2)）
- 修复当 `NCM_RESOLVE_PLAYABLE_CARD` 为 `False` 时，Bot 依然会回复的问题
- 部分代码优化

### 0.4.0

- 项目部分重构
- 删除 `链接` 指令，新增 `直链`、`上传` 指令
- 将卡片点击后跳转的地址改为官网歌曲页，代替 `链接` 指令，同时删除了发送过音乐卡片的缓存机制
- 添加配置项 `NCM_RESOLVE_PLAYABLE_CARD`、`NCM_UPLOAD_FOLDER_NAME`

### 0.3.9

- 让 `htmlrender` 成为真正的可选依赖
- 把配置项 `NCM_MSG_CACHE_TIME` 的默认值改为 `43200`（12 小时）

### 0.3.8

- 修改及统一表格背景色

### 0.3.7

- 添加配置项 `NCM_DELETE_LIST_MSG` 和 `NCM_DELETE_LIST_MSG_DELAY`（[#5](https://github.com/lgc-NB2Dev/nonebot-plugin-multincm/issues/5)）

### 0.3.6

- 支持使用 `nonebot-plugin-htmlrender` (`playwright`) 渲染歌曲列表与歌词图片（默认不启用，如要启用需要自行安装 `nonebot-plugin-multincm[playwright]`）
- 添加配置项 `NCM_USE_PLAYWRIGHT` 与 `NCM_LRC_EMPTY_LINE`

### 0.3.5

- 🎉 NoneBot 2.0 🚀

### 0.3.4

- 修复分割线下会显示歌词翻译的问题

### 0.3.3

- 新增配置项 `NCM_ILLEGAL_CMD_FINISH`
- 在未启用 `NCM_ILLEGAL_CMD_FINISH` 时输入错误指令将会提示用户退出点歌

### 0.3.2

- 新增配置项 `NCM_MSG_CACHE_TIME`、`NCM_AUTO_RESOLVE`
- 调整登录流程到 `driver.on_startup` 中

### 0.3.1

- 修复电台相关 bug

### 0.3.0

- 支持电台节目的解析与点播

### 0.2.5

- `解析`、`歌词`、`链接` 指令可以直接根据 Bot 发送的上个音乐卡片作出回应了
- 歌词解析会合并多行空行和去掉首尾空行了
- 现在插件会定时清理自身内存中的缓存了

### 0.2.4

- 修复一个歌词解析 bug

### 0.2.3

- 微调歌曲列表排版
- 微调插件帮助文本

### 0.2.2

- 修复搜歌 `KeyError`

### 0.2.1

- 删除歌词尾部的空行与多余分割线

### 0.2.0

- 新增了三个指令 `解析`、`歌词`、`链接`
- 点歌指令支持直接输入音乐 ID

</details>
