Events and Subscriptions

Turn on a light when a door opens. Turn the lights off at sunrise. Send a message if a door opens when you’re not home. These are all examples of event-handler SmartApps. They follow a common pattern - subscribe to some Event, and take action when the Event happens.

This section will discuss Events and how you can subscribe to them in your SmartApp.

Subscribe to specific device Events

The most common use case for Event subscriptions is for device Events:

preferences {
    section {
        input "theSwitch", "capability.switch"

def install() {
    subscribe(theSwitch, "switch.on", switchOnHandler)

def switchOnHandler(evt) {
    log.debug "switch turned on!"

The handler method must accept an Event parameter.

Refer to the Event API documentation for more information about the Event object.

You can find the possible Events to subscribe to by referring to the Attributes column for a capability in the Capabilities Reference. The general form we use is “<attributeName>.<attributeValue>”. If the attribute does not have any possible values (for example, “battery”), you would just use the attribute name.

In the example above, the switch capability has the attribute “switch”, with possible values “on” and “off”. Putting these together, we use “switch.on”.

Subscribe to all device Events

You can also subscribe to all states by just specifying the attribute name:

subscribe(theSwitch, "switch", switchHandler)

def switchHandler(evt) {
    if (evt.value == "on") {
        log.debug "switch turned on!"
    } else if (evt.value == "off") {
        log.debug "switch turned off!"

In this case, the switchHandler method will be called for both the “on” and “off” Events.

Subscribe to multiple devices

If your SmartApp allows multiple devices, you can subscribe to Events for all the devices:

preferences {
    section {
        input "switches", "capability.switch", multiple: true

def installed() {
    subscribe(switches, "switch", switchesHandler)

def switchesHandler(evt) {
    log.debug "one of the configured switches changed states"

Subscribe to Location events

In addition to subscribing to device Events, you can also subscribe to Events for the user’s Location.

You can subscribe to the following Location Events:

Triggered when the mode changes.
Triggered when the geofence position changes for this Location. Does not get triggered when the fence is widened or narrowed - only fired when the position changes.
Triggered at sunset for this Location.
Triggered at sunrise for this Location.
Triggered around sunrise time. Used to get the time of the next sunrise for this Location.
Triggered around sunset time. Used to get the time of the next sunset for this Location.

Pass in the Location property automatically injected into every SmartApp as the first parameter to the subscribe method.

subscribe(location, "mode", modeChangeHandler)

// shortcut for mode change handler
subscribe(location, modeChangeHandler)

subscribe(location, "position", positionChange)
subscribe(location, "sunset", sunsetHandler)
subscribe(location, "sunrise", sunriseHandler)
subscribe(location, "sunsetTime", sunsetTimeHandler)
subscribe(location, "sunriseTime", sunriseTimeHandler)

Refer to the Sunset and Sunrise section for more information about sunrise and sunset.

The Event object

Event-handler methods must accept a single parameter, the Event itself.

Refer to the Event API documentation for more information.

A few of the common ways of using the Event:

def eventHandler(evt) {
    // get the event name, e.g., "switch"
    log.debug "This event name is ${}"

    // get the value of this event, e.g., "on" or "off"
    log.debug "The value of this event is ${evt.value}"

    // get the Date this event happened at
    log.debug "This event happened at ${}"

    // did the value of this event change from its previous state?
    log.debug "The value of this event is different from its previous value: ${evt.isStateChange()}"


The contents of each Event instance will vary depending on the exact Event. If you refer to the Event reference documentation, you will see different value methods, like “floatValue” or “dateValue”. These may or may not be populated depending on the specific Event, and may even throw exceptions if not applicable.

See also