killadm / LOCK2MQTT

米家智能门锁接入开源智能家居系统

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

LOCK2MQTT

米家智能门锁接入homeassistant

特性

  • 门锁状态

    • 开门
    • 关门
    • 超时未关
    • 敲门
    • 撬门
    • 门卡住
  • 锁舌状态

    • 所有锁舌收回
    • 斜舌弹出
    • 方舌/斜舌弹出
    • 呆舌/斜舌弹出
    • 所有锁舌弹出
  • 开锁事件

    • 方法

      • 蓝牙
      • 密码
      • 指纹
      • 应急钥匙
      • 转盘方式
      • NFC
      • 一次性密码
      • 双重验证
      • 人工
      • 自动
    • 动作

      • 室外开门
      • 上提把手锁门
      • 反锁
      • 解除反锁
      • 室内开门
      • 门内上锁
      • 开启童锁
      • 关闭童锁
    • 操作者

  • 报警事件

    • 密码多次验证失败
    • 指纹多次验证失败
    • 密码输入超时
    • 撬锁
    • 重置按键按下
    • 有人撬锁或钥匙未拔
    • 钥匙孔异物
    • 钥匙未取出
    • NFC设备多次验证失败
    • 超时未按要求上锁
  • 电量事件

  • 蓝牙温湿度计接入(主题:LOCK2MQTT/temp/raw,施工中)

  • 网关日志格式化后输出(主题:LOCK2MQTT/json)

  • WIFIManager配网

  • MQTT输出

  • OTA在线升级

  • 远程调试信息输出

原理

小白万能遥控器的PCB上存在串口测试点,该串口会不停输出运行日志,当它作为米家智能门锁的蓝牙网关时,串口同样会明文输出门锁发送给网关的消息。 本项目通过ESP8266接收网关的串口日志,提取米家智能门锁相关的消息,经过处理后,序列化为json数据,并通过mqtt协议输出。

硬件

  • 米家智能门锁 x 1

    图片

  • 小白万能遥控器 声控版 x 1

    图片

  • ESP8266 x 1

图片

编译

待填坑

烧录

感谢astonish921填坑,这个帖子写的很详细。

https://bbs.iobroker.cn/t/topic/3364

接线

因网关串口输出非常频繁,为了提高效率,默认使用ESP8266的硬串口。 调试完成后,可以通过网关PCB上的VBUS触点给ESP8266供电。

  • 网关端

图片

  • ESP8266端

图片

配网

通电后,连接SSID为"LOCK2MQTT_****"的无线,稍后会弹出认证页面(如果没有弹出,手动访问http://192.168.4.1)

图片

点击“配置WIFI (扫描)”,选择对应的wifi名称,按照提示输入wifi密码及mqtt服务器信息,确定之后等待几秒,配网成功。

接入HomeAssistant

将项目中的lock.yaml放入packages文件夹,重启ha

待填坑

如何匹配操作者 操作者是通过key来匹配的,key 的后六位都一样(我这是000180,不知道是不是每个人的都一样),正常情况下配置完门锁之后00000000、01000180、02000180分别为管理员、管理员密码、管理员指纹,之后新增的指纹、密码等key的前两位会按顺序递增。 你也可以通过订阅LOCK2MQTT/event主题来获取相应操作者的key。 拿到key之后打开lock.yaml,搜索“我”,按下边的格式增加就行了。

  - platform: mqtt
    name: lock_user
    icon: 'mdi:account-lock'
    state_topic: 'LOCK2MQTT/event'
    value_template: >-
       {% if value_json.key == '00000000' or value_json.key == '01000180' or value_json.key == '02000180' %}
         我
       {% elif value_json.key == '03000180' %}
         老婆
       {% elif value_json.key == '新操作者key' %}
         新操作者
       {% elif value_json.key == 'ffffffff' %}
         未知操作者
       {% else %}
         无效操作者
       {% endif %}

进阶-解决ESP8266供电

如果你用的是nodemcu开发板,可以通过连接开发板和网关的VIN-VBUS、GND-GND来实现供电。

为了能够放入网关外壳,我用了huex大佬的IRMQTT板子来做LOCK2MQTT主控板,当然你也可以自己画。

下载gerber文件,去嘉立创薅5块钱5片的羊毛,然后按下图贴好元件(AMS1117是SOT-89,电容电阻是0603),插好排针。

图片

烧录时需要短接正面(有esp-12f的那面)的Fp触点。

烧录成功之后,按下图接线,并把板子卡在相应位置,测试正常之后,就可以把盖子装回去了。

致谢

声明

  • 本项目仅供学习交流技术使用,未经本人同意,不可用于任何商业用途。
  • 因使用本项目造成的一切不良后果与作者无关。
  • 源代码遵循Mozilla Public License, version 2.0 许可协议发布。

About

米家智能门锁接入开源智能家居系统

License:Mozilla Public License 2.0


Languages

Language:C++ 100.0%