升级了cups-airprint、ddnsto-go、dozzle、drawio、emby_beta、filebrowser、libretv、nextcloud、onenav、portainer、zigbee2mqtt;

This commit is contained in:
waxgourd
2025-07-30 17:03:35 +08:00
parent 60a3225b06
commit ce7aa3d450
24 changed files with 189 additions and 23 deletions

View File

@@ -85,4 +85,93 @@ adapter: ember
- 点击启动启动时长大约一分钟进入日志页面中点击刷新出现“Zigbee2MQTT started!”则表示启动成功。
- 启动完成后可在信息页中点击"打开 网页界面",或点击“在侧边栏显示”,方便以后从左侧栏快速访问。
- 启动完成后可在信息页中点击"打开 网页界面",或点击“在侧边栏显示”,方便以后从左侧栏快速访问。
## 自定义转换器
如果 Z2M Addons 官方显示不支持你的设备,别慌,可以自定义转换器,操作如下:
先打开调试模式,能查看到更多调试信息:使用 FileBroswer 打开 homeassistant/zigbee2mqtt/configuration.yaml 文件,
并添加或修改log_level: debug
#### 第一步打开zigbee2mqtt点击开发控制台找到 JS 代码,复制并保存到本地,命名为 **[ 设备型号 ].js** (此处将 **[ 设备型号 ]** 替换为你真实的设备信息);
如果这里的js没有生成有效文件或者生成的文件在调试过程中没有很好的效果需要从官方已经存在的转换器https://github.com/Koenkk/zigbee-herdsman-converters查找相关设备类型的代码多次修改调试验证。
#### 第二步:将 **[ 设备型号 ].js** 通过 FileBroswer 拖拽上传到目标目录
```homeassistant/zigbee2mqtt/external_converters```
zigbee2mqtt 2.0.0 之后的版本文件存放位置(**如果没有external_converters 这个文件夹,请手动创建**
简单参考一个js
```python3
const {} = require('zigbee-herdsman-converters/lib/modernExtend');
const fz = require('zigbee-herdsman-converters/converters/fromZigbee');
const exposes = require('zigbee-herdsman-converters/lib/exposes');
const reporting = require('zigbee-herdsman-converters/lib/reporting');
const e = exposes.presets;
const definition = {
zigbeeModel: ['FNB56-ZRC06FB2.0'],
model: 'NZRC106W-M2',
vendor: 'Feibit',
description: 'Security controller',
extend: [],
fromZigbee: [fz.command_arm, fz.battery],
toZigbee: [],
exposes: [e.battery(), e.action(['panic', 'disarm', 'arm_day_zones', 'arm_all_zones'])],
configure: async (device, coordinatorEndpoint) => {
const endpoint = device.getEndpoint(1);
await reporting.bind(endpoint, coordinatorEndpoint, ['genBasic']);
},
onEvent: async (_, data) => {
if (data.type === 'commandArm' && data.cluster === 'ssIasAce') {
await data.endpoint.defaultResponse(0, 0, 1281, data.meta.zclTransactionSequenceNumber);
}
},
};
module.exports = definition;
```
#### 第三步:点击 “允许添加新设备”,等待设备连接完成就好了,然后就是测试功能。
验证过程:
- 查看 z2m 界面新加入的设备是否已经不显示 不支持了,如果还显示,说明匹配失败或 JS 文件有问题。
- 重启 z2m 加载项,点击 日志ctrl+F搜索步骤二中添加的 JS 文件名,出现 Load xxx.js ,并下面没有出现 error 相关字样,表示成功加载且 JS 内容正确。
然后 在日志中查看 MQ 消息,验证设备发送和接收的消息的正确性是否符合预期。如果不满意效果,就需要调整 JS 内容并重启 z2m 加载项,查看日志,重复此过程达到满意即可。
- 如果确定 JS 没问题,但设备还是没有接入成功或者设备按钮效果不符合预期,可能是设备固件需要升级或者固件本身和 z2m 兼容性不好。咨询设备厂商或客服烧录最新固件,再次调试。
接入完成之后,关闭调试,减少日志输出提高 z2m 性能,```log_level: debug``` 改为 ```log_level: info```
### 参考:
官方接入自定义设备参考
https://www.zigbee2mqtt.io/advanced/support-new-devices/01_support_new_devices.html#_2-3-using-modern-extend
升级到 2.0.0+的说明
https://github.com/Koenkk/zigbee2mqtt/discussions/24198
### 如果需要贡献给官方,步骤如下:
- fork 官方转换器仓库https://github.com/Koenkk/zigbee-herdsman-converters
- clone 你 fork 的仓库
- 找到你设备对应的文件比如src/devices/feibit.ts
- 将你测试通过的 JS 代码按照格式添加到官方文件中,根据官方 README 按照步骤操作,提交到你 fork 的仓库,注意提交的 message 按照如下格式feat(add): xxxx(新的设备型号),更多请参考官方历史提交日志记录
- 然后提交 PR等待官方审核等待审核同时准备好设备照片512*512 背景透明
- 同样 fork 官方平台仓库https://github.com/Koenkk/zigbee2mqtt.io
- clone 你 fork 的仓库
- 在位置public/images/devices添加你的设备图片提交到你 fork 仓库,提交 PR等待审核