Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/morzzz007/node-tradfri

Node API to control IKEA Tradfri Lights
https://github.com/morzzz007/node-tradfri

Last synced: about 2 months ago
JSON representation

Node API to control IKEA Tradfri Lights

Awesome Lists containing this project

README

        

# Node TRÅDFRI API ![img](http://i.imgur.com/Qicn5wu.jpg) [![Build Status](https://travis-ci.org/morzzz007/node-tradfri.svg?branch=master)](https://travis-ci.org/morzzz007/node-tradfri) [![npm version](https://badge.fury.io/js/node-tradfri.svg)](https://badge.fury.io/js/node-tradfri) [![npm](https://img.shields.io/npm/dm/node-tradfri.svg)]()
Node API to control **IKEA Tradfri (Trådfri)** Lights.
Currently supports Node versions **7.6+** only!

## Installation

`npm install node-tradfri --save`

## CoAP

This library uses [libcoap](https://github.com/obgm/libcoap) with tinydtls to send CoAP requests.
Prebuilt OsX client is included or you can build your own and set the `coapClientPath` config setting to point to your library.
For more information on building a CoAP client for Raspibian or macOS [see this section.](#how-to-build-coap-client)

## First steps
1. Obtain the TRÅDFRI Gateway's IP address and Security Code (found at the bottom of the gateway)
2. Generate a DTLS `IDENTITY` and a `PRE_SHARED_KEY`

## How to generate a DTLS Identity

> The identities will expire after 6 weeks without any usage. Each time you use it the expiration will be moved in time. That means that you should not need to think about renewals of the identities as long as it is used continuously.

### Use the included script
`node node_modules/node-tradfri/dtls.js HUB_IP_ADDRESS SECURITY_CODE (COAP_CLIENT_PATH [optional])`

Example:
`node node_modules/node-tradfri/dtls.js 192.168.0.33 ABCDEFGHIJKLM`

### Manually
```
coap-client -m post -u "Client_identity" -k "SECURITY_CODE" -e '{"9090":"IDENTITY"}' "coaps://IP_ADDRESS:5684/15011/9063"
```

## Usage
```javascript
const tradfri = require('node-tradfri').create({
coapClientPath: './lib/coap-client', // use embedded coap-client
identity: '',
preSharedKey: '',
hubIpAddress: ''
});

const devices = await tradfri.getDevices();

// or

await tradfri.setDeviceState(65537, {
state: 'on',
color: 'ffffff',
brightness: 255
});
```

# API
## Basics
Every exposed method is asynchronous and returns a promise.

You can use async/await:
```javascript
const deviceIds = await tradfri.getDeviceIds();
```

Or the typical promises approach:
```javascript
tradfri.getDeviceIds().then(deviceIds => {
// do something
});
```

## Public API List
|Devices|Groups|
|---|---|
|getDeviceIds()|getGroupIds()|
|getDevices()|getGroups()|
|turnOnDevice()|turnOnGroup()|
|turnOffDevice()|turnOffGroup()|
|toggleDevice()|toggleGroup()|
|setDeviceState()|setGroupState()|

## Methods for working with indivudial devices/bulbs (for groups [see this section](#methods-for-working-with-groups))

### getDeviceIds()
Returns device id's.

Response:
```javascript
[65536, 65537, 65538]
```

### getDevices()
Returns an array with every device connected to the hub.

Example:
```javascript
[ { id: 65540,
name: 'Ceiling 2',
type: 'TRADFRI bulb E14 WS opal 400lm',
on: true,
color: 'efd275',
brightness: 254 },
{ id: 65539,
name: 'Ceiling 1',
type: 'TRADFRI bulb E14 WS opal 400lm',
on: true,
color: 'efd275',
brightness: 254 } ]
```

### turnOnDevice(``)
|Parameters|type|values|
|---|---|---|
|`deviceId`|required|int/string|

### turnOffDevice(``)
|Parameters|type|values|
|---|---|---|
|`deviceId`|required|int/string|

### toggleDevice(``, ``)
|Parameters|type|values|
|---|---|---|
|`deviceId`|required|int/string|
|`state`|optional|boolean|

### setDeviceState(``, ``)

#### Examples
Turn device on:
```javascript
await tradfri.setDeviceState(65537, { state: 'on' });
```

Combine settings, turn on and set brightness:
```javascript
await tradfri.setDeviceState(65537, { state: 'on', brightness: 255 });
```

#### Usage

|Parameters|type|values|
|---|---|---|
|`deviceId`|required|int/string|
|`newState`|required|object|

In newState you can combine the following values:

|Parameters|values|action|
|---|---|---|
|`state`|boolean/string ('on', 'off')|Toggle light on/off
|`color`|string (hex color value, ex: 'efd275')|Sets color
|`brightness`|number/string (0-255)|Sets brightness
|`colorX, colorY`|number|Sets color [(how to use)](https://github.com/morzzz007/node-tradfri/pull/13)
|`transitionTime`|number|Sets the trainsition time

## Methods for working with groups

### getGroupIds()
Returns group id's.

Response:
```javascript
[150429]
```

### getGroups()
Returns an array of groups with the devices in it.

Response:
```javascript
[ { id: 150429,
name: 'Kitchen',
devices: [ [Object], [Object], [Object] ],
on: false } ]
```

### turnOnGroup(``)
|Parameters|type|values|
|---|---|---|
|`groupId`|required|int/string|

### turnOffGroup(``)
|Parameters|type|values|
|---|---|---|
|`groupId`|required|int/string|

### toggleGroup(``, ``)
|Parameters|type|values|
|---|---|---|
|`groupId`|required|int/string|
|`state`|optional|boolean|

### setGroupState(``, ``)

#### Examples
Turn group on:
```javascript
await tradfri.setGroupState(150429, { state: 'on' });
```

Combine settings, turn on and set brightness:
```javascript
await tradfri.setGroupState(150429, { state: 'on', brightness: 255 });
```

#### Usage

|Parameters|type|values|
|---|---|---|
|`groupId`|required|int/string|
|`newState`|required|object|

In newState you can combine the following values:

|Parameters|values|action|
|---|---|---|
|`state`|boolean/string ('on', 'off')|Toggle light on/off
|`color`|string (hex color value, ex: 'efd275')|Sets color
|`brightness`|number/string (0-255)|Sets brightness

# How to build CoAP client
## OsX
### Prerequisites
```shell
brew install libtool
brew install automake
brew install autoconf
```

### Build
```shell
git clone https://github.com/obgm/libcoap.git
cd libcoap
git checkout origin/dtls
git checkout -b dtls
git submodule update --init ext/tinydtls
cd ext/tinydtls
autoreconf
./configure
cd ../../
./autogen.sh
./configure --disable-shared --disable-documentation
make
```

Now you can find the `coap-client` in the `/examples` directory

## Raspibian (Raspberry Pi)
### Prerequisites
```shell
sudo apt-get install autoconf automake libtool
```
### Build
```shell
git clone https://github.com/obgm/libcoap.git
cd libcoap
git checkout origin/dtls
git checkout -b dtls
git submodule update --init ext/tinydtls
cd ext/tinydtls
autoreconf
cd ../../
./autogen.sh
./configure --disable-shared --disable-documentation
make
```

Now you can find the `coap-client` in the `/examples` directory