-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathadvanced-hue-motion-sensor.groovy
128 lines (104 loc) · 4.54 KB
/
advanced-hue-motion-sensor.groovy
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/**
* Advanced Hue Motion Sensor
* Version 1.0.4
* Download: https://github.com/apwelsh/hubitat
* Description:
* This is a child device handler for the Advance Hue Bridge Integration App. This device reports light level
* and battery level from a Hue connected sensor. Although this can work in poll mode, it is highly recommended to
* use the event stream based push notifications
*-------------------------------------------------------------------------------------------------------------------
* Copyright 2020 Armand Peter Welsh
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
* documentation files (the 'Software'), to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
* and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all copies or substantial portions of
* the Software.
*
* THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO
* THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*-------------------------------------------------------------------------------------------------------------------
**/
import groovy.transform.Field
@Field static final Boolean DEFAULT_LOG_ENABLE = true
@Field static final Boolean DEFAULT_DBG_ENABLE = false
@Field static final String SETTING_LOG_ENABLE = 'logEnable'
@Field static final String SETTING_DBG_ENABLE = 'debug'
@Field static final String SETTING_SENSITIVITY = 'sensitivity'
metadata {
definition (
name: 'AdvancedHueMotionSensor',
namespace: 'apwelsh',
author: 'Armand Welsh',
importUrl: 'https://raw.githubusercontent.com/apwelsh/hubitat/master/hue/device/advanced-hue-motion-sensor.groovy') {
capability 'MotionSensor'
capability 'Battery'
capability 'Refresh'
attribute 'status', 'string' // expect enabled/disabled
attribute 'health', 'string' // reachable/unreachable
}
}
preferences {
input name: SETTING_LOG_ENABLE,
type: 'bool',
defaultValue: DEFAULT_LOG_ENABLE,
title: 'Enable informational logging'
input name: SETTING_DBG_ENABLE,
type: 'bool',
defaultValue: DEFAULT_DBG_ENABLE,
title: 'Enable debug logging'
def sensitivitymax = 1
try {
Map config = parent.stateForNetworkId(deviceInstance.deviceNetworkId)?.config
sensitivitymax = config?.sensitivitymax?:1
int s = config?.sensitivity == null ? sensitivitymax : config.sensitivity
if (this[SETTING_SENSITIVITY] != s) {
updateSetting(SETTING_SENSITIVITY, s)
}
} catch (ex) {
log.error "${ex}"
}
input name: SETTING_SENSITIVITY,
type: 'number',
defaultValue: sensitivitymax,
range: 0..sensitivitymax,
title: 'Motion Sensitivity',
description: "Enter a value from 0 to ${sensitivitymax}"
}
private getDeviceInstance() {
parent.getChildDeviceById(device.deviceId)
}
void updateSetting(String name, Object value) {
device.updateSetting(name, value)
this[name] = value
}
/**
* Hubitat DTH Lifecycle Functions
**/
def installed() {
updated()
refresh()
}
def updated() {
if (this[SETTING_LOG_ENABLE] == null) { updateSetting(SETTING_LOG_ENABLE, DEFAULT_LOG_ENABLE) }
if (this[SETTING_DBG_ENABLE] == null) { updateSetting(SETTING_DBG_ENABLE, DEFAULT_DBG_ENABLE) }
if (this[SETTING_LOG_ENABLE]) { log.debug 'Preferences updated' }
Map configs = [:]
Map devcfg = parent.stateForNetworkId(device.deviceNetworkId)?.config
if (this[SETTING_SENSITIVITY] != devcfg[SETTING_SENSITIVITY]) { configs[SETTING_SENSITIVITY] = this[SETTING_SENSITIVITY] }
parent.setDeviceConfig(this, configs)
}
/*
* Device Capability Interface Functions
*/
void refresh() {
if (this[SETTING_DBG_ENABLE]) { log.debug "Sensor (${this}) refreshing" }
parent.getDeviceState(this)
}
void setHueProperty(Map args) {
}