-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathadvanced-hue-temperature-sensor.groovy
97 lines (79 loc) · 3.49 KB
/
advanced-hue-temperature-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
/**
* Advanced Hue Temperature Sensor
* Version 1.0.3
* 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'
metadata {
definition (
name: 'AdvancedHueTemperatureSensor',
namespace: 'apwelsh',
author: 'Armand Welsh',
importUrl: 'https://raw.githubusercontent.com/apwelsh/hubitat/master/hue/device/advanced-hue-temperature-sensor.groovy') {
capability 'Battery'
capability 'TemperatureMeasurement'
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'
}
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' }
}
/*
* Device Capability Interface Functions
*/
void refresh() {
if (this[SETTING_DBG_ENABLE]) { log.debug "Sensor (${this}) refreshing" }
parent.getDeviceState(this)
}
void setHueProperty(Map args) {
}