Files
2015-08-04 15:49:03 -07:00

78 lines
2.9 KiB
Groovy

/**
* Copyright 2015 SmartThings
*
* 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.
*
* Mail Arrived
*
* Author: SmartThings
*/
definition(
name: "Mail Arrived",
namespace: "smartthings",
author: "SmartThings",
description: "Send a text when mail arrives in your mailbox using a SmartSense Multi on your mailbox door. Note: battery life may be impacted in cold climates.",
category: "Convenience",
iconUrl: "https://s3.amazonaws.com/smartapp-icons/Meta/mail_contact.png",
iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Meta/mail_contact@2x.png"
)
preferences {
section("When mail arrives...") {
input "accelerationSensor", "capability.accelerationSensor", title: "Where?"
}
section("Notify me...") {
input("recipients", "contact", title: "Send notifications to") {
input "pushNotification", "bool", title: "Push notification", required: false, defaultValue: "true"
input "phone1", "phone", title: "Phone number", required: false
}
}
}
def installed() {
subscribe(accelerationSensor, "acceleration.active", accelerationActiveHandler)
}
def updated() {
unsubscribe()
subscribe(accelerationSensor, "acceleration.active", accelerationActiveHandler)
}
def accelerationActiveHandler(evt) {
log.trace "$evt.value: $evt, $settings"
// Don't send a continuous stream of notifications
def deltaSeconds = 5
def timeAgo = new Date(now() - (1000 * deltaSeconds))
def recentEvents = accelerationSensor.eventsSince(timeAgo)
log.trace "Found ${recentEvents?.size() ?: 0} events in the last $deltaSeconds seconds"
def alreadySentNotifications = recentEvents.count { it.value && it.value == "active" } > 1
if (alreadySentNotifications) {
log.debug "Notifications already sent within the last $deltaSeconds seconds (phone1: $phone1, pushNotification: $pushNotification)"
}
else {
if (location.contactBookEnabled) {
log.debug "$accelerationSensor has moved, notifying ${recipients?.size()}"
sendNotificationToContacts("Mail has arrived!", recipients)
}
else {
if (phone1 != null && phone1 != "") {
log.debug "$accelerationSensor has moved, texting $phone1"
sendSms(phone1, "Mail has arrived!")
}
if (pushNotification) {
log.debug "$accelerationSensor has moved, sending push"
sendPush("Mail has arrived!")
}
}
}
}