Execute custom scripts via homekit apps.
Core of the code written by @xxcombat. Great plugin that has served me well. Original plugin homebridge-script.
Because it appears that the original homebridge-script plugin has stopped being maintained and supported and PR's are also not being accepted. I've updated it to allow for executing a state script or work by checking for the existance of a file. Thanks to @ybizeul for the code snipet that allows for state.sh to execute. This plugin also works with the latest file-exists that broke the original plugin. While this fork depends on file-exists there is no need to install it seperately for this fork, as i've included it as a dependency.
(Requires node >=6.0.0)
npm install -g homebridge
npm install -g homebridge-script2
For autostart homebridge with OSX copy com.homebridge.startup.plist to /Library/LaunchDaemons
Homebridge-script configuration parameters
Name | Value | Required | Notes |
---|---|---|---|
accessory |
"Script2" | yes | Must be set to "Script2" and is required |
name |
(custom) | yes | Name of accessory that will appear in homekit app and is required |
on |
(custom) | yes | Location of script to execute the on action and is required |
off |
(custom) | yes | Location of script to execute the off action and is required |
fileState |
(custom) | fileState or state is required (see note) | Location of file that flags on or off current state. If this is configured the plugin will use the existence of this file to determine the current on or off state. If file exists, accessory is determined to be on. If file does not exist, accessory is determined to be off. This is not required. But if set, it will override using the state script. fileState or state must be configured. Use full path when setting this it's value. Do not use "~/". |
state |
(custom) | fileState or state is required (see note) | Location of script to execute the current state check. It must output to stdout the current state. It is not required if fileState is being used instead. fileState or state must be configured. |
on_value |
(custom) | no* (see note, default set to "true") | Used in conjunction with the state script. If using the state script this is the value that will be used to match against the state script output. If this value matches the output, then the accessory will be determined to be on. Required if using state script. |
unique_serial |
(custom) | no (default set to "Script2 Serial number") | If you have more than one "accessory" configured, please set unique values for each accessory. Unique values per accessory required for the Eve app. |
"accessories": [
{
"accessory": "Script2",
"name": "RPC3 Socket 1",
"on": "/var/homebridge/rpc3control/on.sh 1",
"off": "/var/homebridge/rpc3control/off.sh 1",
"state": "/var/homebridge/rpc3control/state.sh 1",
"fileState": "/var/homebridge/rpc3control/script1.flag",
"on_value" : "true",
"unique_serial" : "1234567"
}
]
"accessories": [
{
"accessory": "Script2",
"name": "Alarm of bike",
"on": "~/on.sh",
"off": "~/off.sh",
"state": "~/state.sh",
"on_value" : "true",
"unique_serial" : "1234567"
}
]