Building an Interface for 433Mhz Controlled Mains Sockets and Home Assistant

by El Ape in Circuits > Remote Control

7892 Views, 34 Favorites, 0 Comments

Building an Interface for 433Mhz Controlled Mains Sockets and Home Assistant

Sockets.jpg

I recently bought a 3 pack of 433Mhz sockets from bangood and set about building an RF blaster to control the sockets via Home assistant. These devices are considerably cheaper than other such devices such as the Belkin Wemo or TP Link SmartPlugs.

The downside is that the communication is only one way in that the switches will not report back to Home assistant if they are operated manually.

For the price though, they are ideal for devices such as bedside lamps or side lamps.

What Your Going to Need.

All of the parts you need can be purchased from Bangood or AliExpress, I've provided links to Bangood for you

Remote controlled sockets

RF Transmitter Receiver modules

Wemos D1-Mini

170 Point Mini Breadboard

Project Case

Decent USB Data cable

Soldering iron and solder

Magnifying glass

3 short Dupont leads, Black, Red and Yellow

Arduino IDE Installed and ready to go by Arduino

Overview of Arduino install for ESP8266 by Traiker J

The rc-switch library by Suat Özgür

WifiManager by tzapu

PubSubClient by Nick O'Leary

Installing Arduino Libraries by MertArduino

Assemble Your Decoder

TXRX MODULES.jpg
Reciever CCT.jpg

The RF Modules are shipped as a seperate transmitter and receiver modules.

You can see these modules above in the first image, the larger module on the left is the Receiver we need to start with this module as we need to read the codes from the remote that came with the sockets.

To start with, solder the headers onto Wemos D1, an easy way to do this is to insert the header pins into the breadboard, pop the Wemos board onto the headers and solder them in place. I start with the top and bottom pins first and then do the rest once they have first cooled.

Once you have finished soldering, mount the receiver module onto the breadboard.and hook up the wires...

Wemos Colour Receiver.

3V3 Red Vcc

D3 Yellow Data

GND Black GND

Grab the Codes From Your Remote.

Capture.PNG

Start the Arduino editor and make sure it is connected to the correct serial port

Change the board to "WeMos D1 R2 & mini"

Now load the example sketch ReceiveDemo_Advanced from the rc-switch library.

Upload the sketch to your Wemos board, and open the Serial Monitor.

Press each button on your remote, You should see output similar to the above image.

Copy and paste the data for each button press.

Available

Decimal: 9429772 (24Bit) Binary: 100011111110001100001100 Tri-State: not applicable PulseLength: 143 microseconds Protocol: 1 Raw data: 4438,394,161,122,450,118,451,118,453,404,158,413,164,406,165,406,159,412,161,410,161,410,163,119,454,114,457,112,456,402,163,408,166,117,453,116,455,113,453,116,455,403,161,410,162,120,455,113,460,

Received value: 9429772

Of this data the info we are interested in is as follows

Decimal: 9429772 (24Bit) (Which will be different of each button on your remote)
(24Bit) is the data length, I've never seen myself anything other than 24Bit but I'm sure there are variations.

PulseLength: 143

Protocol: 1, The protocol length defaults to 1 so no need to set unless it is different.

Build the Transmitter

TX Module.jpg

Power up your Soldering Iron.

Insert an Antenna into the Ant pin on the transmitter board and once your iron is hot enough solder the antenna in place.

Unplug the USB lead from the WeMos module.

Remove the receiver board from the bread board and replace it with the transmitter.

Check you hookup wires are going to the correct locations on the transmitter.

WeMos Colour Transmitter
5v Red VCC

G Black GND

D3 Yellow Data

Reconnect the USB lead to the WeMos module

Download the sketch SendDemo.ino and save to a folder called SendDemo, open it up in the Arduino IDE

You now need to edit the following lines:

Line 12, set the Pulse length

Line 13-18 Set the on/off codes for each socket

Line 19 set the bit length

Line 20 set the protocol if needed

Save the sketch and upload to the WeMos, if all is well your RF Sockets should start turning on and off in turn on a 1 second interval.

Downloads

The Final Sketch

Download the rfBlaster.ino sketch and save it to a folder called rfBlaster, then open in the Arduino IDE.

You now need to edit the following lines.

Line 20: #define R433PULSELENGTH 143

Change to suit your pulse length

Line 21: #define R433BITLENGTH 24

Change in line with your devices needs

Line 26: const PROGMEM char* MQTT_USER = "MQTT User";

Change "MQTT User" to the user name used to connect to you MQTT server and

Line 27: const PROGMEM char* MQTT_PASSWORD = "MQTT Password";

Change "MQTT Password" to your MQTT servers password

Line 79: WiFi.hostByName("your_mgtt.server.co.uk", MQTT_SERVER_IP);


Once you have given the sketch the once over, verify it, correct any errors if needs be then save the sketch and upload to your WeMos.

Downloads

Connect Your RfBlaster to the Wireless Network.

netlist.png
auth.png
connect.png
auth.png
configure.png
key.png
connected.png

Open up the Serial Monitor in the Arduino IDE, change the baud to 115200 and hit the reset button on the side of the WeMos.

If this WeMos has never had a sketch uploaded to it using the WiFiManager library you should be seeing something similar to this...

Ver: 1.3
*WM:

*WM: AutoConnect

*WM: Connecting as wifi client...

*WM: Using last saved values, should be faster

*WM: Connection result:

*WM: 0

*WM: SET AP STA

*WM:

*WM: Configuring access point...

*WM: ThingMaBob

*WM: AP IP address:

*WM: 192.168.4.1

*WM: HTTP server started

If not and you would like to start from scratch, you will need to uncomment line 63: //wifiManager.resetSettings(); and resend the sketch to the WeMos, then comment the line out again and resend once more to the WeMos.

Now we are set to connect the rfBlaster to your local wireless network.

Using a smartphone or a pc with a WiFi adapter bring up the list of available networks.

Click on the network named ThingMaBob and connect to it.

You will then need to Authenticate, on Android clicking the Authenticate icon at the top of the screen will take you to the pages built into the WiFiManager, you can now select your local network and then enter your wifi key.

When you click save the settings will be written back to the WeMos so that it will automatically connect on boot.

The WeMos will now reboot and connect to your local WLAN and attempt to connect to the MQTT server.

Adding the RfBlaster to Home Assistant

I separate all of my devices into separate files which I then include in the main configuration.yaml.

Please add these devices to wherever you keep yours.

platform: mqtt
name: "Socket1"

state_topic: "RFBlaster/switch1/status"

command_topic: "RFBlaster/switch1/switch"

payload_on: "1ON"

payload_off: "1OFF"

optimistic: false

You will need an entry for each socket you have, you can alter the names to whatever you like, but you must make sure state_topic and command_topic match what you entered in the rfBlaster sketch on lines 28 to 33. Please also make sure you increment the number in the payloads for each device.

Finally run a test to make sure everything is ok with your new entry

/usr/local/bin/hass -c ./ --script check_config

If all appears ok restart hass

service hass-daemon restart

You should now see 3 new switches in the home assistant gui.

Check you can toggle the switches from within Home assistant.

Boxing It All Up.

box.jpg
sticky.jpg
snug.jpg
back.jpg
front.jpg

Take one of the project boxes and pop the back off

Plug your USB lead into the WeMos

Peel the back off of the sticky pad on the back of the breadboard and sit it in the project box pushing it down firmly and holding in place to allow the adhesive on the back of the breadboard to grab.

I found I needed to bend the transmitter over somewhat as it sat proud of the top of the box.

Dress your cables so they are reasonably tidy and wont make fitting the back a pain.

Fit the back, and give your project a final test in its fully assembled state and if all is working deploy to where ever you need.