A framework for emulating Hue smart light devices via the Hue::Bridge class.
A real bridge talks to Hue devices via ZigBee, however with Sming you can control anything you want using the published API. Refer to specifications available at https://developers.meethue.com (free account login required).
Refer to the Basic_Alexa sample for details of how to use this library. Here are a few key notes.
HttpServer object is required to allow the framework to respond to requests.
Note that Gen 3+ Hue Bridges listen on port 80 (standard HTTP), however older versions use port 1901.
This library has only been tested on port 80.
In your application, remember to add bodyparsers for JSON and XML:
server.setBodyParser(MIME_JSON, bodyToStringParser); server.setBodyParser(MIME_XML, bodyToStringParser);
Without these, you’ll get empty bodies for incoming requests.
The sample demonstrates use of provided On/Off, Dimmable and Colour device types with a global callback function.
Ideally you should provide your own custom Hue devices by inheriting from
This is demonstrated using MyHueDevice. The device ID is 666.
class Hue::Bridge : public UPnP::schemas_upnp_org::device::Basic1Template<Bridge>
using ConfigDelegate = Delegate<void(const Config &config)>
Called when a new user key is created.
The application should use this to store new users in persistent memory. At startup, these should be passed back via the
using StateChangeDelegate = Delegate<void(const Hue::Device &device, Hue::Device::Attributes attr)>
A global callback may be provided to perform actions when device states change.
The callback is invoked only when all request actions have been completed. The current state may be quereied using
device – The device which has been updated
attr – A set of flags indicating which attributes were changed
inline Bridge(Hue::Device::Enumerator &devices)
devices – List of devices to present
void configure(const Config &config)
Perform a configuration action.
config – The action to perform
inline void enablePairing(bool enable)
Enable creation of new users.
This could be enabled via web page on local Access Point, or physical push-button. It should also be time limited, so exits pairing mode after maybe 30 seconds. If a user creation request is received then this is disabled automatically.
DO NOT leave this permanently enabled!
inline const Stats &getStats()
Get bridge statistics.
const – Stats&
inline void resetStats()
Clear the bridge statistics.
inline const UserMap &getUsers() const
Access the list of users.
const – UserMap&
void getStatusInfo(JsonObject json)
Get bridge status information in JSON format.
json – Where to write information
- using ConfigDelegate = Delegate<void(const Config &config)>
class Hue::Device : public Item
Subclassed by Hue::OnOffDevice
virtual Status setAttribute(Attribute attr, unsigned value, Callback callback) = 0
Set a device attribute.
DO NOT invoke the callback directly: only use it if pended.
attr – The attribute to change
value – Value for the attribute (exact type is attribute-specific)
callback – If you return Status::pending, invoke this callback when completed
virtual bool getAttribute(Attribute attr, unsigned &value) const = 0
Get the (cached) device attribute value.
bool – true on success, false if attribute not supported or value unknown
virtual String getUniqueId() const
Returns the unique device ID string.
Other forms of ID string may be used, however for maximum compatibility the standard format should be used. By default, this method uses the WiFi station MAC address, with 00:11 appended plus the 8-bit device ID.
String – Unique ID of the form AA:BB:CC:DD:EE:FF:00:11-XX, consisting of a 64-bit Zigbee MAC address plus unique endpoint ID.
class Enumerator : public UPnP::Enumerator<Device, Enumerator>
Abstract class to manage a list of devices.
Applications must provide an implementation of this for the bridge. Returned device objects may only be considered valid for the duration of the current task call as they may be destroyed at any time.
Subclassed by Hue::DeviceListEnumerator
virtual Device *find(Device::ID id)
Lookup device by ID.
With default implementation, enumerator position is updated
Device* – nullptr if not found
- virtual Device *find(Device::ID id)
- virtual Status setAttribute(Attribute attr, unsigned value, Callback callback) = 0
Status of a
The action was performed immediately without error.
The action was accepted but requires further processing.
Use this to perform requests asynchronously. You MUST invoked the provided
Callbackfunction to complete the request.
When controlling remote devices, for example connected via serial link, you might issue the command immediately and then return
pending. When the serial response is received, or a timeout occurs, then the request can be completed. Note that the error code passed to the callback is optional and will be specific to your application: it will be output in verbose debug mode so may be useful.
Action could not be completed.
If the Attribute not supported by your device, or an internal I/O error occured then return this value.
- enumerator success
Basic Alexa Sample