Files
WLED/usermods/usermod_v2_HttpPullLightControl
Will Miles 4a3af814bf Merge pull request #4669 from willmmiles/4597-usermods-not-building
Correct issues with usermods not being linked.
- Explicitly set libArchive: false in usermod library.json files
- Fix up symlink path generation on Windows
- Add validation script to report usermod linkage in resulting binary
2025-05-26 22:41:45 -04:00
..
2025-05-11 12:49:32 -04:00

usermod_v2_HttpPullLightControl

The usermod_v2_HttpPullLightControl is a custom user module for WLED that enables remote control over the lighting state and color through HTTP requests. It periodically polls a specified URL to obtain a JSON response containing instructions for controlling individual lights.

Features

  • Configure the URL endpoint (only support HTTP for now, no HTTPS) and polling interval via the WLED user interface.
  • All options from the JSON API are supported (since v0.0.3). See: https://kno.wled.ge/interfaces/json-api/
  • The ability to control the brightness of all lights and the state (on/off) and color of individual lights remotely.
  • Start or stop an effect and when you run the same effect when its's already running, it won't restart.
  • The ability to control all these settings per segment.
  • Remotely turn on/off relays, change segments or presets.
  • Unique ID generation based on the device's MAC address and a configurable salt value, appended to the request URL for identification.

Configuration

  • Enable the usermod_v2_HttpPullLightControl via the WLED user interface.
  • Specify the URL endpoint and polling interval.

JSON Format and examples

  • The module sends a GET request to the configured URL, appending a unique identifier as a query parameter: https://www.example.com/mycustompage.php?id=xxxxxxxx where xxxxxxx is a 40 character long SHA1 hash of the MAC address combined with a given salt.

  • Response Format (since v0.0.3) it is eactly the same as the WLED JSON API, see: https://kno.wled.ge/interfaces/json-api/ After getting the URL (it can be a static file like static.json or a mylogic.php which gives a dynamic response), the response is read and parsed to WLED.

  • An example of a response to set the individual lights: 0 to RED, 12 to Green and 14 to BLUE. Remember that is will SET lights, you might want to set all the others to black. { "seg": { "i": [ 0, "FF0000", 12, "00FF00", 14, "0000FF" ] } }

  • Another example setting the first 10 LEDs to RED, LED 40 to a PURPLE (using RGB values) and all LEDs in between OFF (black color) { "seg": { "i": [ 0,10, "FF0000", 10,40, "00FF00", 40, [0,100,100] ] } }

  • Or first set all lights to black (off), then the LED5 to color RED: { "seg": { "i": [ 0,40, "000000", 5, "FF0000" ] } }

  • Or use the following example to start an effect, but first we UNFREEZE (frz=false) the segment because it was frozen by individual light control in the previous examples (28=Chase effect, Speed=180m Intensity=128). The three color slots are the slots you see under the color wheel and used by the effect. RED, Black, White in this case.

`{
  "seg":
    {
    "frz": false,
    "fx": 28,
    "sx": 200,
    "ix": 128,
    "col": [
      "FF0000",
      "000000",
      "FFFFFF"
      ]
    }
}`

Installation

  1. Add usermod_v2_HttpPullLightControl to your WLED project following the instructions provided in the WLED documentation.
  2. Compile by setting the build_flag: -D USERMOD_HTTP_PULL_LIGHT_CONTROL and upload to your ESP32/ESP8266!
  3. There are several compile options which you can put in your platformio.ini or platformio_override.ini:
  • -DUSERMOD_HTTP_PULL_LIGHT_CONTROL ;To Enable the usermod

  • -DHTTP_PULL_LIGHT_CONTROL_URL=""http://mydomain.com/json-response.php"" ; The URL which will be requested all the time to set the lights/effects

  • -DHTTP_PULL_LIGHT_CONTROL_SALT=""my_very-S3cret_C0de"" ; A secret SALT which will help by making the ID more safe

  • -DHTTP_PULL_LIGHT_CONTROL_INTERVAL=30 ; The interval at which the URL is requested in seconds

  • -DHTTP_PULL_LIGHT_CONTROL_HIDE_SALT ; Do you want to Hide the SALT in the User Interface? If yes, Set this flag. Note that the salt can now only be set via the above -DHTTP_PULL_LIGHT_CONTROL_SALT= setting

  • -DWLED_AP_SSID=""Christmas Card"" ; These flags are not just for my Usermod but you probably want to set them

  • -DWLED_AP_PASS=""christmas""

  • -DWLED_OTA_PASS=""otapw-secret""

  • -DMDNS_NAME=""christmascard""

  • -DSERVERNAME=""CHRISTMASCARD""

  • -D ABL_MILLIAMPS_DEFAULT=450

  • -D DEFAULT_LED_COUNT=60 ; For a LED Ring of 60 LEDs

  • -D BTNPIN=41 ; The M5Stack Atom S3 Lite has a button on GPIO41

  • -D DATA_PINS=2 ; The M5Stack Atom S3 Lite has a Grove connector on the front, we use this GPIO2

  • -D STATUSLED=35 ; The M5Stack Atom S3 Lite has a Multi-Color LED on GPIO35, although I didnt managed to control it

  • -D IRPIN=4 ; The M5Stack Atom S3 Lite has a IR LED on GPIO4

  • -D DEBUG=1 ; Set these DEBUG flags ONLY if you want to debug and read out Serial (using Visual Studio Code - Serial Monitor)

  • -DDEBUG_LEVEL=5

  • -DWLED_DEBUG

Use Case: Interactive Christmas Cards

Imagine distributing interactive Christmas cards embedded with a tiny ESP32 and a string of 20 LEDs to 20 friends. When a friend powers on their card, it connects to their Wi-Fi network and starts polling your server via the usermod_v2_HttpPullLightControl. (Tip: Let them scan a QR code to connect to the WLED WiFi, from there they configure their own WiFi).

Your server keeps track of how many cards are active at any given time. If all 20 cards are active, your server instructs each card to light up all of its LEDs. However, if only 4 cards are active, your server instructs each card to light up only 4 LEDs. This creates a real-time interactive experience, symbolizing the collective spirit of the holiday season. Each lit LED represents a friend who's thinking about the others, and the visual feedback creates a sense of connection among the group, despite the physical distance.

This setup demonstrates a unique way to blend traditional holiday sentiments with modern technology, offering an engaging and memorable experience.