mirror of
https://github.com/mtan93/SmartThingsPublic.git
synced 2026-03-29 22:04:19 +01:00
Compare commits
1 Commits
MSA-1408-1
...
MSA-1401-1
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
82009b8e61 |
@@ -22,7 +22,6 @@ metadata {
|
|||||||
capability "Refresh"
|
capability "Refresh"
|
||||||
capability "Temperature Measurement"
|
capability "Temperature Measurement"
|
||||||
capability "Health Check"
|
capability "Health Check"
|
||||||
capability "Sensor"
|
|
||||||
|
|
||||||
command "enrollResponse"
|
command "enrollResponse"
|
||||||
|
|
||||||
|
|||||||
@@ -35,7 +35,6 @@ metadata {
|
|||||||
// status messages
|
// status messages
|
||||||
status "open": "command: 2001, payload: FF"
|
status "open": "command: 2001, payload: FF"
|
||||||
status "closed": "command: 2001, payload: 00"
|
status "closed": "command: 2001, payload: 00"
|
||||||
status "wake up": "command: 8407, payload: "
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// UI tile definitions
|
// UI tile definitions
|
||||||
@@ -175,7 +174,7 @@ def zwaveEvent(physicalgraph.zwave.commands.wakeupv1.WakeUpNotification cmd)
|
|||||||
if (!state.lastbat || now() - state.lastbat > 53*60*60*1000) {
|
if (!state.lastbat || now() - state.lastbat > 53*60*60*1000) {
|
||||||
cmds << command(zwave.batteryV1.batteryGet())
|
cmds << command(zwave.batteryV1.batteryGet())
|
||||||
} else {
|
} else {
|
||||||
cmds << zwave.wakeUpV1.wakeUpNoMoreInformation().format()
|
cmds << zwave.wakeUpV1.wakeUpNoMoreInformation()
|
||||||
}
|
}
|
||||||
[event, response(cmds)]
|
[event, response(cmds)]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,131 @@
|
|||||||
|
/**
|
||||||
|
* LifX Scene Manager
|
||||||
|
*
|
||||||
|
* Copyright 2016 Patrick Killian
|
||||||
|
*
|
||||||
|
* 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: "LifX Scene Manager",
|
||||||
|
namespace: "climbingcoder",
|
||||||
|
author: "Patrick Killian",
|
||||||
|
description: "When your mode changes, automatically activate a Lifx lighting scene with the same name",
|
||||||
|
category: "Convenience",
|
||||||
|
iconUrl: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience.png",
|
||||||
|
iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png",
|
||||||
|
iconX3Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png")
|
||||||
|
|
||||||
|
|
||||||
|
preferences {
|
||||||
|
section("Configuration") {
|
||||||
|
input(name:"apikey", type:"text", title:"LifX API Token", required:true)
|
||||||
|
input(name:"fadeTime", type:"number", title:"Fade Time", description:"Seconds of fade between scenes", required:true)
|
||||||
|
}
|
||||||
|
section("Getting a LifX API Token") {
|
||||||
|
paragraph "1. Go to https://cloud.lifx.com/sign_in and sign in with your LifX account"
|
||||||
|
paragraph "2. Click on your email address and then choose settings from the drop down menu"
|
||||||
|
paragraph "3. Click 'Generate Token' and give your token any name"
|
||||||
|
paragraph "4. Copy your token to the required field above and save it somewhere else for reference"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
def installed() {
|
||||||
|
log.debug "Installed with settings: ${settings}"
|
||||||
|
initialize()
|
||||||
|
}
|
||||||
|
|
||||||
|
def updated() {
|
||||||
|
log.debug "Updated with settings: ${settings}"
|
||||||
|
unsubscribe()
|
||||||
|
initialize()
|
||||||
|
}
|
||||||
|
|
||||||
|
def initialize() {
|
||||||
|
subscribe(location, "mode", modeChangeHandler)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def modeChangeHandler(evt) {
|
||||||
|
log.debug "mode changed to ${evt.value}"
|
||||||
|
def sceneUUID = ""
|
||||||
|
sceneUUID = findMatchingLifxScene("${evt.value}")
|
||||||
|
if (sceneUUID == "") {
|
||||||
|
log.debug "No matching scene found"
|
||||||
|
} else {
|
||||||
|
activateLifxScene("${sceneUUID}")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the UUID of a LifX scene that matches
|
||||||
|
* the passed in sceneName by obtaining a list
|
||||||
|
* of all available scenes and comparing them
|
||||||
|
* to the passed in name
|
||||||
|
*
|
||||||
|
* @param sceneName - the name of the desired scene
|
||||||
|
*
|
||||||
|
* @return UUID - the UUID of any matching scenes found
|
||||||
|
*/
|
||||||
|
def findMatchingLifxScene(sceneName) {
|
||||||
|
log.debug ("Getting list of LifX scenes")
|
||||||
|
def params = [
|
||||||
|
headers: ["Authorization": "Bearer ${settings.apikey}"],
|
||||||
|
uri: "https://api.lifx.com/v1/scenes",
|
||||||
|
body: []
|
||||||
|
]
|
||||||
|
def uuid = ""
|
||||||
|
|
||||||
|
try {
|
||||||
|
httpGet(params) { resp ->
|
||||||
|
log.debug "response status code: ${resp.status}"
|
||||||
|
resp.data.each {
|
||||||
|
log.debug("Found scene '${it.name}'")
|
||||||
|
if ("${it.name}" == sceneName) {
|
||||||
|
uuid = "${it.uuid}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
log.error "something went wrong: $e"
|
||||||
|
} finally {
|
||||||
|
return uuid
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calls the Lifx http endpoint to activate a scene with
|
||||||
|
* the given UUID
|
||||||
|
*
|
||||||
|
* @param UUID - the UUID of the scene to activate
|
||||||
|
*/
|
||||||
|
def activateLifxScene(UUID) {
|
||||||
|
log.debug "Activating scene with UUID '${UUID}'"
|
||||||
|
def params = [
|
||||||
|
headers: ["Authorization": "Bearer ${settings.apikey}"],
|
||||||
|
uri: "https://api.lifx.com/v1/scenes/scene_id:${UUID}/activate",
|
||||||
|
body: [
|
||||||
|
duration: "${settings.fadeTime}"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
|
||||||
|
try {
|
||||||
|
httpPut(params) { resp ->
|
||||||
|
log.debug "response status code: ${resp.status}"
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
log.error "something went wrong: $e"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -1,103 +0,0 @@
|
|||||||
/**
|
|
||||||
* Curb Control
|
|
||||||
*
|
|
||||||
* Copyright 2016 Savanni D'Gerinel
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
definition(
|
|
||||||
name: "Curb Control",
|
|
||||||
namespace: "curb-v2",
|
|
||||||
author: "Savanni D'Gerinel",
|
|
||||||
description: "Control point for Curb/SmartThings integration",
|
|
||||||
category: "Green Living",
|
|
||||||
iconUrl: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience.png",
|
|
||||||
iconX2Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png",
|
|
||||||
iconX3Url: "https://s3.amazonaws.com/smartapp-icons/Convenience/Cat-Convenience@2x.png",
|
|
||||||
oauth: true)
|
|
||||||
|
|
||||||
|
|
||||||
preferences {
|
|
||||||
section("Allow Endpoint to Control These Things...") {
|
|
||||||
input "switches", "capability.switch", title: "Which Switches?", multiple: true, required: false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
mappings {
|
|
||||||
|
|
||||||
path("/switches") {
|
|
||||||
action: [
|
|
||||||
GET: "listSwitches"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
path("/switches/:id") {
|
|
||||||
action: [
|
|
||||||
GET: "showSwitch"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
path("/switches/:id/:command") {
|
|
||||||
action: [
|
|
||||||
PUT: "updateSwitch"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
def installed() {}
|
|
||||||
|
|
||||||
def updated() {}
|
|
||||||
|
|
||||||
|
|
||||||
//switches
|
|
||||||
def listSwitches() {
|
|
||||||
switches.collect{device(it,"switch")}
|
|
||||||
}
|
|
||||||
|
|
||||||
def showSwitch() {
|
|
||||||
show(switches, "switch")
|
|
||||||
}
|
|
||||||
void updateSwitch() {
|
|
||||||
update(switches)
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
def deviceHandler(evt) {}
|
|
||||||
|
|
||||||
private void update(devices) {
|
|
||||||
log.debug "update, request: params: ${params}, devices: $devices.id"
|
|
||||||
|
|
||||||
|
|
||||||
//def command = request.JSON?.command
|
|
||||||
def command = params.command
|
|
||||||
//let's create a toggle option here
|
|
||||||
if (command)
|
|
||||||
{
|
|
||||||
def device = devices.find { it.id == params.id }
|
|
||||||
if (!device) {
|
|
||||||
httpError(404, "Device not found")
|
|
||||||
} else {
|
|
||||||
if(command == "toggle")
|
|
||||||
{
|
|
||||||
if(device.currentValue('switch') == "on")
|
|
||||||
device.off();
|
|
||||||
else
|
|
||||||
device.on();;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private show(devices, type) {
|
|
||||||
def device = devices.find { it.id == params.id }
|
|
||||||
if (!device) {
|
|
||||||
httpError(404, "Device not found")
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
def attributeName = type == "motionSensor" ? "motion" : type
|
|
||||||
def s = device.currentState(attributeName)
|
|
||||||
[id: device.id, label: device.displayName, value: s?.value, unitTime: s?.date?.time, type: type]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private device(it, type) {
|
|
||||||
it ? [id: it.id, label: it.label, type: type] : null
|
|
||||||
}
|
|
||||||
@@ -237,7 +237,7 @@ def completionPage() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
section("Notifications") {
|
section("Notifications") {
|
||||||
input("recipients", "contact", title: "Send notifications to", required: false) {
|
input("recipients", "contact", title: "Send notifications to") {
|
||||||
input(name: "completionPhoneNumber", type: "phone", title: "Text This Number", description: "Phone number", required: false)
|
input(name: "completionPhoneNumber", type: "phone", title: "Text This Number", description: "Phone number", required: false)
|
||||||
input(name: "completionPush", type: "bool", title: "Send A Push Notification", description: "Phone number", required: false)
|
input(name: "completionPush", type: "bool", title: "Send A Push Notification", description: "Phone number", required: false)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user