qButton is really three related projects for smart home control in one, all running on ESP8266 boards.
This is not an officially supported Google product.
This is a simple standalone WiFi-connected button. It sends a pre-programmed command through the Google Assistant API, which may be used for smart home control, such as to turn a set of lights on or off, start some music, or anything else that you can do with a Google Assistant command.
It is designed to be low-power so that it can run for a while from a small battery. It remains off or in low-power mode until the button is pressed, then quickly starts up, connects to WiFi, sends the command, and turns off again.
- Copy
config.h.example
toconfig.h
. - Set your client ID, client secret and device model ID for the Google Assistant API in
config.h
. - Build and install the firmware from the 'button' env using PlatformIO.
$ platformio run --target upload --environment button
- Connect the device to power. After a few seconds it will show up as an access point named qbutton.
- Connect to the access point from your phone or laptop.
- Open http://192.168.0.1/ or http://qbutton.local/ in your browser.
- Enter your WiFi network details and click 'Update'.
- Reset the device. It should connect to your WiFi network.
- Connect to the same WiFi network and open http://qbutton.local/ in a browser, or find the device's IP address (from the serial console or your DHCP server) and use that.
- Click the 'set account' link and authorize it to access your Google account.
- Set the command you want it to run.
- Reset once more. It should now connect and run your command on each reset.
This is replacement firmware for the Sonoff RF Bridge 433, which lets you pair a large number of 433 MHz RF buttons (of which there are many available) and have each send a certain Google Assistant command.
- Copy
config.h.example
toconfig.h
. - Set your client ID, client secret and device model ID for the Google Assistant API in
config.h
. - Open the Sonoff RF Bridge (screws are under stickers on the base), solder a 4 pin header for the serial port. The Tasmota wiki has some more details.
- Connect a 3.3V USB serial adapter between the serial pins and your computer, remembering to swap to RX and TX lines.
- Switch the switch on the board towards the side that the serial pins are on.
- Connect the RF Bridge to power (either via the USB port or from the serial header, not both at the same time) while holding down the button on the side. You can release the button a few seconds after connecting pwoer. This puts it into reflashing mode.
- Build and install the firmware from the 'rfbridge' env using PlatformIO.
$ platformio run --target upload --environment rfbridge
- Disconnect power and the serial cable. Switch the switch back to the other side.
- Connect the bridge device to power. After a few seconds it will show up as an access point named qbutton.
- Connect to the access point from your phone or laptop.
- Open http://192.168.0.1/ or http://qbutton.local/ in your browser.
- Enter your WiFi network details and click 'Update'.
- Reset the device. It should connect to your WiFi network.
- Connect to the same WiFi network and open http://qbutton.local/ in a browser, or find the device's IP address (from the serial console or your DHCP server) and use that.
- Set an admin password for the web interface.
- Click the 'set account' link and authorize it to access your Google account.
- Enter a command for the first button you want to pair, and click 'Add command'. The bridge should beep.
- Hold the RF button you are pairing down until the bridge beeps again.
- Repeat for the rest of the buttons you want to pair.
- To reflash, run:
$ PLATFORMIO_UPLOAD_PORT=qbutton.local platformio run --target upload --environment miniupdate
$ PLATFORMIO_UPLOAD_PORT=qbutton.local platformio run --target upload --environment rfbridge
This is a simple smart switch for switching on and off whatever devices you can attach to the pins of your ESP8266 board from Google Home, via the Sinric service. It's well suited for low voltage devices, such as fairy lights that can run off 5V from a USB power supply.
- Create an account on Sinric and follow the instructions there to connect it to Google Home.
- Add devices there for each device you want to control, with device type 'Switch'.
- Copy
config.h.example
toconfig.h
. - If you're not using my circuit board design, update
config.h
so that:-
SWITCH_PINS
has all the pins you want to be able to control. -
SWITCH_NAMES
has the names you want to display for them in the web interface. These names don't have to match the names you use on Sinric; the names from Sinric are what Google Home will see.
-
- If you want to, enable OTA updates and network or serial logging for debugging in
config.h
. - Build and install the firmware from the 'switch' env using PlatformIO.
$ platformio run --target upload --environment switch
- Connect the device to power. After a few seconds it will show up as an access point named qswitch.
- Connect to the access point from your phone or laptop.
- Open http://192.168.0.1/ or http://qswitch.local/ in your browser.
- Enter your WiFi network details and click 'Update'.
- Reset the device. It should connect to your WiFi network.
- Connect to the same WiFi network and open http://qswitch.local/ in a browser, or find the device's IP address (from the serial console or your DHCP server) and use that.
- Set an admin password.
- Enter your Sinric API key.
- Enter the switch IDs from your Sinric account for each pin that you want to control.
- Connect whatever you want to control to the pins, and try controlling it from the Google Home app or Google Assistant.