A Python module and CLI for controlling Broadlink devices locally. The following devices are supported:
- Universal remotes: RM home, RM mini 3, RM plus, RM pro, RM pro+, RM4 mini, RM4 pro, RM4C mini, RM4S
- Smart plugs: SP mini, SP mini 3, SP mini+, SP1, SP2, SP2-BR, SP2-CL, SP2-IN, SP2-UK, SP3, SP3-EU, SP3S-EU, SP3S-US, SP4L-AU, SP4L-EU, SP4L-UK, SP4M, SP4M-US, Ankuoo NEO, Ankuoo NEO PRO, Efergy Ego, BG AHC/U-01
- Switches: MCB1, SC1, SCB1E, SCB2
- Outlets: BG 800, BG 900
- Power strips: MP1-1K3S2U, MP1-1K4S, MP2
- Environment sensors: A1
- Alarm kits: S1C, S2KIT
- Light bulbs: LB1, LB2, SB800TD
- Curtain motors: Dooya DT360E-45/20
- Thermostats: Hysen HY02B05H
- Hubs: S3
Use pip3 to install the latest version of this module.
pip3 install broadlink
First, open Python 3 and import this module.
python3
import broadlink
Now let's try some functions...
In order to control the device, you need to connect it to your local network. If you have already configured the device with the Broadlink app, this step is not necessary.
- Put the device into AP Mode.
- Long press the reset button until the blue LED is blinking quickly.
- Long press again until blue LED is blinking slowly.
- Manually connect to the WiFi SSID named BroadlinkProv.
- Connect the device to your local network with the setup function.
broadlink.setup('myssid', 'mynetworkpass', 3)
Security mode options are (0 = none, 1 = WEP, 2 = WPA1, 3 = WPA2, 4 = WPA1/2)
Use this function to discover devices:
devices = broadlink.discover()
You may need to specify local_ip_address
or discover_ip_address
if discovery does not return any devices.
devices = broadlink.discover(local_ip_address='192.168.0.100') # IP address of your local machine.
devices = broadlink.discover(discover_ip_address='192.168.0.255') # Broadcast address of your subnet.
If the device is locked, it may not be discoverable with broadcast. In such cases, you can use the unicast version broadlink.hello()
for direct discovery:
device = broadlink.hello('192.168.0.16') # IP address of your Broadlink device.
If you are a perfomance freak, use broadlink.xdiscover()
to create devices instantly:
for device in broadlink.xdiscover():
print(device) # Example action. Do whatever you want here.
After discovering the device, call the auth()
method to obtain the authentication key required for further communication:
device.auth()
The next steps depend on the type of device you want to control.
Learning IR codes takes place in three steps.
- Enter learning mode:
device.enter_learning()
- When the LED blinks, point the remote at the Broadlink device and press the button you want to learn.
- Get the IR packet.
packet = device.check_data()
Learning IR codes takes place in five steps.
- Sweep the frequency:
device.sweep_frequency()
- When the LED blinks, point the remote at the Broadlink device for the first time and long press the button you want to learn.
- Enter learning mode:
device.find_rf_packet()
- When the LED blinks, point the remote at the Broadlink device for the second time and short press the button you want to learn.
- Get the RF packet:
packet = device.check_data()
You can exit the learning mode in the middle of the process by calling this method:
device.cancel_sweep_frequency()
device.send_data(packet)
data = device.check_sensors()
device.set_power(True)
device.set_power(False)
state = device.check_power()
state = device.get_energy()
device.set_power(1, True) # Example socket. It could be 2 or 3.
device.set_power(1, False)
state = device.check_power()
state = device.get_state()
devices[0].set_state(pwr=0)
devices[0].set_state(pwr=1)
devices[0].set_state(brightness=75)
devices[0].set_state(bulb_colormode=0)
devices[0].set_state(blue=255)
devices[0].set_state(red=0)
devices[0].set_state(green=128)
devices[0].set_state(bulb_colormode=1)
data = device.check_sensors()
Return a list of sub-devices
device.get_subdevices()
Get sub-device state; use sub-device DID, obtained from get_subdevices() for the input parameter to query specific sub-device.
device.get_state("00000000000000000000a043b0d06963")
Set sub-device state; (sub-device DID, pwr1, pwr2, pwr3) where pwr options are (None = no change; 1 = on and 0 = off)
In the following example the first command turns pwr1 on and pwr2 off; while the 2nd command turns pwr2 off only.
device.set_state("00000000000000000000a043b0d0783a",1,0)
device.set_state("00000000000000000000a043b0d0783a",None,0)