Skip to content

Latest commit

 

History

History
218 lines (153 loc) · 10.2 KB

README.md

File metadata and controls

218 lines (153 loc) · 10.2 KB

TechLife Bulb - Custom Integration for Home Assistant

This light integration controls your techlife bulbs without flashing or modifying.

About this repository

The steps explained in this file are the ones I took to solve the problem of integrating my TechLife bulbs with Home Assistant. Some of my decision were influenced by my Home Assistant instance being run in a docker container.

Features:

The script has the ability to:

  • Turn on / off
  • Change brigthness
  • Change rgb color

Requirements:

In order to make the bulb (or bulbs) work you will need to:

  • Connect the bulbs to your wifi
  • Redirect bulb traffic to your custom mqtt broker
  • Know which credentials are being used by the bulbs (username and password)
  • Copy the folder custom_components into HA's config/custom_components folder
  • Create lightbulb entities in your configuration.yaml file
  • Restart HA

Don't forget to check the Credits and Info section at the end of this file.

Connect the bulbs to your wifi

For this there are two options. Either use a script that others have created or configure it using the app. I believe I used the script once and it worked fine.

The script is techlife_setup.py and you can find it in the root of this repository. Check the Connecting to wifi - Custom Script section for more info.

The other option is to use the mobile app TechLife Pro. For this you will have to create an account and follow the steps listed there to connect the bulb to your wifi.

Redirect bulb traffic to your custom mqtt broker

As far as I can tell, until 2020 there were two methods, now there is only one. I will be only explaining the one that is still working.

The method that is still working is to redirect the traffic from the bulbs to your custom mqtt broker. The traffic redirection is done via modifying the dns so that the name the bulb asks points to your mqtt broker.

For this you will firstly need to run an mqtt broker. There are two options here, you could either run it inside the HA instance or either run it in a separate container. I chose the latter. I used the eclipse-mosquitto container.

Then you will have to run a dns server. Any dns server will be fine. I used dnsmasq. Due to my scenario I used it within a container, but is not necessary.

The configuration of the dns server should be redirecting the traffic from both cloud.qh-tek.com and cloud.hq-tek.com to your mqtt broker. The configuration file for dnsmasq should have the following lines:

address=/cloud.qh-tek.com/<your_mqtt_broker_ip>
address=/cloud.hq-tek.com/<your_mqtt_broker_ip>

Obtain the credentials from your lightbulb

We are looking for three pieces of key information: mac address, username and password.

After my investigation I have concluded that both username and password are subject to change on manufacturing. When looking online I found that the most common username was testuser and the password was testpassword. This was not the case for me.

The mac address should be found in the router's configuration page. There you will have to be looking for a newly connected device and its mac address. The name of the device is something, again, subject to change. Mine was something like TechLife-xxxx.

The mac address format is: 00:00:00:00:00:00

For debugging purposes also keep the lightbulb's IP address.

As for the username and password, we will be exploting the fact that the bulbs are trying to connect via unencrypted MQTT. We will have to capture the traffic the lightbulb sends when gets turned on and then inspect it. I used tcpdump to capture the traffic and then wireshark to inspect it. The username and password are sent in the clear.

The credentials my lightbulb was using were user and passwd.

For the lightbulb to use those credentials they must exist in the mqtt broker. Create a user with those credentials in the mqtt broker.

Debugging

Once reached this point it is good to ensure that the connection is working properly. For that use the tester.py script and try to turn on and off the lightbulb. If it works then the credentials are correct and the traffic redirection is working.

Don't forget to change the data in the script to match your setup.

Copy files into Home Assistant

The custom components are stored within config/custom_components/ folder. We will be creating the component techlife_bulb_control. The folder structure should be as follows:

config/custom_components/
└── techlife_bulb_control
    ├── __init__.py
    ├── light.py
    └── manifest.json

Creating entity in configuration.yaml

Example configuration to create an entity called light.yourbulb.

light: 
    - platform: techlife_bulb_control
      mac_address: "00:00:00:00:00:00"
      name: "YourBulb"
      broker_url: 192.168.0.0
      broker_username: !secret broker_username
      broker_password: !secret broker_password

Note: the entity_id is given by the name.

Restart Home Assistant

Once you have restarted, the custom_component will be available in your system (check home_assistant.log) and an entity named 'light.yourbulb' will be available.

Home Assistant uses two ids to identify each entity. The entity_id and the unique_id. The entity_id is the used to call the entity in the frontend. The unique_id is the one that is used to identify the entity within the system.

An entity without a unique_id won't be able to be reconfigured in the frontend. The script assigns a unique_id to the entity with the format <mac_address> as the documentation suggests.

Connecting to wifi - Custom Script

If the bulb is already connected to your wifi you can skip this step.

  • Download techlife_setup.py
  • Ensure python installed in your system.
  • Modify ssid, password and bssid inside the script.
  • Connect the bulb (Reset if needed turning on / off 6 times)
  • Connect your computer to the wifi made by the bulb
  • Run > python techlife_setup.py

Lightbulb MQTT message format

As far as I have researched there are two types of lightbulbs. The ones with only brightness and the ones with brightness and color. The message format is different for each type.

The command used for both brightness only and RGB lightbulbs is 0x28. The closing tag command is 0x29.

Message format to set brightness.

Example with brightness 150 (out of 255):

byte value example
0 Command 0x28
1 0x00 0x00
2 0x00 0x00
3 0x00 0x00
4 0x00 0x00
5 0x00 0x00
6 0x00 0x00
7 Second byte of brightness value (little endian) 0xFA
8 First byte of brightness value 0x16
9 0x00 0x00
10 0x00 0x00
11 0x00 0x00
12 0x00 0x00
13 0xF0 0xF0
14 Checksum 0x66
15 Closing tag 0x29

Brightness value is a number between 0 and 10000. In this example: brightness = 150 -> 10000 * 150 // 255 = 5882 -> 0x16FA. Byte 7: 0xFA, byte 8: 0x16.

Message format to set RGB (and brightness).

Example with RGB color (130, 255, 180) and brightness 150 (out of 255):

Each color value is a number between 0 and 10000. In this example: brightness = 150.

color value [0, 255] brightness [0, 1] * value [0, 10000] value in hex
Red 130 150 / 255 * 10000 * 130 // 255 = 2998 0x0BB6
Green 255 150 / 255 * 10000 * 255 // 255 = 5882 0x16FA
Blue 180 150 / 255 * 10000 * 180 // 255 = 4152 0x1038

In an RGB bulb the brightness information is coded within the RGB values. Quoting Home Assistant's documentation:

Note that in color modes ColorMode.RGB, ColorMode.RGBW and ColorMode.RGBWW there is brightness information both in the light's brightness property and in the color. As an example, if the light's brightness is 128 and the light's color is (192, 64, 32), the overall brightness of the light is: 128/255 * max(192, 64, 32)/255 = 38%.

byte value example
0 Command 0x28
1 Second byte of RED value (little endian) 0xB6
2 First byte of RED value 0x0B
3 Second byte of GREEN value (little endian) 0xFA
4 First byte of GREEN value 0x16
5 Second byte of BLUE value (little endian) 0x38
6 First byte of BLUE value 0x10
7 0x00 0x00
8 0x00 0x00
9 0x00 0x00
10 0x00 0x00
11 0x00 0x00
12 0x00 0x00
13 0x0F 0x0F
14 Checksum 0x76
15 Closing tag for Command 0x28 is 0x29 0x29

Note that 13th byte is different in both cases. In the brightness only message it is 0xF0 and for the RGB message it is 0x0F.

Message format to turn ON

byte 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
value 0xFA 0x23 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x23 0xFB

Message format to turn OFF

byte 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
value 0xFA 0x24 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x24 0xFB

Known issues

  • The TechLife Pro app will stop being able to reach the lightbulb once the traffic redirection is in place.
  • At the time being there is no check for whether the lightbulb is online or not. HA will operate as if the lightbulb were always online, even if it is not. This will lead to a mismatch between the state of the lightbulb and the state of the entity in HA.

Credits and Info

The following links were used to either learn from them or plainly use their code. Please, all credit is for them.