Skip to main content

The Wake-on-LAN plugin for nonebot2

Project description

NoneBotPluginLogo

NoneBotPluginText

nonebot-plugin-wake-on-lan

✨ Nonebot 局域网唤醒插件 ✨

license pypi python

📖 介绍

一个简单的Nonebot插件,通过向指定子网广播魔术封包来唤醒局域网内的计算机。

适用于bot和目标设备运行在同一局域网的情况下,例如在局域网下使用Android设备+Termux部署的bot。当然,你也可以把广播IP设置为你的公网IP,然后在你的网关处设置端口转发,将来自指定端口的数据包转发到子网广播地址,以实现用部署在公网服务器上的bot唤醒你自己局域网内的设备。

这是我以前写出来自用的插件,因此很多地方都写得比较随便,请见谅。

🧩 特点

  • 插件使用基类抽象方法,所以理论上是支持跨平台的。但由于个人精力有限,目前只在Telegram上进行了测试。如果在其他平台上出现使用问题请发issue。
  • 细化的权限控制,你可以具体配置哪一名用户拥有对哪一台设备的唤醒权限。
  • 可设置宵禁时间,宵禁时间内非插件管理员将无法唤醒设备,以免半夜三更设备突然自己启动这种瘆人情况发生。

📝 更新日志

  • 0.1.6:补充了Pydantic作为依赖项。
  • 0.1.5:添加了对Pydantic V2版本的支持,但由于引入了Nonebot 2.2.0更新的get_plugin_config方法,破坏了对之前版本的前向兼容性。如果你希望使用旧版的Nonebot,可以继续使用0.1.4版本,插件功能几乎无差别。

💿 安装

使用 nb-cli 安装 在 nonebot2 项目的根目录下打开命令行, 输入以下指令即可安装。
nb plugin install nonebot-plugin-wake-on-lan
使用包管理器安装 在 nonebot2 项目的插件目录下, 打开命令行, 根据你使用的包管理器, 输入相应的安装命令。
pip
pip install nonebot-plugin-wake-on-lan

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

plugins = ["nonebot_plugin_wol"]

⚙️ 配置

在 nonebot2 项目的.env文件中添加以下示例配置,并修改其值。

#wol
wol_admin='
[
    "123456789"
]
'
wol_data_path="/path/to/data/folder"
wol_curfew='
{
    "start_time": [20, 0, 0],
    "end_time": [10, 0, 0]
}
'

配置说明如下:

  • wol_admin是一个列表,应为插件管理员的用户ID(不同平台获取用户ID的方式各不相同,请自行查找方法),注意用户ID应为字符串类型。
    可配置多个插件管理员,如:["123456789", "987654321"]

  • wol_data_path是一个字符串,应为插件的数据存储目录,建议确保指向的目录为空目录。
    如果你使用Windows系统,请务必注意作为路径分隔符的反斜杠需要再加上一个反斜杠来转义。例如C:\path\to\data\folder需要填写成C:\\path\\to\\data\\folder
    数据存储目录的路径可以是绝对路径,也可以是对于bot入口文件(通常为bot.py)所在目录的相对路径。众所周知,相对路径以.开头表示,例如./data代表你的bot.py所在目录下的data目录,而/data这个绝对路径则代表系统根目录下的data目录。

  • wol_curfew是一个字典,其下的start_timeend_time都是列表,分别为宵禁的开始时间和结束时间。每个列表内有三个元素,对应时、分和秒,这些元素应为整数而非字符串。例如[19, 30, 15]代表19点30分15秒
    如果开始时间比结束时间更晚,则会被当做跨日期处理。例如上述示例配置就代表宵禁从晚上20点整开始,到次日上午10点整结束。
    如果你不想设置宵禁时间,请将该配置设置为空字典{}(即wol_curfew={}),或将宵禁的开始时间与结束时间设置为相同。

🎉 使用

如果你不知道什么是Wake-on-LAN,可查看此处
在使用本插件前,请先确认你的设备可以被魔术封包唤醒
1.在主板BIOS处打开WOL选项。绝大部分的现代主板都支持该功能,但在设置中的名称有所不同。可能叫做Remote Wake UpWake-on-LAN由PCI/PCIE设备唤醒,如果找不到请善用搜索引擎。
2.在系统中启用WOL。
对于Linux系统,可以使用ethtool -s [网络接口名称] wol g命令启用WOL,但每次重启系统后WOL可能会被再次禁用。可以将该指令通过systemd等方式加入开机自启项,让其每次开机时都自动执行一次。
对于Windows系统,在设备管理器里找到你的网卡,双击打开配置界面,在高级选项卡中启用唤醒模式匹配唤醒魔包,并在电源管理选项卡中勾选允许此设备唤醒计算机
3.使用移动端或网页端工具测试WOL是否能正常使用。

📜 指令列表

所有指令都可在群聊或私聊环境中触发,但只有拥有权限的用户才能成功执行。
参数用方括号标出,所有参数都是不可缺省的必填参数。
下方的指令表中没有加上,但你可能需要加上指令前缀(默认为/)才能成功执行命令。(如/wol help

wol wake [设备名称]:向指定的设备发送魔术封包来唤醒它。用户必须是插件管理员,或被插件管理员授予对应设备的唤醒权限才可执行该指令。
wol device set [设备名称] [广播IP] [MAC地址] [端口号(通常为9)]:添加或设置一个新的设备到设备列表,已在设备列表中的设备配置将被覆盖(需要插件管理员权限)。
注意广播IP参数填写的是子网广播地址,而不是设备的IP地址。如果你不知道什么是子网广播地址,也可以简单理解为要填写成你设备的局域网IP地址+最后一段改成255。例如,假设目标设备的IP地址为172.16.0.1,则你应该填写172.16.0.255
wol device remove [设备名称]:将一台设备从设备列表中移除(需要插件管理员权限)。
wol device list:显示当前设备列表。出于隐私保护上的考量,设备列表中将只会打印出设备名称,设备的MAC地址等信息将不会显示。同时,用户必须是插件管理员或拥有任何一台设备的唤醒权限才可执行该指令。
wol user add [设备名称] [用户ID]:授权一名用户唤醒指定设备(需要插件管理员权限)。
wol user remove [设备名称] [用户ID]:将一名用户从指定设备的授权列表中移除(需要插件管理员权限)。
wol user list [设备名称]:打印出拥有指定设备唤醒权限的用户列表(需要插件管理员权限)。
wol help:查看插件帮助信息。

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_wake_on_lan-0.1.6.tar.gz (8.4 kB view hashes)

Uploaded Source

Built Distribution

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page