Key | Value | Example Payload | Description |
---|---|---|---|
clearCache | true | {"clearCache": true} |
Clears the browser cache |
eval | JavaScript | {"eval": "alert('Hello World!');"} |
Evaluates Javascript in the dashboard |
audio | URL | {"audio": "http://<url>"} |
Play the audio specified by the URL immediately |
relaunch | true | {"relaunch": true} |
Relaunches the dashboard from configured launchUrl |
reload | true | {"reload": true} |
Reloads the current page immediately |
url | URL | {"url": "http://<url>"} |
Browse to a new URL immediately |
wake | true | {"wake": true} |
Wakes the screen if it is asleep |
- Commands are constructed via valid JSON. It is possible to string multiple commands together:
- eg,
{"clearCache":true, "relaunch":true}
- eg,
- For REST
- POST the JSON to URL
http://[mywallpanel]:2971/api/command
- POST the JSON to URL
- For MQTT
- WallPanel subscribes to topic
[baseTopic]/command
- Default Topic:
wallpanel/mywallpanel/command
- Default Topic:
- Publish a JSON payload to this topic
- WallPanel subscribes to topic
Key | Value | Example | Description |
---|---|---|---|
currentUrl | URL String | {"currentUrl":"http://hasbian:8123/states"} |
Current URL the Dashboard is displaying |
screenOn | true/false | {"screenOn":true} |
If the screen is currently on |
- State values are presented together as a JSON block
- eg,
{"currentUrl":"http://hasbian:8123/states","screenOn":true}
- eg,
- For REST
- GET the JSON from URL
http://[mywallpanel]:2971/api/state
- GET the JSON from URL
- For MQTT
- WallPanel publishes state to topic
[baseTopic]/state
- Default Topic:
wallpanel/mywallpanel/state
- Default Topic:
- WallPanel publishes state to topic
Sensor | Keys | Example | Notes |
---|---|---|---|
battery | unit, value, charging, acPlugged, usbPlugged | {"unit":"%", "value":"39", "acPlugged":false, "usbPlugged":true, "charging":true} |
|
brightness | unit, value | {"unit":"lx", "value":"920"} |
|
pressure | unit, value | {"unit":"??", "value":"21"} |
|
motion | value | {"value": false} |
Published immediately when motion detected |
NOTE: Sensor values are device specific. Not all devices will publish all sensor values.
- Sensor values are constructued as JSON per the above table
- For MQTT
- WallPanel publishes all sensors to MQTT under
[baseTopic]/sensor
- Each sensor publishes to a subtopic based on the type of sensor
- Example:
wallpanel/mywallpanel/sensor/battery
- Example:
- WallPanel publishes all sensors to MQTT under
Key | Value | Behavior | Default |
---|---|---|---|
app.deviceId | String | The unique identifier for this WallPanel device | mywallpanel |
app.preventSleep | true/false | Prevents the screen from turning off | false |
app.launchUrl | URL | The URL the Dashboard launches at | Tutorial Webpage |
app.showActivity | true/false | On-screen indication of browser activity | true |
camera.cameraId | int | The camera ID to attach to | 0 |
camera.motionEnabled | true/false | If the device camera is used for motion detection | false |
camera.motionCheckInterval | int | The interval the camera is polled for motion in milliseconds | 500 |
camera.motionLeniency | int | The leniency on changes in pictures between polls | 20 |
camera.motionMinLuma | int | The minimum light needed to perform motion detection | 1000 |
camera.motionWake | true/false | If motion activity should wake the device | true |
PLANNED: camera.webcamEnabled | true/false | If the device camera is used as a webcam | false |
http.enabled | true/false | Switch for REST(HTTP) being enabled | false |
http.port | int | The port to listen on for REST(HTTP) | 2971 |
mqtt.enabled | true/false | Switch for MQTT being enabled | false |
mqtt.serverName | String | The hostname/IP of the MQTT server | mqtt |
mqtt.serverPort | Int | The port number for TCP MQTT | 1883 |
mqtt.baseTopic | String | The root topic WallPanel will pub/sub under | wallpanel/{app.deviceId}/ |
mqtt.clientId | String | The client ID to connect to MQTT with | {app.deviceId} |
mqtt.username | String | The username to connect to MQTT with (or blank) | |
mqtt.password | String | The password to connect to MQTT with (or blank) | |
mqtt.sensorFrequency | Int | The frequency to post sensor data in seconds, or 0 to never post | 0 |
NOTE: Currently these are only configured locally, but the roadmap is considering external configuration (pull or push?) options