updateSceneLightState.js
1.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
'use strict';
const v3 = require('../../../index').v3
, model = v3.model
, SceneLightState = model.lightStates.SceneLightState
;
// If using this code outside of this library the above should be replaced with
// const v3 = require('node-hue-api').v3
// , model = v3.model
// , SceneLightState = model.lightStates.SceneLightState
// ;
// Replace this with your username for accessing the bridge
const USERNAME = require('../../../test/support/testValues').username;
// This example will getOperator a new scene and then update the LightState for one of the lights.
// You may need to remove this scene later depending on whether or not you wish to have it remain.
v3.discovery.nupnpSearch()
.then(searchResults => {
const host = searchResults[0].ipaddress;
return v3.api.createLocal(host).connect(USERNAME);
})
.then(api => {
return createSceneThenUpdateLightState(api);
})
.then(result => {
console.log(`Updated Scene LightState?\n${JSON.stringify(result, null, 2)}`);
})
.catch(err => {
console.error(`Unexpected Error: ${err.message}`);
})
;
function createSceneThenUpdateLightState(api) {
const scene = model.createLightScene();
scene.name = 'node-hue-api-test-scene';
scene.lights = [1];
// Allow the Bridge to delete this scene
scene.recycle = true;
// Create the new scene we are going to update the light state on
return api.scenes.createScene(scene)
.then(result => {
console.log(`Created new scene with id: ${result.id}`);
const lightId = 1
, sceneId = result.id
, lightState = new SceneLightState()
;
// Craft the parameters of the desired light state for the scene
lightState.on().brightness(100);
// Now update the light state for one of the lights in the scene
return api.scenes.updateLightState(sceneId, lightId, lightState);
});
}