Node-RED node to interface with IKEA Tradfri lights without any external binaries thanks to node-tradfri. and node-red-contrib-node-tradfri.
- All operations (brightness, color temperature, color, etc.) supported by the gateway are available.
- Support for observation (i.e. reporting on changes to the light and groups).
Only one node (besides the config node) are necessary for operation. After the configuration has been successful -- either by providing an existing identity and PSK or by generating a new Identity and PSK by providing the security code from the gateway -- simply select which group and/or light to target and check if the node should observe the device as well. Its also possible to select [All devices] and control an entire group. Support for updating lights or groups by id or name provided in the payload has been added recently.
Nodes can be programmatically controlled by sending a message with msg.payload
set to one of the following strings:
"status"
The node will output the current status of its target light.
Lights can be controlled by sending an objet with one or more of the following properties as msg.payload
to the node.
deviceName
string
Name of the device, case insensitive.deviceId
number
ID of the device.onOff
boolean
Turn the light on (true
) or off (false
).dimmer
number
[0,100]
The brightness of the light.colorTemperature
number
[0,100]
The color temperature of the light (cold white:0
, warm white100
).color
string
Sets the color of the light. For WS-bulbs,F5FAF6
,F1E0B5
andEFD275
will set the light to the default cold, normal and warm temperatures respectively.transition
number
The default transition time for operations. Will only work for single operation commands and not for on/off. Defaults to 0.hue
number
[0,360]
Sets the hue of the light.saturation
number
[0,100]
Sets the saturation of the light.
A group can be controlled by selecting [All devices] and sending an object with one or more of the following properties as msg.payload
to the node.
groupName
string
Name of the group, case insensitive.groupId
number
ID of the group.dimmer
number
The brightness in percent [0..100%].onOff
boolean
If the lightbulb is on (true
) or off (false
)transitionTime
number
The duration of state changes in seconds. Default 0.5s, not supported for on/off.sceneId
number
Set this to the instanceId of a scene (or "mood" as IKEA calls them), to activate it.
If the node is set to observe it will send a message with the light or group's current properties as payload every time the light or group is updated: Light:
-
name
string
The name of this accessory as displayed in the app. Defaults to the model name. -
createdAt
number
The unix timestamp of the creation of the device. Unknown what this is exactly. -
instanceId
number
The ID under which the accessory is known to the gateway. Is used in callbacks throughout the library. -
deviceInfo
DeviceInfo{}
Some additional information about the device in form of aDeviceInfo
object (see below) -
alive
boolean
Whether the gateway considers this device as alive. -
lastSeen
number
The unix timestamp of the last communication with the gateway. -
lightList
Light[]
An array of all lights belonging to this accessory in form of aLight[]
array (see below). -
otaUpdateState
number
Unknown. Might be a boolean Group: -
name
string
The name of this accessory as displayed in the app. Defaults to the model name. -
createdAt
number
The unix timestamp of the creation of the device. Unknown what this is exactly. -
instanceId
number
The ID under which the accessory is known to the gateway. Is used in callbacks throughout the library. -
dimmer
number
The brightness in percent [0..100%]. -
onOff
boolean
If the group is on (true
) or off (false
) -
deviceIDs
number[]
An array of device IDs within this group. -
sceneId
number
The current active scene. -
groupType
number
The type of group (currently unknown)DeviceInfo
object -
battery
number
The battery percentage of a device. Only present if the device is battery-powered. -
firmwareVersion
string
The firmware version of the device -
manufacturer
string
The device manufacturer. Usually "IKEA of Sweden". -
modelNumber
string
The name/type of the device, e.g. "TRADFRI bulb E27 CWS opal 600lm" -
power
PowerSources
How the device is powered. One of the following enum values:Unknown (0)
InternalBattery (1)
ExternalBattery (2)
Battery (3)
Although not in the specs, this is apparently used by the remote
PowerOverEthernet (4)
USB (5)
AC_Power (6)
Solar (7)
-
serialNumber
string
Not used currently. Always ""Lights
array -
dimmer
number
The brightness in percent [0..100%]. -
onOff
boolean
If the lightbulb is on (true
) or off (false
) -
transitionTime
number
The duration of state changes in seconds. Default 0.5s, not supported for on/off. -
isSwitchable
boolean
Whether the lightbulb supports on/off. -
isDimmable
boolean
Whether the lightbulb supports setting the brightness. -
spectrum
"none" | "white" | "rgb"
The supported color spectrum of the lightbulb. -
colorTemperature
number
The color temperature in percent, where 0% equals cold white and 100% equals warm white. -
color
string
The 6 digit hex number representing the lightbulb's color. Don't use any prefixes like "#", only the hex number itself! -
hue
number
The color's hue [0..360°]. -
saturation
number
The color's saturation [0..100%].
If the node is set to observe and the target light is updated or if triggered manually by sending a "status"
request as msg.payload
to the node, the node will send a msg.payload
with the current status of the light.
id
number
The id of the light.name
string
The given name of the light.model
string
The model of the light.firmware
string
The firmware of the light.alive
boolean
True if the gateway can communicate with the light, false if not.on
boolean
True if the light is on, false if not.brightness
number
[0,100]
The brightness of the light.colorTemperature
number
[0,100]
The color temperature of the light.color
string
The hex-code for the color of the light. Only fully supported by CWS bulbs.colorX
number
The x component of the xy-color.colorY
number
The y component of the xy-color.transition
number
The default transition time for operations. However, since the default value of 0.5 makes it impossible to send temperature and brightness updates in the same command, this is overridden and set to 0 by default.created
number
Probably when the light was paired with the gateway for the first time, measured in epoch time.seen
number
When the light was last interacted with by the gateway (or similar), measured in epoch time.type
number
The type of device where 2 is light.power
number
The type of power source powering the light. Will most likely always be 1.
To install this repository in node red execute the following:
Execute the following commands:
cd ~/.node-red
(depends where your node-red install directory is)npm install git+https://github.com/flavorplus/node-red-contrib-node-tradfri.git
1- (re)start Node-red and the ["]tradfri] node should appear in the [function] list.
Note: this has only been tested on a Synology NAS. Execute the following commands:
docker exec -it nodered bash
(where nodered is the name of your running node red container)cd /data
npm install git+https://github.com/flavorplus/node-red-contrib-node-tradfri.git
1
1) update github repository link accordingly.
Make sure you have [gulp-cli] installed:
npm install --global gulp-cli
(you might need to prefix it with sudo
in case of an error)
Enter the directory of this repository.
Install all (dev) dependancies with:
npm install
To clean, build and install, execute:
gulp
- Added support for updating groups and devices by name
- Added support for listening to all groups, no groups, all devices and no devices
- Added option to include group event when a device updates
- Added group support and scenes
- A lot of re-writing and re-structuring Please read the info in node-red carefully as the payload format changed.
- Moved output status object from
msg.payload.light
tomsg.payload
. - Updated security code, identity and PSK to be saved as credentials in config.
- Updated info panels and tweaked node appearance.
- Published to NPM