mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-03-31 14:13:11 +01:00
Merge pull request #332 from SmartThingsCommunity/master
Merging changes into stage
This commit is contained in:
@@ -66,9 +66,20 @@ metadata {
|
|||||||
import physicalgraph.zwave.commands.doorlockv1.*
|
import physicalgraph.zwave.commands.doorlockv1.*
|
||||||
import physicalgraph.zwave.commands.usercodev1.*
|
import physicalgraph.zwave.commands.usercodev1.*
|
||||||
|
|
||||||
|
def updated() {
|
||||||
|
try {
|
||||||
|
if (!state.init) {
|
||||||
|
state.init = true
|
||||||
|
response(secureSequence([zwave.doorLockV1.doorLockOperationGet(), zwave.batteryV1.batteryGet()]))
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
log.warn "updated() threw $e"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
def parse(String description) {
|
def parse(String description) {
|
||||||
def result = null
|
def result = null
|
||||||
if (description.startsWith("Err")) {
|
if (description.startsWith("Err 106")) {
|
||||||
if (state.sec) {
|
if (state.sec) {
|
||||||
result = createEvent(descriptionText:description, displayed:false)
|
result = createEvent(descriptionText:description, displayed:false)
|
||||||
} else {
|
} else {
|
||||||
@@ -80,6 +91,8 @@ def parse(String description) {
|
|||||||
displayed: true,
|
displayed: true,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
} else if (description == "updated") {
|
||||||
|
return null
|
||||||
} else {
|
} else {
|
||||||
def cmd = zwave.parse(description, [ 0x98: 1, 0x72: 2, 0x85: 2, 0x86: 1 ])
|
def cmd = zwave.parse(description, [ 0x98: 1, 0x72: 2, 0x85: 2, 0x86: 1 ])
|
||||||
if (cmd) {
|
if (cmd) {
|
||||||
@@ -286,7 +299,7 @@ def zwaveEvent(physicalgraph.zwave.commands.alarmv2.AlarmReport cmd) {
|
|||||||
}
|
}
|
||||||
break
|
break
|
||||||
case 167:
|
case 167:
|
||||||
if (!state.lastbatt || (new Date().time) - state.lastbatt > 12*60*60*1000) {
|
if (!state.lastbatt || now() - state.lastbatt > 12*60*60*1000) {
|
||||||
map = [ descriptionText: "$device.displayName: battery low", isStateChange: true ]
|
map = [ descriptionText: "$device.displayName: battery low", isStateChange: true ]
|
||||||
result << response(secure(zwave.batteryV1.batteryGet()))
|
result << response(secure(zwave.batteryV1.batteryGet()))
|
||||||
} else {
|
} else {
|
||||||
@@ -431,7 +444,7 @@ def zwaveEvent(physicalgraph.zwave.commands.batteryv1.BatteryReport cmd) {
|
|||||||
} else {
|
} else {
|
||||||
map.value = cmd.batteryLevel
|
map.value = cmd.batteryLevel
|
||||||
}
|
}
|
||||||
state.lastbatt = new Date().time
|
state.lastbatt = now()
|
||||||
createEvent(map)
|
createEvent(map)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -499,15 +512,14 @@ def refresh() {
|
|||||||
cmds << "delay 4200"
|
cmds << "delay 4200"
|
||||||
cmds << zwave.associationV1.associationGet(groupingIdentifier:2).format() // old Schlage locks use group 2 and don't secure the Association CC
|
cmds << zwave.associationV1.associationGet(groupingIdentifier:2).format() // old Schlage locks use group 2 and don't secure the Association CC
|
||||||
cmds << secure(zwave.associationV1.associationGet(groupingIdentifier:1))
|
cmds << secure(zwave.associationV1.associationGet(groupingIdentifier:1))
|
||||||
state.associationQuery = new Date().time
|
state.associationQuery = now()
|
||||||
} else if (new Date().time - state.associationQuery.toLong() > 9000) {
|
} else if (secondsPast(state.associationQuery, 9)) {
|
||||||
log.debug "setting association"
|
|
||||||
cmds << "delay 6000"
|
cmds << "delay 6000"
|
||||||
cmds << zwave.associationV1.associationSet(groupingIdentifier:2, nodeId:zwaveHubNodeId).format()
|
cmds << zwave.associationV1.associationSet(groupingIdentifier:2, nodeId:zwaveHubNodeId).format()
|
||||||
cmds << secure(zwave.associationV1.associationSet(groupingIdentifier:1, nodeId:zwaveHubNodeId))
|
cmds << secure(zwave.associationV1.associationSet(groupingIdentifier:1, nodeId:zwaveHubNodeId))
|
||||||
cmds << zwave.associationV1.associationGet(groupingIdentifier:2).format()
|
cmds << zwave.associationV1.associationGet(groupingIdentifier:2).format()
|
||||||
cmds << secure(zwave.associationV1.associationGet(groupingIdentifier:1))
|
cmds << secure(zwave.associationV1.associationGet(groupingIdentifier:1))
|
||||||
state.associationQuery = new Date().time
|
state.associationQuery = now()
|
||||||
}
|
}
|
||||||
log.debug "refresh sending ${cmds.inspect()}"
|
log.debug "refresh sending ${cmds.inspect()}"
|
||||||
cmds
|
cmds
|
||||||
@@ -515,55 +527,22 @@ def refresh() {
|
|||||||
|
|
||||||
def poll() {
|
def poll() {
|
||||||
def cmds = []
|
def cmds = []
|
||||||
if (state.assoc != zwaveHubNodeId && secondsPast(state.associationQuery, 19 * 60)) {
|
// Only check lock state if it changed recently or we haven't had an update in an hour
|
||||||
log.debug "setting association"
|
def latest = device.currentState("lock")?.date?.time
|
||||||
cmds << zwave.associationV1.associationSet(groupingIdentifier:2, nodeId:zwaveHubNodeId).format()
|
if (!latest || !secondsPast(latest, 6 * 60) || secondsPast(state.lastPoll, 55 * 60)) {
|
||||||
cmds << secure(zwave.associationV1.associationSet(groupingIdentifier:1, nodeId:zwaveHubNodeId))
|
cmds << secure(zwave.doorLockV1.doorLockOperationGet())
|
||||||
cmds << zwave.associationV1.associationGet(groupingIdentifier:2).format()
|
state.lastPoll = now()
|
||||||
cmds << "delay 6000"
|
} else if (!state.lastbatt || now() - state.lastbatt > 53*60*60*1000) {
|
||||||
cmds << secure(zwave.associationV1.associationGet(groupingIdentifier:1))
|
cmds << secure(zwave.batteryV1.batteryGet())
|
||||||
cmds << "delay 6000"
|
state.lastbatt = now() //inside-214
|
||||||
state.associationQuery = new Date().time
|
|
||||||
} else {
|
|
||||||
// Only check lock state if it changed recently or we haven't had an update in an hour
|
|
||||||
def latest = device.currentState("lock")?.date?.time
|
|
||||||
if (!latest || !secondsPast(latest, 6 * 60) || secondsPast(state.lastPoll, 55 * 60)) {
|
|
||||||
cmds << secure(zwave.doorLockV1.doorLockOperationGet())
|
|
||||||
state.lastPoll = (new Date()).time
|
|
||||||
} else if (!state.MSR) {
|
|
||||||
cmds << zwave.manufacturerSpecificV1.manufacturerSpecificGet().format()
|
|
||||||
} else if (!state.fw) {
|
|
||||||
cmds << zwave.versionV1.versionGet().format()
|
|
||||||
} else if (!state.codes) {
|
|
||||||
state.pollCode = 1
|
|
||||||
cmds << secure(zwave.userCodeV1.usersNumberGet())
|
|
||||||
} else if (state.pollCode && state.pollCode <= state.codes) {
|
|
||||||
cmds << requestCode(state.pollCode)
|
|
||||||
} else if (!state.lastbatt || (new Date().time) - state.lastbatt > 53*60*60*1000) {
|
|
||||||
cmds << secure(zwave.batteryV1.batteryGet())
|
|
||||||
} else if (!state.enc) {
|
|
||||||
encryptCodes()
|
|
||||||
state.enc = 1
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
log.debug "poll is sending ${cmds.inspect()}"
|
if (cmds) {
|
||||||
device.activity()
|
log.debug "poll is sending ${cmds.inspect()}"
|
||||||
cmds ?: null
|
cmds
|
||||||
}
|
} else {
|
||||||
|
// workaround to keep polling from stopping due to lack of activity
|
||||||
private def encryptCodes() {
|
sendEvent(descriptionText: "skipping poll", isStateChange: true, displayed: false)
|
||||||
def keys = new ArrayList(state.keySet().findAll { it.startsWith("code") })
|
null
|
||||||
keys.each { key ->
|
|
||||||
def match = (key =~ /^code(\d+)$/)
|
|
||||||
if (match) try {
|
|
||||||
def keynum = match[0][1].toInteger()
|
|
||||||
if (keynum > 30 && !state[key]) {
|
|
||||||
state.remove(key)
|
|
||||||
} else if (state[key] && !state[key].startsWith("~")) {
|
|
||||||
log.debug "encrypting $key: ${state[key].inspect()}"
|
|
||||||
state[key] = encrypt(state[key])
|
|
||||||
}
|
|
||||||
} catch (java.lang.NumberFormatException e) { }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -672,7 +651,7 @@ private Boolean secondsPast(timestamp, seconds) {
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return (new Date().time - timestamp) > (seconds * 1000)
|
return (now() - timestamp) > (seconds * 1000)
|
||||||
}
|
}
|
||||||
|
|
||||||
private allCodesDeleted() {
|
private allCodesDeleted() {
|
||||||
|
|||||||
@@ -246,6 +246,9 @@ def toggle(devices) {
|
|||||||
else if (devices*.currentValue('lock').contains('locked')) {
|
else if (devices*.currentValue('lock').contains('locked')) {
|
||||||
devices.unlock()
|
devices.unlock()
|
||||||
}
|
}
|
||||||
|
else if (devices*.currentValue('lock').contains('unlocked')) {
|
||||||
|
devices.lock()
|
||||||
|
}
|
||||||
else if (devices*.currentValue('alarm').contains('off')) {
|
else if (devices*.currentValue('alarm').contains('off')) {
|
||||||
devices.siren()
|
devices.siren()
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user