mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-03-27 21:04:15 +00:00
Initial commit
This commit is contained in:
@@ -0,0 +1,156 @@
|
||||
/**
|
||||
* Smart Lock / Unlock
|
||||
*
|
||||
* Copyright 2014 Arnaud
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
|
||||
* in compliance with the License. You may obtain a copy of the License at:
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed
|
||||
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License
|
||||
* for the specific language governing permissions and limitations under the License.
|
||||
*
|
||||
*/
|
||||
definition(
|
||||
name: "Smart Lock / Unlock",
|
||||
namespace: "",
|
||||
author: "Arnaud",
|
||||
description: "Automatically locks door X minutes after being closed and keeps door unlocked if door is open.",
|
||||
category: "Safety & Security",
|
||||
iconUrl: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience.png",
|
||||
iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png")
|
||||
|
||||
preferences
|
||||
{
|
||||
section("Select the door lock:") {
|
||||
input "lock1", "capability.lock", required: true
|
||||
}
|
||||
section("Select the door contact sensor:") {
|
||||
input "contact1", "capability.contactSensor", required: true
|
||||
}
|
||||
section("Automatically lock the door when closed...") {
|
||||
input "minutesLater", "number", title: "Delay (in minutes):", required: true
|
||||
}
|
||||
section("Automatically unlock the door when open...") {
|
||||
input "secondsLater", "number", title: "Delay (in seconds):", required: true
|
||||
}
|
||||
section( "Push notification?" ) {
|
||||
input "sendPushMessage", "enum", title: "Send push notification?", metadata:[values:["Yes", "No"]], required: false
|
||||
}
|
||||
section( "Text message?" ) {
|
||||
input "sendText", "enum", title: "Send text message notification?", metadata:[values:["Yes", "No"]], required: false
|
||||
input "phoneNumber", "phone", title: "Enter phone number:", required: false
|
||||
}
|
||||
}
|
||||
|
||||
def installed()
|
||||
{
|
||||
initialize()
|
||||
}
|
||||
|
||||
def updated()
|
||||
{
|
||||
unsubscribe()
|
||||
unschedule()
|
||||
initialize()
|
||||
}
|
||||
|
||||
def initialize()
|
||||
{
|
||||
log.debug "Settings: ${settings}"
|
||||
subscribe(lock1, "lock", doorHandler, [filterEvents: false])
|
||||
subscribe(lock1, "unlock", doorHandler, [filterEvents: false])
|
||||
subscribe(contact1, "contact.open", doorHandler)
|
||||
subscribe(contact1, "contact.closed", doorHandler)
|
||||
}
|
||||
|
||||
def lockDoor()
|
||||
{
|
||||
if (lock1.latestValue("lock") == "unlocked")
|
||||
{
|
||||
log.debug "Locking $lock1..."
|
||||
lock1.lock()
|
||||
log.debug ("Sending Push Notification...")
|
||||
if (sendPushMessage != "No") sendPush("$lock1 locked after $contact1 was closed for $minutesLater minute(s)!")
|
||||
log.debug("Sending text message...")
|
||||
if ((sendText == "Yes") && (phoneNumber != "0")) sendSms(phoneNumber, "$lock1 locked after $contact1 was closed for $minutesLater minute(s)!")
|
||||
}
|
||||
else if (lock1.latestValue("lock") == "locked")
|
||||
{
|
||||
log.debug "$lock1 was already locked..."
|
||||
}
|
||||
}
|
||||
|
||||
def unlockDoor()
|
||||
{
|
||||
if (lock1.latestValue("lock") == "locked")
|
||||
{
|
||||
log.debug "Unlocking $lock1..."
|
||||
lock1.unlock()
|
||||
log.debug ("Sending Push Notification...")
|
||||
if (sendPushMessage != "No") sendPush("$lock1 unlocked after $contact1 was open for $secondsLater seconds(s)!")
|
||||
log.debug("Sending text message...")
|
||||
if ((sendText == "Yes") && (phoneNumber != "0")) sendSms(phoneNumber, "$lock1 unlocked after $contact1 was open for $secondsLater seconds(s)!")
|
||||
}
|
||||
else if (lock1.latestValue("lock") == "unlocked")
|
||||
{
|
||||
log.debug "$lock1 was already unlocked..."
|
||||
}
|
||||
}
|
||||
|
||||
def doorHandler(evt)
|
||||
{
|
||||
if ((contact1.latestValue("contact") == "open") && (evt.value == "locked"))
|
||||
{
|
||||
def delay = secondsLater
|
||||
runIn (delay, unlockDoor)
|
||||
}
|
||||
else if ((contact1.latestValue("contact") == "open") && (evt.value == "unlocked"))
|
||||
{
|
||||
unschedule (unlockDoor)
|
||||
}
|
||||
else if ((contact1.latestValue("contact") == "closed") && (evt.value == "locked"))
|
||||
{
|
||||
unschedule (lockDoor)
|
||||
}
|
||||
else if ((contact1.latestValue("contact") == "closed") && (evt.value == "unlocked"))
|
||||
{
|
||||
log.debug "Unlocking $lock1..."
|
||||
lock1.unlock()
|
||||
def delay = (minutesLater * 60)
|
||||
runIn (delay, lockDoor)
|
||||
}
|
||||
else if ((lock1.latestValue("lock") == "unlocked") && (evt.value == "open"))
|
||||
{
|
||||
unschedule (lockDoor)
|
||||
log.debug "Unlocking $lock1..."
|
||||
lock1.unlock()
|
||||
}
|
||||
else if ((lock1.latestValue("lock") == "unlocked") && (evt.value == "closed"))
|
||||
{
|
||||
log.debug "Unlocking $lock1..."
|
||||
lock1.unlock()
|
||||
def delay = (minutesLater * 60)
|
||||
runIn (delay, lockDoor)
|
||||
}
|
||||
else if ((lock1.latestValue("lock") == "locked") && (evt.value == "open"))
|
||||
{
|
||||
unschedule (lockDoor)
|
||||
log.debug "Unlocking $lock1..."
|
||||
lock1.unlock()
|
||||
}
|
||||
else if ((lock1.latestValue("lock") == "locked") && (evt.value == "closed"))
|
||||
{
|
||||
unschedule (lockDoor)
|
||||
log.debug "Unlocking $lock1..."
|
||||
lock1.unlock()
|
||||
}
|
||||
else
|
||||
{
|
||||
log.debug "Problem with $lock1, the lock might be jammed!"
|
||||
unschedule (lockDoor)
|
||||
unschedule (unlockDoor)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user