Difference between revisions of "App Object"

From Hubitat Documentation
Jump to: navigation, search
(Added a few more api url methods)
(subscribe)
Line 78: Line 78:
 
:: <code>void subscribe(InstalledAppWrapper app, handlerMethod)</code>
 
:: <code>void subscribe(InstalledAppWrapper app, handlerMethod)</code>
 
:: <code>void subscribe(Location location, handlerMethod)</code>
 
:: <code>void subscribe(Location location, handlerMethod)</code>
 +
:: <code>void subscribe(DeviceWrapper device, String handlerMethod, Map options = null)</code>
 +
:: <code>void subscribe(DeviceWrapperList devices, String handlerMethod, Map options = null)</code>
 
:: <code>void subscribe(DeviceWrapper device, String attributeName, handlerMethod, Map options = null)</code>
 
:: <code>void subscribe(DeviceWrapper device, String attributeName, handlerMethod, Map options = null)</code>
 
:: <code>void subscribe(DeviceWrapperList devices, String attributeName, handlerMethod, Map options = null)</code>
 
:: <code>void subscribe(DeviceWrapperList devices, String attributeName, handlerMethod, Map options = null)</code>

Revision as of 14:39, 12 May 2020

Provided Methods

createAccessToken

Creates an OAuth access token that can be used as part of the OAuth functionality of a properly configured app. The function will return the token, but will also automatically set the state variable state.accessToken to the return value. This value can then be passed to any API Endpoint (for example those defined in the mappings section of an app) using a query string parameter called access_token.
Signature
String createAccessToken()
Parameters
None
Returns
The OAuth access token.

getApiServerUrl

Returns the base URL of the Hubitat cloud API.
Signature
String getApiServerUrl()
Parameters
None
Returns
The base URL of the Hubitat cloud API, generally https://cloud.hubitat.com/api

getFullApiServerUrl

Returns the full URL of the Hubitat cloud API for a specific App.
Signature
String getFullApiServerUrl()
Parameters
None
Returns
The URL of the Hubitat cloud API for the app, generally https://cloud.hubitat.com/api/hubid/apps/appid

getLocalApiServerUrl

Returns the base URL of the Hubitat local API.
Signature
String getLocalApiServerUrl()
Parameters
None
Returns
The base URL of the Hubitat local API, generally https://hubip/apps/api

getFullLocalApiServerUrl

Returns the base URL of the Hubitat local API for a specific App.
Signature
String getFullLocalApiServerUrl()
Parameters
None
Returns
he URL of the Hubitat local API for the app, generally generally https://hubip/apps/api/appid

getHubUID

Retrieves a unique identifier that represents your hub.
Signature
String getHubUID()
Parameters
None
Returns
A UUID that uniquely identifies your hub.

subscribe

Subscribe to events sent from a device, app or location.
Signature
void subscribe(InstalledAppWrapper app, handlerMethod)
void subscribe(Location location, handlerMethod)
void subscribe(DeviceWrapper device, String handlerMethod, Map options = null)
void subscribe(DeviceWrapperList devices, String handlerMethod, Map options = null)
void subscribe(DeviceWrapper device, String attributeName, handlerMethod, Map options = null)
void subscribe(DeviceWrapperList devices, String attributeName, handlerMethod, Map options = null)
void subscribe(Location location, String attributeName, handlerMethod, Map options = null)


Parameters
app - Installed App to subscribe to.
location - Location to subscribe to.
device - Device to subscribe to.
handlerMethod - The method to run when an event is received.
attributeName - The name of the attribute to subscribe to.
options - Optional values to configure the subscribe. Possible values:
filterEvents - Used for device subscriptions. Set to false to receive all events, defaults to true and events that do not have a changed value will not be processed.

unsubscribe

Unsubscribe from events sent from a device or all event subscriptions.
Signature
void unsubscribe()
void unsubscribe(DeviceWrapper device)
void unsubscribe(List<DeviceWrapper> deviceList)
void unsubscribe(DeviceWrapper device, String attributeName) (Since 2.0.7)
void unsubscribe(List<DeviceWrapper> deviceList, String attributeName) (Since 2.1.0)
void unsubscribe(DeviceWrapper device, String attributeName, String handlerMethod) (Since 2.1.0)
void unsubscribe(List<DeviceWrapper> deviceList, String attributeName, String handlerMethod) (Since 2.1.0)
void unsubscribe(InstalledAppWrapper installedApp) (Since 2.1.2)
void unsubscribe(Location location) (Since 2.1.2)
void unsubscribe(Location location, String attributeName) (Since 2.1.2)
void unsubscribe(String handlerMethod) (Since 2.1.2)
Parameters
device - The device to unsubscribe from.
deviceList - A list of devices to unsubscribe from.
attributeName - which attribute you want to unsubscribe from.
handlerMethod - The name of a method which was subscribed to a device event.
location - The location to unsubscribe from.
installedApp - The installed app to unsubscribe from.
Returns
None

addChildDevice

Creates a new child device and returns that device from the method call.
Signature
ChildDeviceWrapper addChildDevice(String namespace, String typeName, String deviceNetworkId) (since 2.1.9)
ChildDeviceWrapper addChildDevice(String namespace, String typeName, String deviceNetworkId, Map properties) (since 2.1.9)
ChildDeviceWrapper addChildDevice(String namespace, String typeName, String deviceNetworkId, Long hubId) (deprecated)
ChildDeviceWrapper addChildDevice(String namespace, String typeName, String deviceNetworkId, Long hubId, Map properties) (deprecated)
Parameters
namespace - The namespace of the child driver to add as a child device (optional, if not specified it will default the the namespace of the parent)
typeName - The name of the child driver to add as a child device
deviceNetworkId - unique identifier for this device
hubId - present for backwards compatibility, pass 1.
properties - optional parameters for this child device. Possible values listed below
Properties
boolean isComponent - true or false, if true, device will still show up in device list but will not be able to be deleted or edited in the UI. If false, device can be modified/deleted on the UI.
String name - name of child device, if not specified, driver name is used.
String label - label of child device, if not specified it is left blank.
Returns
ChildDeviceWrapper

getChildDevices

Gets a list of all child devices for this device.
Signature
List<ChildDeviceWrapper> getChildDevices()
List<ChildDeviceWrapper> getAllChildDevices()
Parameters
None
Returns
List<ChildDeviceWrapper>

getChildDevice

Gets a specific child device with the device network id specified.
Signature
ChildDeviceWrapper getChildDevice(String deviceNetworkId)
Parameters
deviceNetworkId - The unique identifier for the device
Returns
ChildDeviceWrapper

deleteChildDevice

Deletes a specific child device with the device network id sepcified.
Signature
void deleteChildDevice(String deviceNetworkId)
Parameters
deviceNetworkId - The unique identifier for the device
Returns
None

User Defined Methods

installed

This method is called when the app is first installed.
Signature
void installed()

updated

This method is called when the preferences of an installed app are updated.
Signature
void updated()

uninstalled

This method is called when the app is uninstalled. This method can be used to do any cleanup that is necessary.
Signature
void uninstalled()

Additional to be documented

Map getState()
String apiServerUrl(String url)
String localApiServerUrl(String url)
String fullLocalApiServerUrl(String url)
void setLocationMode(String mode)
void pause(Long millisecs)
InstalledAppWrapper getParent()
InstalledAppWrapper addChildApp(String namespace, String name, String label, Map properties = null)
void deleteChildApp(Long childAppId)
DeviceWrapper getSubscribedDeviceById(Long deviceId)
void sendEvent(Map properties)
void sendEvent(DeviceWrapper device, Map properties)
void sendEvent(String dni, Map properties)
List<Event> getLocationEventsSince(String attributeName, Date startDate, Map options = null)
void subscribe(Object thing, String attributeName, handlerMethod, Map options = null)
void subscribe(location, handlerMethod)
List<InstalledApp> getAllChildApps()
List<InstalledApp> getChildApps()
InstalledAppWrapper getChildAppById(Long childAppId)
InstalledAppWrapper getChildAppByLabel(String childAppLabel)