mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-04-02 06:13:07 +01:00
Z-Wave D/W: send requests secure encapsulated when necessary DVCSMP-1826
This commit is contained in:
@@ -28,8 +28,7 @@ metadata {
|
|||||||
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x98"
|
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x98"
|
||||||
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x86,0x72,0x98", outClusters: "0x5A,0x82"
|
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x86,0x72,0x98", outClusters: "0x5A,0x82"
|
||||||
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x80,0x71,0x85,0x70,0x72,0x86,0x30,0x31,0x84,0x59,0x73,0x5A,0x8F,0x98,0x7A", outClusters:"0x20" // Philio multi+
|
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x80,0x71,0x85,0x70,0x72,0x86,0x30,0x31,0x84,0x59,0x73,0x5A,0x8F,0x98,0x7A", outClusters:"0x20" // Philio multi+
|
||||||
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x72,0x5A,0x80,0x73,0x86,0x84,0x85,0x59,0x71,0x70,0x7A,0x98" // Vision door/window
|
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x72,0x5A,0x80,0x73,0x84,0x85,0x59,0x71,0x70,0x7A,0x98" // Vision door/window
|
||||||
fingerprint deviceId: "0x0701", inClusters: "0x5E,0x98,0x86,0x72,0x5A,0x85,0x59,0x73,0x80,0x71,0x31,0x70,0x84,0x7A" // Vision Motion
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// simulator metadata
|
// simulator metadata
|
||||||
@@ -82,22 +81,22 @@ def updated() {
|
|||||||
def cmds = []
|
def cmds = []
|
||||||
if (!state.MSR) {
|
if (!state.MSR) {
|
||||||
cmds = [
|
cmds = [
|
||||||
zwave.manufacturerSpecificV2.manufacturerSpecificGet().format(),
|
command(zwave.manufacturerSpecificV2.manufacturerSpecificGet()),
|
||||||
"delay 1200",
|
"delay 1200",
|
||||||
zwave.wakeUpV1.wakeUpNoMoreInformation().format()
|
zwave.wakeUpV1.wakeUpNoMoreInformation()
|
||||||
]
|
]
|
||||||
} else if (!state.lastbat) {
|
} else if (!state.lastbat) {
|
||||||
cmds = []
|
cmds = []
|
||||||
} else {
|
} else {
|
||||||
cmds = [zwave.wakeUpV1.wakeUpNoMoreInformation().format()]
|
cmds = [zwave.wakeUpV1.wakeUpNoMoreInformation()]
|
||||||
}
|
}
|
||||||
response(cmds)
|
response(cmds)
|
||||||
}
|
}
|
||||||
|
|
||||||
def configure() {
|
def configure() {
|
||||||
delayBetween([
|
commands([
|
||||||
zwave.manufacturerSpecificV2.manufacturerSpecificGet().format(),
|
zwave.manufacturerSpecificV2.manufacturerSpecificGet(),
|
||||||
batteryGetCommand()
|
zwave.batteryV1.batteryGet()
|
||||||
], 6000)
|
], 6000)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -148,12 +147,11 @@ def zwaveEvent(physicalgraph.zwave.commands.notificationv3.NotificationReport cm
|
|||||||
result << sensorValueEvent(1)
|
result << sensorValueEvent(1)
|
||||||
} else if (cmd.event == 0x03) {
|
} else if (cmd.event == 0x03) {
|
||||||
result << createEvent(descriptionText: "$device.displayName covering was removed", isStateChange: true)
|
result << createEvent(descriptionText: "$device.displayName covering was removed", isStateChange: true)
|
||||||
result << response(zwave.wakeUpV1.wakeUpIntervalSet(seconds:4*3600, nodeid:zwaveHubNodeId))
|
if(!state.MSR) result << response(command(zwave.manufacturerSpecificV2.manufacturerSpecificGet()))
|
||||||
if(!state.MSR) result << response(zwave.manufacturerSpecificV2.manufacturerSpecificGet())
|
|
||||||
} else if (cmd.event == 0x05 || cmd.event == 0x06) {
|
} else if (cmd.event == 0x05 || cmd.event == 0x06) {
|
||||||
result << createEvent(descriptionText: "$device.displayName detected glass breakage", isStateChange: true)
|
result << createEvent(descriptionText: "$device.displayName detected glass breakage", isStateChange: true)
|
||||||
} else if (cmd.event == 0x07) {
|
} else if (cmd.event == 0x07) {
|
||||||
if(!state.MSR) result << response(zwave.manufacturerSpecificV2.manufacturerSpecificGet())
|
if(!state.MSR) result << response(command(zwave.manufacturerSpecificV2.manufacturerSpecificGet()))
|
||||||
result << createEvent(name: "motion", value: "active", descriptionText:"$device.displayName detected motion")
|
result << createEvent(name: "motion", value: "active", descriptionText:"$device.displayName detected motion")
|
||||||
}
|
}
|
||||||
} else if (cmd.notificationType) {
|
} else if (cmd.notificationType) {
|
||||||
@@ -171,12 +169,11 @@ def zwaveEvent(physicalgraph.zwave.commands.wakeupv1.WakeUpNotification cmd)
|
|||||||
def event = createEvent(descriptionText: "${device.displayName} woke up", isStateChange: false)
|
def event = createEvent(descriptionText: "${device.displayName} woke up", isStateChange: false)
|
||||||
def cmds = []
|
def cmds = []
|
||||||
if (!state.MSR) {
|
if (!state.MSR) {
|
||||||
cmds << zwave.wakeUpV1.wakeUpIntervalSet(seconds:4*3600, nodeid:zwaveHubNodeId).format()
|
cmds << command(zwave.manufacturerSpecificV2.manufacturerSpecificGet())
|
||||||
cmds << zwave.manufacturerSpecificV2.manufacturerSpecificGet().format()
|
|
||||||
cmds << "delay 1200"
|
cmds << "delay 1200"
|
||||||
}
|
}
|
||||||
if (!state.lastbat || now() - state.lastbat > 53*60*60*1000) {
|
if (!state.lastbat || now() - state.lastbat > 53*60*60*1000) {
|
||||||
cmds << batteryGetCommand()
|
cmds << command(zwave.batteryV1.batteryGet())
|
||||||
} else {
|
} else {
|
||||||
cmds << zwave.wakeUpV1.wakeUpNoMoreInformation().format()
|
cmds << zwave.wakeUpV1.wakeUpNoMoreInformation().format()
|
||||||
}
|
}
|
||||||
@@ -213,7 +210,7 @@ def zwaveEvent(physicalgraph.zwave.commands.manufacturerspecificv2.ManufacturerS
|
|||||||
if (msr == "0086-0102-0059") {
|
if (msr == "0086-0102-0059") {
|
||||||
result << response(zwave.securityV1.securityMessageEncapsulation().encapsulate(zwave.batteryV1.batteryGet()).format())
|
result << response(zwave.securityV1.securityMessageEncapsulation().encapsulate(zwave.batteryV1.batteryGet()).format())
|
||||||
} else {
|
} else {
|
||||||
result << response(batteryGetCommand())
|
result << response(command(zwave.batteryV1.batteryGet()))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -221,7 +218,7 @@ def zwaveEvent(physicalgraph.zwave.commands.manufacturerspecificv2.ManufacturerS
|
|||||||
}
|
}
|
||||||
|
|
||||||
def zwaveEvent(physicalgraph.zwave.commands.securityv1.SecurityMessageEncapsulation cmd) {
|
def zwaveEvent(physicalgraph.zwave.commands.securityv1.SecurityMessageEncapsulation cmd) {
|
||||||
def encapsulatedCommand = cmd.encapsulatedCommand([0x20: 1, 0x85: 2, 0x70: 1])
|
def encapsulatedCommand = cmd.encapsulatedCommand([0x20: 1, 0x25: 1, 0x30: 1, 0x31: 5, 0x80: 1, 0x84: 1, 0x71: 3, 0x9C: 1])
|
||||||
// log.debug "encapsulated: $encapsulatedCommand"
|
// log.debug "encapsulated: $encapsulatedCommand"
|
||||||
if (encapsulatedCommand) {
|
if (encapsulatedCommand) {
|
||||||
state.sec = 1
|
state.sec = 1
|
||||||
@@ -233,12 +230,16 @@ def zwaveEvent(physicalgraph.zwave.Command cmd) {
|
|||||||
createEvent(descriptionText: "$device.displayName: $cmd", displayed: false)
|
createEvent(descriptionText: "$device.displayName: $cmd", displayed: false)
|
||||||
}
|
}
|
||||||
|
|
||||||
def batteryGetCommand() {
|
private command(physicalgraph.zwave.Command cmd) {
|
||||||
def cmd = zwave.batteryV1.batteryGet()
|
if (state.sec == 1) {
|
||||||
if (state.sec) {
|
zwave.securityV1.securityMessageEncapsulation().encapsulate(cmd).format()
|
||||||
cmd = zwave.securityV1.securityMessageEncapsulation().encapsulate(cmd)
|
} else {
|
||||||
|
cmd.format()
|
||||||
}
|
}
|
||||||
cmd.format()
|
}
|
||||||
|
|
||||||
|
private commands(commands, delay=200) {
|
||||||
|
delayBetween(commands.collect{ command(it) }, delay)
|
||||||
}
|
}
|
||||||
|
|
||||||
def retypeBasedOnMSR() {
|
def retypeBasedOnMSR() {
|
||||||
@@ -265,8 +266,8 @@ def retypeBasedOnMSR() {
|
|||||||
setDeviceType("Door / Window Sensor Plus (SG)")
|
setDeviceType("Door / Window Sensor Plus (SG)")
|
||||||
break
|
break
|
||||||
case "0109-2002-0205": // Vision Motion
|
case "0109-2002-0205": // Vision Motion
|
||||||
log.debug "Changing device type to Vision Motion Sensor Plus (SG)"
|
log.debug "Changing device type to Z-Wave Plus Motion/Temp Sensor"
|
||||||
setDeviceType("Vision Motion Sensor Plus (SG)")
|
setDeviceType("Z-Wave Plus Motion/Temp Sensor")
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user