Metadata-Version: 2.3
Name: nonebot-adapter-efchat
Version: 0.1.9.post2
Summary: A NoneBot adapter for EFChat
License: MIT
Keywords: bot,efchat,wtek
Author: molanp
Author-email: molanpp@outlook.com
Requires-Python: >=3.9,<4.0
Classifier: Development Status :: 5 - Production/Stable
Classifier: Framework :: Robot Framework
Classifier: Framework :: Robot Framework :: Library
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Requires-Dist: aiofiles (>=23.0.0)
Requires-Dist: filetype (>=1.0.0)
Requires-Dist: nonebot2 (>=2.2.0)
Requires-Dist: pydantic (>=1.10.0,<3.0.0,!=2.5.0,!=2.5.1)
Requires-Dist: typing-extensions (>=4.0.0)
Project-URL: Homepage, https://github.com/molanp/nonebot_adapter_efchat
Project-URL: Repository, https://github.com/molanp/nonebot_adapter_efchat
Description-Content-Type: text/markdown

<p align="center">
  <a href="https://nonebot.dev/"><img src="https://nonebot.dev/logo.png" width="200" height="200" alt="nonebot"></a>
</p>

<div align="center">

# NoneBot-Adapter-EFChat

_✨ NoneBot2 EFChat 协议适配 / EFChat Protocol Adapter for NoneBot2 ✨_

</div>

## EFChat适配器简述

EFChat Adapter 是一个适用于 **[EFChat聊天室](https://efchat.irin-wakako.uk)** 的 **NoneBot 适配器**，可以轻松地在 EFChat 聊天室中开发机器人，并使用 NoneBot 生态来构建聊天机器人。

> [!IMPORTANT]
>
> 为了避免造成不必要的麻烦，本适配器不会支持以下功能：
> 1. **其他有可能危害聊天室安全的功能**

---

## 🚀 特性
- 🔌 **NoneBot 适配**，可直接集成到 NoneBot 插件系统，实现灵活的机器人开发
- 📡 **自动处理 EFChat 事件**，支持房间消息、私聊、系统通知等
- ✨ **支持多Bot**， 支持同时运行并管理多个bot

---

## 📦 安装
```bash
pip install nonebot-adapter-efchat
```
---

## 🔧 配置
在 `bot.py` 中启用 EFChat 适配器：
```python
from nonebot import get_driver
from nonebot.adapters.efchat import Adapter

driver = get_driver()
driver.register_adapter(Adapter)
```

在 `.env` 文件中添加：
```ini
DRIVER=~websockets+~httpx

EFCHAT_BOTS = '
[
    {
        "nick": "EFChatBot",
        "password": "", // 可选配置
        "channel": "NewPR",
        "head": "https://efchat.irin-wakako.uk/imgs/ava.png", // 可选，为空使用默认头像
        "token": "",
        "ignore_self": true // 默认忽略自身消息
    }
]
'
```
* 配置项`token`是必填项;[获取TOKEN](get_token.md)
* 如果Bot将会拥有管理员权限，请提供`password`字段以确保账号安全
- `nick`是bot账号，同时也是在聊天室里显示的昵称
- `channel`是Bot活跃的房间名称
- `head`是Bot的头像url地址

> ⚠️ **暂不支持一个bot同时连接多个房间**

---

## [📖 API 参考](api.md)

---

## 💬 使用示例

### **消息回显**
在 `plugins/echo.py` 中创建一个简单的回显插件：
```python
from nonebot import on_message
from nonebot.adapters.efchat import MessageEvent

echo = on_message()

@echo.handle()
async def handle_echo(event: MessageEvent):
    await echo.send(f"你发送的消息是: {event.get_message()}")
```

机器人发送的消息默认不保存到聊天记录，如果需要保存，请在发送消息时传入`show=True`

例如
```py
await matcher.send("xxx", show=True)
```
---

## 🔨 开发与贡献
欢迎贡献代码！请遵循以下流程：
1. **Fork 本仓库** 并克隆代码。
2. **提交 Pull Request**，描述你的改动。

---

## 📜 许可证
本项目基于 **MIT 许可证** 开源，你可以自由使用和修改。

