110 KiB
title |
---|
Endpoints |
import ApiEndpoint from '@site/static/js/api_endpoint.jsx'
For API endpoints marked with 🔒 you need use an authorization header with a Bearer
token.
The token is available for add-ons and Home Assistant using the
SUPERVISOR_TOKEN
environment variable.
To see more details about each endpoint, click on it to expand it.
Add-ons
Return overview information about installed add-ons.Payload:
key | type | description |
---|---|---|
addons | list | A list of Addon models |
Example response:
{
"addons": [
{
"name": "Awesome add-on",
"slug": "awesome_addon",
"description": "My awesome add-on",
"advanced": false,
"stage": "stable",
"repository": "core",
"version": null,
"version_latest": "1.0.1",
"update_available": false,
"installed": false,
"detached": true,
"available": true,
"build": false,
"url": null,
"icon": false,
"logo": false
}
]
}
Reloads the information stored about add-ons.
Get the changelog for an add-on.
Get the documentation for an add-on.
Get logs for an add-on via the Systemd journal backend.
The endpoint accepts the same headers and provides the same functionality as
/host/logs
.
Identical to /addons/<addon>/logs
except it continuously returns new log entries.
Get logs for an add-on related to a specific boot.
The bootid
parameter is interpreted in the same way as in
/host/logs/boots/<bootid>
and the endpoint otherwise provides the same
functionality as /host/logs
.
Identical to /addons/<addon>/logs/boots/<bootid>
except it continuously returns
new log entries.
Returned data:
key | type | description |
---|---|---|
advanced | boolean | true if advanced mode is enabled |
apparmor | string | disabled, default or the name of the profile |
arch | list | A list of supported architectures for the add-on |
audio | boolean | true if audio is enabled |
audio_input | float or null | The device index |
audio_output | float or null | The device index |
auth_api | boolean | true if auth api access is granted is enabled |
auto_uart | boolean | true if auto_uart access is granted is enabled |
auto_update | boolean | true if auto update is enabled |
available | boolean | true if the add-on is available |
boot | string | "auto" or "manual" |
boot_config | string | Default boot mode of addon or "manual_only" if boot mode cannot be auto |
build | boolean | true if local add-on |
changelog | boolean | true if changelog is available |
description | string | The add-on description |
detached | boolean | true if the add-on is running detached |
devices | list | A list of attached devices |
devicetree | boolean | true if devicetree access is granted is enabled |
discovery | list | A list of discovery services |
dns | list | A list of DNS servers used by the add-on |
docker_api | boolean | true if docker_api access is granted is enabled |
documentation | boolean | true if documentation is available |
full_access | boolean | true if full access access is granted is enabled |
gpio | boolean | true if gpio access is granted is enabled |
hassio_api | boolean | true if hassio api access is granted is enabled |
hassio_role | string | The hassio role (default, homeassistant, manager, admin) |
homeassistant | string or null | The minimum Home Assistant Core version |
homeassistant_api | boolean | true if homeassistant api access is granted is enabled |
host_dbus | boolean | true if host dbus access is granted is enabled |
host_ipc | boolean | true if host ipc access is granted is enabled |
host_network | boolean | true if host network access is granted is enabled |
host_pid | boolean | true if host pid access is granted is enabled |
host_uts | boolean | true if host UTS namespace access is enabled. |
hostname | string | The host name of the add-on |
icon | boolean | true if icon is available |
ingress | boolean | true if ingress is enabled |
ingress_entry | string or null | The ingress entrypoint |
ingress_panel | boolean or null | true if ingress_panel is enabled |
ingress_port | int or null | The ingress port |
ingress_url | string or null | The ingress URL |
ip_address | string | The IP address of the add-on |
kernel_modules | boolean | true if kernel module access is granted is enabled |
logo | boolean | true if logo is available |
long_description | string | The long add-on description |
machine | list | A list of supported machine types for the add-on |
name | string | The name of the add-on |
network | dictionary or null | The network configuration for the add-on |
network_description | dictionary or null | The description for the network configuration |
options | dictionary | The add-on configuration |
privileged | list | A list of hardwars/system attributes the add-onn has access to |
protected | boolean | true if protection mode is enabled |
rating | int | The addon rating |
repository | string | The URL to the add-on repository |
schema | dictionary or null | The schema for the add-on configuration |
services_role | list | A list of services and the add-ons role for that service |
slug | string | The add-on slug |
stage | string | The add-on stage (stable, experimental, deprecated) |
startup | string | The stage when the add-on is started (initialize, system, services, application, once) |
state | string or null | The state of the add-on (started, stopped) |
stdin | boolean | true if the add-on accepts stdin commands |
translations | dictionary | A dictionary containing content of translation files for the add-on |
udev | boolean | true if udev access is granted is enabled |
update_available | boolean | true if an update is available |
url | string or null | URL to more information about the add-on |
usb | list | A list of attached USB devices |
version | string | The installed version of the add-on |
version_latest | string | The latest version of the add-on |
video | boolean | true if video is enabled |
watchdog | boolean | true if watchdog is enabled |
webui | string or null | The URL to the web UI for the add-on |
signed | boolean | True if the image is signed and trust |
Example response:
{
"advanced": false,
"apparmor": "default",
"arch": ["armhf", "aarch64", "i386", "amd64"],
"audio_input": null,
"audio_output": null,
"audio": false,
"auth_api": false,
"auto_uart": false,
"auto_update": false,
"available": false,
"boot": "auto",
"boot_config": "auto",
"build": false,
"changelog": false,
"description": "description",
"detached": false,
"devices": ["/dev/xy"],
"devicetree": false,
"discovery": ["service"],
"dns": [],
"docker_api": false,
"documentation": false,
"full_access": false,
"gpio": false,
"hassio_api": false,
"hassio_role": "default",
"homeassistant_api": false,
"homeassistant": null,
"host_dbus": false,
"host_ipc": false,
"host_network": false,
"host_pid": false,
"host_uts": false,
"hostname": "awesome-addon",
"icon": false,
"ingress_entry": null,
"ingress_panel": true,
"ingress_port": 1337,
"ingress_url": null,
"ingress": false,
"ip_address": "172.0.0.21",
"kernel_modules": false,
"logo": false,
"long_description": "Long description",
"machine": ["raspberrypi2", "tinker"],
"name": "Awesome add-on",
"network_description": "{}|null",
"network": {},
"options": {},
"privileged": ["NET_ADMIN", "SYS_ADMIN"],
"protected": false,
"rating": "1-6",
"repository": "12345678",
"schema": {},
"services_role": ["service:access"],
"slug": "awesome_addon",
"stage": "stable",
"startup": "application",
"state": "started",
"stdin": false,
"translations": {
"en": {
"configuration": {
"lorem": "ipsum"
}
}
},
"udev": false,
"update_available": false,
"url": null,
"usb": ["/dev/usb1"],
"version_latest": "1.0.2",
"version": "1.0.0",
"video": false,
"watchdog": true,
"webui": "http://[HOST]:1337/xy/zx",
"signed": false
}
Install an add-on
Deprecated! Use /store/addons/<addon>/install
instead.
This function is not callable by itself and you can not use self
as the slug here.
:::tip
To reset customized network/audio/options, set it null
.
:::
Payload:
key | type | description |
---|---|---|
boot | string | (auto, manual) |
auto_update | boolean | true if the add-on should auto update |
network | dictionary | A map of network configuration. |
options | dictionary | The add-on configuration |
audio_output | float or null | The index of the audio output device |
audio_input | float or null | The index of the audio input device |
ingress_panel | boolean | true if ingress_panel is enabled |
watchdog | boolean | true if watchdog is enabled |
You need to supply at least one key in the payload.
Example payload:
{
"boot": "manual",
"auto_update": false,
"network": {
"CONTAINER": "1337"
},
"options": {
"awesome": true
},
"watchdog": true
}
Run a configuration validation against the current stored add-on configuration or payload.
Payload:
Optional the raw add-on options.
Returned data:
key | type | description |
---|---|---|
message | string | Include the error message |
valid | boolean | If config is valid or not |
pwned | boolean | None |
This function is not callable by itself and you can not use self
as the slug here.
Payload:
key | type | description |
---|---|---|
protected | boolean | true if protection mode is on |
Returns a Stats model for the add-on.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Write data to add-on stdin.
The payload you want to pass into the addon you give the endpoint as the body of the request.
Stop an add-on Uninstall an add-onPayload:
key | type | optional | description |
---|---|---|---|
remove_config | boolean | True | Delete addon's config folder (if used) |
Deprecated! Use /store/addons/<addon>/update
instead.
Audio
Set a profile as the default input profilePayload:
key | type | optional | description |
---|---|---|---|
name | string | False | The name of the profile |
Payload:
key | type | optional | description |
---|---|---|---|
name | string | False | The name of the profile |
Returned data:
key | type | description |
---|---|---|
host | string | The IP address of the plugin |
version | string | The installed observer version |
version_latest | string | The latest published version |
update_available | boolean | true if an update is available |
audio | dictionary | An Audio model |
Example response:
{
"host": "172.0.0.19",
"version": "1",
"latest_version": "2",
"update_available": true,
"audio": {
"card": [
{
"name": "Awesome card",
"index": 1,
"driver": "Awesome driver",
"profiles": [
{
"name": "Awesome profile",
"description": "My awesome profile",
"active": false
}
]
}
],
"input": [
{
"name": "Awesome device",
"index": 0,
"description": "My awesome device",
"volume": 0.3,
"mute": false,
"default": false,
"card": null,
"applications": [
{
"name": "Awesome application",
"index": 0,
"stream_index": 0,
"stream_type": "INPUT",
"volume": 0.3,
"mute": false,
"addon": "awesome_addon"
}
]
}
],
"output": [
{
"name": "Awesome device",
"index": 0,
"description": "My awesome device",
"volume": 0.3,
"mute": false,
"default": false,
"card": 1,
"applications": [
{
"name": "Awesome application",
"index": 0,
"stream_index": 0,
"stream_type": "INPUT",
"volume": 0.3,
"mute": false,
"addon": "awesome_addon"
}
]
}
],
"application": [
{
"name": "Awesome application",
"index": 0,
"stream_index": 0,
"stream_type": "OUTPUT",
"volume": 0.3,
"mute": false,
"addon": "awesome_addon"
}
]
}
}
Get logs for the audio plugin container via the Systemd journal backend.
The endpoint accepts the same headers and provides the same functionality as
/host/logs
.
Identical to /audio/logs
except it continuously returns new log entries.
Get logs for the audio plugin container related to a specific boot.
The bootid
parameter is interpreted in the same way as in
/host/logs/boots/<bootid>
and the endpoint otherwise provides the same
functionality as /host/logs
.
Identical to /audio/logs/boots/<bootid>
except it continuously returns
new log entries.
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
active | boolean | False | true if muted |
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
active | boolean | False | true if muted |
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
active | boolean | False | true if muted |
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
active | boolean | False | true if muted |
Payload:
key | type | optional | description |
---|---|---|---|
card | string | False | The name of the audio device |
name | string | False | The name of the profile |
Returns a Stats model for the audio plugin.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Update the audio plugin
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
volume | float | False | The volume (between 0.0 and 1.0 ) |
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
volume | float | False | The volume (between 0.0 and 1.0 ) |
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
volume | float | False | The volume (between 0.0 and 1.0 ) |
Payload:
key | type | optional | description |
---|---|---|---|
index | string | False | The index of the device |
volume | float | False | The volume (between 0.0 and 1.0 ) |
Auth
You can do authentication against Home Assistant Core using Basic Authentication. Use the `X-Supervisor-Token` header to provide the Supervisor authentication token. See the corresponding POST method to provide JSON or urlencoded credentials. You can do authentication against Home Assistant Core. You can POST the data as JSON, as urlencoded (with `application/x-www-form-urlencoded` header) or by using use basic authentication. For using Basic authentication, you can use the `X-Supervisor-Token` for Supervisor authentication token.Payload:
key | type | description |
---|---|---|
username | string | The username for the user |
password | string | The password for the user |
Payload:
key | type | description |
---|---|---|
username | string | The username for the user |
password | string | The new password for the user |
Reset internal authentication cache, this is useful if you have changed the password for a user and need to clear the internal cache.
List all users in Home Assistant to help with credentials recovery. Requires an admin level authentication token.
Payload:
key | type | description |
---|---|---|
users | list | List of the Home Assistant users. |
Backup
Return a list of Backups
Example response:
{
"backups": [
{
"slug": "skuwe823",
"date": "2020-09-30T20:25:34.273Z",
"name": "Awesome backup",
"type": "partial",
"size": 44,
"size_bytes": 44070259,
"protected": true,
"location": "MountedBackups",
"locations": ["MountedBackups"],
"compressed": true,
"content": {
"homeassistant": true,
"addons": ["awesome_addon"],
"folders": ["ssl", "media"]
}
}
]
}
Return information about backup manager.
Returned data:
key | type | description |
---|---|---|
backups | list | A list of Backups |
days_until_stale | int | Number of days until a backup is considered stale |
Example response:
{
"backups": [
{
"slug": "skuwe823",
"date": "2020-09-30T20:25:34.273Z",
"name": "Awesome backup",
"type": "partial",
"size": 44,
"size_bytes": 44070259,
"protected": true,
"compressed": true,
"location": null,
"locations": [null],
"content": {
"homeassistant": true,
"addons": ["awesome_addon"],
"folders": ["ssl", "media"]
}
}
],
"days_until_stale": 30
}
Create a full backup.
Payload:
key | type | optional | description |
---|---|---|---|
name | string | True | The name you want to give the backup |
password | string | True | The password you want to give the backup |
compressed | boolean | True | false to create uncompressed backups |
location | list, string or null | True | Name of a backup mount or null for /backup. Use a list of backup mounts or null to make backup in multiple places |
homeassistant_exclude_database | boolean | True | Exclude the Home Assistant database file from backup |
background | boolean | True | Return job_id immediately, do not wait for backup to complete. Clients must check job for status and slug. |
extra | dictionary | True | Extra metadata to store with the backup for client-specific use cases |
Example response:
{
"slug": "skuwe823",
"job_id": "abc123"
}
:::note
Error responses from this API may also include a job_id
if the message alone cannot accurately describe what happened.
Callers should direct users to review the job or supervisor logs to get an understanding of what occurred.
:::
Upload a backup.
Query
key | multiple | description |
---|---|---|
location | Yes | The name of the backup mount to upload to. Use empty string for /backup . Provide multiple locations to upload to multiple places |
Examples
?location=
- Upload to/backup
?location=MountedBackups
- Upload to backup mount namedMountedBackup
?location=&location=MountedBackups
- Upload to both of the above places
Example response:
{
"slug": "skuwe823",
"job_id": "abc123"
}
:::note
Error responses from this API may also include a job_id
if the message alone cannot accurately describe what happened.
Callers should direct users to review the job or supervisor logs to get an understanding of what occurred.
:::
Create a partial backup.
Payload:
key | type | optional | description |
---|---|---|---|
name | string | True | The name you want to give the backup |
password | string | True | The password you want to give the backup |
homeassistant | boolean | Content | Add home assistant core settings to the backup |
addons | list or ALL |
Content | A list of strings representing add-on slugs. Provide the string ALL instead of a list to include all currently installed add-ons |
folders | list | Content | A list of strings representing directories |
compressed | boolean | True | false to create uncompressed backups |
location | list, string or null | True | Name of a backup mount or null for /backup. Use a list of backup mounts or null to make backup in multiple places |
homeassistant_exclude_database | boolean | True | Exclude the Home Assistant database file from backup |
background | boolean | True | Return job_id immediately, do not wait for backup to complete. Clients must check job for status and slug. |
extra | dictionary | True | Extra metadata to store with the backup for client-specific use cases |
You need to supply at least one key of the ones marked "Content" in the optional column in the payload.
Example response:
{
"slug": "skuwe823",
"job_id": "abc123"
}
:::note
Error responses from this API may also include a job_id
if the message alone cannot accurately describe what happened.
Callers should direct users to review the job or supervisor logs to get an understanding of what occurred.
:::
Update options for backup manager, you need to supply at least one of the payload keys to the API call.Payload:
key | type | description |
---|---|---|
days_until_stale | int | Set number of days until a backup is considered stale |
You need to supply at least one key in the payload.
Reload backup from storage.
Put Supervisor in a freeze state and prepare Home Assistant and addons for an external backup.
:::note
This does not take a backup. It prepares Home Assistant and addons for one but the expectation
is that the user is using an external tool to make the backup. Such as the snapshot feature in
KVM or Proxmox. The caller should call /backups/thaw
when done.
:::
Payload:
key | type | optional | description |
---|---|---|---|
timeout | int | True | Seconds before freeze times out and thaw begins automatically (default: 600). |
End a freeze initiated by /backups/freeze
and resume normal behavior in Home Assistant and addons.
Download the backup file with the given slug.
Query
key | multiple | description |
---|---|---|
location | No | Specify which location to download the backup from of the ones it exists in. Use empty string for /backup (equivalent to null in the locations field of Backup) |
Examples
?location=
- Download from/backup
?location=MountedBackups
- Download from backup mount namedMountedBackup
Returns a Backup details model for the add-on.
Removes the backup file with the given slug.
Payload:
key | type | optional | description |
---|---|---|---|
location | list | True | Specify which locations to remove the backup from instead of removing it from all locations. See locations field of Backup |
Does a full restore of the backup with the given slug.
Payload:
key | type | optional | description |
---|---|---|---|
password | string | True | The password for the backup if any |
background | boolean | True | Return job_id immediately, do not wait for restore to complete. Clients must check job for status. |
location | string or null | True | Specify which location to restore the backup from of the ones it exists in. See locations field of Backup |
Example response:
{
"job_id": "abc123"
}
:::note
Error responses from this API may also include a job_id
if the message alone cannot accurately describe what happened.
Callers should direct users to review the job or supervisor logs to get an understanding of what occurred.
:::
Does a partial restore of the backup with the given slug.
Payload:
key | type | optional | description |
---|---|---|---|
homeassistant | boolean | Content | true if Home Assistant should be restored |
addons | list | Content | A list of add-on slugs that should be restored |
folders | list | Content | A list of directories that should be restored |
password | string | True | The password for the backup if any |
background | boolean | True | Return job_id immediately, do not wait for restore to complete. Clients must check job for status. |
location | string or null | True | Specify which location to restore the backup from of the ones it exists in. See locations field of Backup |
You need to supply at least one key of the ones marked "Content" in the optional column in the payload.
Example response:
{
"job_id": "abc123"
}
:::note
Error responses from this API may also include a job_id
if the message alone cannot accurately describe what happened.
Callers should direct users to review the job or supervisor logs to get an understanding of what occurred.
:::
CLI
Returns information about the CLI pluginReturned data:
key | type | description |
---|---|---|
version | string | The installed cli version |
version_latest | string | The latest published version |
update_available | boolean | true if an update is available |
Example response:
{
"version": "1",
"version_latest": "2",
"update_available": true
}
Returns a Stats model for the CLI plugin.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Update the CLI plugin
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
Core
Proxy GET API calls to the Home Assistant API Proxy POST API calls to the Home Assistant API Run a configuration check Returns information about the Home Assistant coreReturned data:
key | type | description |
---|---|---|
version | string | The installed core version |
version_latest | string | The latest published version in the active channel |
update_available | boolean | true if an update is available |
arch | string | The architecture of the host (armhf, aarch64, i386, amd64) |
machine | string | The machine type that is running the host |
ip_address | string | The internal docker IP address to the supervisor |
image | string | The container image that is running the core |
boot | boolean | true if it should start on boot |
port | int | The port Home Assistant is running on |
ssl | boolean | true if Home Assistant is using SSL |
watchdog | boolean | true if watchdog is enabled |
wait_boot | int | Max time to wait during boot |
audio_input | string or null | The description of the audio input device |
audio_output | string or null | The description of the audio output device |
backups_exclude_database | boolean | Backups exclude Home Assistant database file by default |
Example response:
{
"version": "0.117.0",
"version_latest": "0.117.0",
"update_available": true,
"arch": "arch",
"machine": "amd64",
"ip_address": "172.0.0.15",
"image": "homeassistant/home-assistant",
"boot": true,
"port": 8123,
"ssl": false,
"watchdog": true,
"wait_boot": 800,
"audio_input": "AMCP32",
"audio_output": "AMCP32"
}
Get logs for the Home Assistant Core container via the Systemd journal backend.
The endpoint accepts the same headers and provides the same functionality as
/host/logs
.
Identical to /core/logs
except it continuously returns new log entries.
Get logs for the Home Assistant Core container related to a specific boot.
The bootid
parameter is interpreted in the same way as in
/host/logs/boots/<bootid>
and the endpoint otherwise provides the same
functionality as /host/logs
.
Identical to /core/logs/boots/<bootid>
except it continuously returns
new log entries.
:::tip
Passing image
, refresh_token
, audio_input
or audio_output
with null
resets the option.
:::
Payload:
key | type | description |
---|---|---|
boot | boolean | Start Core on boot |
image | string or null | Name of custom image |
port | int | The port that Home Assistant run on |
ssl | boolean | true to enable SSL |
watchdog | boolean | true to enable the watchdog |
wait_boot | int | Time to wait for Core to startup |
refresh_token | string or null | Token to authenticate with Core |
audio_input | string or null | Profile name for audio input |
audio_output | string or null | Profile name for audio output |
backups_exclude_database | boolean | true to exclude Home Assistant database file from backups |
You need to supply at least one key in the payload.
Rebuild the Home Assistant core containerPayload:
key | type | optional | description |
---|---|---|---|
safe_mode | boolean | True | Rebuild Core into safe mode |
force | boolean | True | Force rebuild during a Home Assistant offline db migration |
Payload:
key | type | optional | description |
---|---|---|---|
safe_mode | boolean | True | Restart Core into safe mode |
force | boolean | True | Force restart during a Home Assistant offline db migration |
Returns a Stats model for the Home Assistant core.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Stop the Home Assistant core container
Payload:
key | type | optional | description |
---|---|---|---|
force | boolean | True | Force stop during a Home Assistant offline db migration |
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
backup | boolean | Create a partial backup of core and core configuration before updating, default is false |
Discovery
Return information about enabled discoveries.Returned data:
key | type | description |
---|---|---|
discovery | list | A list of Discovery models |
services | dictionary | A dictionary of services that contains a list of add-ons that have that service. |
Example response:
{
"discovery": [
{
"addon": "awesome_addon",
"service": "awesome.service",
"uuid": "fh874r-fj9o37yr3-fehsf7o3-fd798",
"config": {}
}
],
"services": {
"awesome": ["awesome_addon"]
}
}
Create a discovery service
Payload:
key | type | optional | description |
---|---|---|---|
service | string | False | The name of the service |
config | dictionary | False | The configuration of the service |
Example response:
{
"uuid": "uuid"
}
Get a discovery model for a UUID.
Delete a specific service.DNS
Return information about the DNS plugin.Returned data:
key | type | description |
---|---|---|
fallback | bool | Try fallback DNS on failure |
host | string | The IP address of the plugin |
llmnr | bool | Can resolve LLMNR hostnames |
locals | list | A list of DNS servers |
mdns | bool | Can resolve MulticastDNS hostnames |
servers | list | A list of DNS servers |
update_available | boolean | true if an update is available |
version | string | The installed observer version |
version_latest | string | The latest published version |
Example response:
{
"host": "127.0.0.18",
"version": "1",
"version_latest": "2",
"update_available": true,
"servers": ["dns://8.8.8.8"],
"locals": ["dns://127.0.0.18"],
"mdns": true,
"llmnr": false,
"fallback": true
}
Get logs for the DNS plugin container via the Systemd journal backend.
The endpoint accepts the same headers and provides the same functionality as
/host/logs
.
Identical to /dns/logs
except it continuously returns new log entries.
Get logs for the DNS plugin container related to a specific boot.
The bootid
parameter is interpreted in the same way as in
/host/logs/boots/<bootid>
and the endpoint otherwise provides the same
functionality as /host/logs
.
Identical to /dns/logs/boots/<bootid>
except it continuously returns
new log entries.
Payload:
key | type | optional | description |
---|---|---|---|
fallback | bool | True | Enable/Disable fallback DNS |
servers | list | True | A list of DNS servers |
You need to supply at least one key in the payload.
Reset the DNS configuration. Restart the DNS pluginReturns a Stats model for the dns plugin.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Update the DNS plugin
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
Docker
Returns information about the docker instance.Returned data:
key | type | description |
---|---|---|
version | string | The version of the docker engine |
storage | string | The storage type |
logging | string | The logging type |
registries | dictionary | A dictionary of dictionaries containing username and password keys for registries. |
Example response:
{
"version": "1.0.1",
"storage": "overlay2",
"logging": "journald",
"registries": {}
}
Get all configured container registries, this returns a dict with the registry hostname as the key, and a dictionary containing the username configured for that registry.
Example response:
{
"registry.example.com": {
"username": "AwesomeUser"
}
}
Add a new container registry.
Payload:
key | type | description |
---|---|---|
hostname | dictionary | A dictionary containing username and password keys for the registry. |
Example payload:
{
"registry.example.com": {
"username": "AwesomeUser",
"password": "MySuperStrongPassword!"
}
}
:::note
To login to the default container registry (Docker Hub), use hub.docker.com
as the registry.
:::
Delete a registry from the configured container registries.Hardware
Get hardware information.Example response:
{
"devices": [
{
"name": "ttyACM0",
"sysfs": "/sys/devices/usb/00:01",
"dev_path": "/dev/ttyACM0",
"by_id": "/dev/serial/by-id/usb-Silicon_Labs-RFUSB_9017F723B061A7C01410CFCF-if00-port1",
"subsystem": "tty",
"parent": null,
"attributes": {
"MINOR": "5"
},
"children": [
"/sys/devices/soc/platform/00ef"
]
}
],
"drives": [
{
"vendor": "Generic",
"model": "Flash Disk",
"revision": "8.07",
"serial": "AABBCCDD",
"id": "Generic-Flash-Disk-AABBCCDD",
"size": 8054112256,
"time_detected": "2023-02-15T21:44:22.504878+00:00",
"connection_bus": "usb",
"seat": "seat0",
"removable": true,
"ejectable": true,
"filesystems": [
{
"device": "/dev/sda1",
"id": "by-uuid-1122-1ABA",
"size": 67108864,
"name": "",
"system": false,
"mount_points": []
}
]
}
]
}
Returned data:
key | description |
---|---|
devices | A list of Device models |
drives | A list of Drive models |
Example response:
{
"audio": {
"input": {
"0,0": "Mic"
},
"output": {
"1,0": "Jack",
"1,1": "HDMI"
}
}
}
Host
Return information about the host.Returned data
key | type | description |
---|---|---|
agent_version | string or null | Agent version running on the Host |
apparmor_version | string or null | The AppArmor version from host |
boot_timestamp | int | The timestamp for the last boot in microseconds |
broadcast_llmnr | bool or null | Host is broadcasting its LLMNR hostname |
broadcast_mdns | bool or null | Host is broadcasting its MulticastDNS hostname |
chassis | string or null | The chassis type |
virtualization | string or null | Virtualization hypervisor in use (if any) |
cpe | string or null | The local CPE |
deployment | string or null | The deployment stage of the OS if any |
disk_total | float | Total space of the disk in MB |
disk_used | float | Used space of the disk in MB |
disk_free | float | Free space of the disk in MB |
features | list | A list of features available for the host |
hostname | string or null | The hostname of the host |
kernel | string or null | The kernel version on the host |
llmnr_hostname | string or null | The hostname currently exposed on the network via LLMNR for host |
operating_system | string | The operating system on the host |
startup_time | float | The time in seconds it took for last boot |
Example response:
{
"agent_version": "1.2.0",
"apparmor_version": "2.13.2",
"chassis": "specific",
"cpe": "xy",
"deployment": "stable",
"disk_total": 32.0,
"disk_used": 30.0,
"disk_free": 2.0,
"features": ["shutdown", "reboot", "hostname", "services", "haos"],
"hostname": "Awesome host",
"llmnr_hostname": "Awesome host",
"kernel": "4.15.7",
"operating_system": "Home Assistant OS",
"boot_timestamp": 1234567788,
"startup_time": 12.345,
"broadcast_llmnr": true,
"broadcast_mdns": false
}
Get systemd Journal logs from the host. Returns log entries in plain text, one log record per line.
HTTP Request Headers
Header | optional | description |
---|---|---|
Accept | true | Type of data (text/plain or text/x-log) |
Range | true | Range of log entries. The format is entries=cursor[[:num_skip]:num_entries] |
:::tip
To get the last log entries the Range request header supports negative values
as num_skip
. E.g. Range: entries=:-9:
returns the last 10 entries. Or
Range: entries=:-200:100
to see 100 entries starting from the one 200 ago.
:::
API returns the last 100 lines by default. Provide a value for Range
to see
logs further in the past.
The Accept
header can be set to text/x-log
to get logs annotated with
extra information, such as the timestamp and Systemd unit name. If no
identifier is specified (i.e. for the host logs containing logs for multiple
identifiers/units), this option is ignored - these logs are always annotated.
Identical to /host/logs
except it continuously returns new log entries.
Returns a list of syslog identifiers from the systemd journal that you can use
with /host/logs/identifiers/<identifier>
and /host/logs/boots/<bootid>/identifiers/<identifier>
.
Get systemd Journal logs from the host for entries related to a specific log identifier. Some examples of useful identifiers here include
audit
- If developing an apparmor profile shows you permission issuesNetworkManager
- Shows NetworkManager logs when having network issuesbluetoothd
- Shows bluetoothd logs when having bluetooth issues
A call to GET /host/logs/identifiers
will show the complete list of possible
values for identifier
.
Otherwise it provides the same functionality as /host/logs
.
Identical to /host/logs/identifiers/<identifier>
except it continuously returns
new log entries.
Returns a dictionary of boot IDs for this system that you can use with
/host/logs/boots/<bootid>
and /host/logs/boots/<bootid>/identifiers/<identifier>
.
The key for each item in the dictionary is the boot offset. 0 is the current boot, a negative number denotes how many boots ago that boot was.
Get systemd Journal logs from the host for entries related to a specific boot.
Call GET /host/info/boots
to see the boot IDs. Alternatively you can provide a
boot offset:
- 0 - The current boot
- Negative number - Count backwards from current boot (-1 is previous boot)
- Positive number - Count forward from last known boot (1 is last known boot)
Otherwise it provides the same functionality as /host/logs
.
Identical to /host/logs/boots/<bootid>
except it continuously returns
new log entries.
Get systemd Journal logs entries for a specific log identifier and boot.
A combination of /host/logs/boots/<bootid>
and /host/logs/identifiers/<identifier>
.
Identical to /host/logs/boots/<bootid>/identifiers/<identifier>
except it continuously
returns new log entries.
Payload:
key | type | optional | description |
---|---|---|---|
hostname | string | True | A string that will be used as the new hostname |
You need to supply at least one key in the payload.
Reboot the hostPayload:
key | type | optional | description |
---|---|---|---|
force | boolean | True | Force reboot during a Home Assistant offline db migration |
Returned data:
key | description |
---|---|
services | A dictionary of Host service models |
Example response:
{
"services": [
{
"name": "awesome.service",
"description": "Just an awesome service",
"state": "active"
}
]
}
Shutdown the host
Payload:
key | type | optional | description |
---|---|---|---|
force | boolean | True | Force shutdown during a Home Assistant offline db migration |
Ingress
Returned data:
key | type | description |
---|---|---|
panels | dictionary | dictionary of Panel models |
Example response:
{
"panels": {
"addon_slug": {
"enable": true,
"icon": "mdi:awesome-icon",
"title": "Awesome add-on",
"admin": true
}
}
}
Create a new session for access to the ingress service.
Payload:
key | type | optional | description |
---|---|---|---|
user_id | string | True | The ID of the user authenticated for the new session |
Returned data:
key | type | optional | description |
---|---|---|---|
session | string | False | The token for the ingress session |
Payload:
key | type | optional | description |
---|---|---|---|
session | string | False | The token for the ingress session |
Jobs
Returns info on ignored job conditions and currently running jobsReturned data:
key | type | description |
---|---|---|
ignore_conditions | list | List of job conditions being ignored |
jobs | list | List of currently running Jobs |
Example response:
{
"ignore_conditions": [],
"jobs": [{
"name": "backup_manager_full_backup",
"reference": "a01bc3",
"uuid": "123456789",
"progress": 0,
"stage": "addons",
"done": false,
"child_jobs": []
}]
}
Set options for job manager
Payload:
key | type | description |
---|---|---|
ignore_conditions | list | List of job conditions to ignore (replaces existing list) |
Root
Returns information about available updates
Example response:
{
"available_updates": [
{
"panel_path": "/update-available/core",
"update_type": "core",
"version_latest": "321",
},
{
"panel_path": "/update-available/os",
"update_type": "os",
"version_latest": "321",
},
{
"panel_path": "/update-available/supervisor",
"update_type": "supervisor",
"version_latest": "321",
},
{
"name": "Awesome addon",
"icon": "/addons/awesome_addon/icon",
"panel_path": "/update-available/awesome_addon",
"update_type": "addon",
"version_latest": "321",
}
]
}
Returned data:
key | type | description |
---|---|---|
update_type | string | addon , os , core or supervisor |
name | string | Returns the name (only if the update_type is addon ) |
icon | string | Returns the path for the icon if any (only if the update_type is addon ) |
version_latest | string | Returns the available version |
panel_path | string | Returns path where the UI can be loaded |
Returned data:
key | type | description |
---|---|---|
supervisor | string | The installed version of the supervisor |
homeassistant | string | The installed version of Home Assistant |
hassos | string or null | The version of Home Assistant OS or null |
docker | string | The docker version on the host |
hostname | string | The hostname on the host |
operating_system | string | The operating system on the host |
features | list | A list ov available features on the host |
machine | string | The machine type |
arch | string | The architecture on the host |
supported_arch | list | A list of supported host architectures |
supported | boolean | true if the environment is supported |
channel | string | The active channel (stable, beta, dev) |
logging | string | The active log level (debug, info, warning, error, critical) |
state | string | The core state of the Supervisor. |
timezone | string | The current timezone |
Example response:
{
"supervisor": "300",
"homeassistant": "0.117.0",
"hassos": "5.0",
"docker": "24.17.2",
"hostname": "Awesome Hostname",
"operating_system": "Home Assistant OS",
"features": ["shutdown", "reboot", "hostname", "services", "hassos"],
"machine": "ova",
"arch": "amd64",
"supported_arch": ["amd64"],
"supported": true,
"channel": "stable",
"logging": "info",
"state": "running",
"timezone": "Europe/Tomorrowland"
}
Mounts
Returns information about mounts configured in SupervisorReturned data:
key | type | description |
---|---|---|
mounts | list | A list of Mounts |
default_backup_mount | string or null | Name of a backup mount or null for /backup |
Example response:
{
"default_backup_mount": "my_share",
"mounts": [
{
"name": "my_share",
"usage": "media",
"type": "cifs",
"server": "server.local",
"share": "media",
"state": "active",
"read_only": false,
"user_path": "/media/my_share"
}
]
}
Set mount manager options
Payload:
key | type | optional | description |
---|---|---|---|
default_backup_mount | string or null | True | Name of a backup mount or null for /backup |
You need to supply at least one key in the payload.
Add a new mount in Supervisor and mount itPayload:
Accepts a Mount
Value in name
must be unique and can only consist of letters, numbers and underscores.
Example payload:
{
"name": "my_share",
"usage": "media",
"type": "cifs",
"server": "server.local",
"share": "media",
"username": "admin",
"password": "password",
"read_only": false
}
Update an existing mount in Supervisor and remount it
Payload:
Accepts a Mount.
The name
field should be omitted. If included the value must match the existing
name, it cannot be changed. Delete and re-add the mount to change the name.
Example payload:
{
"usage": "media",
"type": "nfs",
"server": "server.local",
"path": "/media/camera",
"read_only": true
}
Unmount and delete an existing mount from Supervisor.
Unmount and remount an existing mount in Supervisor using the same configuration.
Multicast
Returns information about the multicast pluginReturned data:
key | type | description |
---|---|---|
version | string | The installed multicast version |
version_latest | string | The latest published version |
update_available | boolean | true if an update is available |
Example response:
{
"version": "1",
"version_latest": "2",
"update_available": true
}
Get logs for the multicast plugin via the Systemd journal backend.
The endpoint accepts the same headers and provides the same functionality as
/host/logs
.
Identical to /multicast/logs
except it continuously returns new log entries.
Get logs for the multicast plugin related to a specific boot.
The bootid
parameter is interpreted in the same way as in
/host/logs/boots/<bootid>
and the endpoint otherwise provides the same
functionality as /host/logs
.
Identical to /multicast/logs/boots/<bootid>
except it continuously returns
new log entries.
Returns a Stats model for the multicast plugin.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Update the multicast plugin
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
Network
Get network information.Returned data:
key | description |
---|---|
interfaces | A list of Network interface models |
docker | Information about the internal docker network |
host_internet | Boolean to indicate if the host can reach the internet. |
supervisor_internet | Boolean to indicate if the Supervisor can reach the internet. |
Example response:
{
"interfaces": [
{
"interface": "eth0",
"type": "ethernet",
"primary": true,
"enabled": true,
"connected": true,
"ipv4": {
"method": "static",
"ip_address": "192.168.1.100/24",
"gateway": "192.168.1.1",
"nameservers": ["192.168.1.1"],
},
"ipv6": null,
"wifi": null,
"vlan": null,
}
],
"docker": {
"interface": "hassio",
"address": "172.30.32.0/23",
"gateway": "172.30.32.1",
"dns": "172.30.32.3"
},
"host_internet": true,
"supervisor_internet": true
}
Returns a Network interface model for a specific network interface.
Update all Network interface data.
Update the settings for a network interface.Payload:
key | type | optional | description |
---|---|---|---|
enabled | bool | True | Enable/Disable an ethernet interface / VLAN got removed with disabled |
ipv4 | dict | True | A struct with ipv4 interface settings |
ipv6 | dict | True | A struct with ipv6 interface settings |
wifi | dict | True | A struct with Wireless connection settings |
ipv4 / ipv6:
key | type | optional | description |
---|---|---|---|
method | string | True | Set IP configuration method can be auto for DHCP or Router Advertisements (only IPv6), static or disabled |
address | list | True | The new IP address for the interface in the X.X.X.X/XX format as list |
nameservers | list | True | List of DNS servers to use |
gateway | string | True | The gateway the interface should use |
wifi:
key | type | optional | description |
---|---|---|---|
mode | string | True | Set the mode infrastructure (default), mesh , adhoc or ap |
auth | string | True | Set the auth mode: open (default), web , wpa-psk |
ssid | string | True | Set the SSID for connect into |
psk | string | True | The shared key which is used with web or wpa-psk |
Return a list of available Access Points on this Wireless interface.
This function only works with Wireless interfaces!
Returned data:
key | description |
---|---|
accesspoints | A list of Access Points |
Example response:
{
"accesspoints": [
{
"mode": "infrastructure",
"ssid": "MY_TestWifi",
"mac": "00:00:00:00",
"frequency": 24675,
"signal": 90
}
]
}
Create a new VLAN id on this network interface.
This function only works with ethernet interfaces!
Payload:
key | type | optional | description |
---|---|---|---|
ipv4 | dict | True | A struct with ipv4 interface settings |
ipv6 | dict | True | A struct with ipv6 interface settings |
Observer
Returns information about the observer plugin
Returned data:
key | type | description |
---|---|---|
host | string | The IP address of the plugin |
version | string | The installed observer version |
version_latest | string | The latest published version |
update_available | boolean | true if an update is available |
Example response:
{
"host": "172.0.0.17",
"version": "1",
"version_latest": "2",
"update_available": true
}
Returns a Stats model for the observer plugin.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Update the observer plugin
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
OS
Load host configurations from a USB stick.
Returns information about the OS.
Returned data:
key | type | description |
---|---|---|
version | string | The current version of the OS |
version_latest | string | The latest published version of the OS in the active channel |
update_available | boolean | true if an update is available |
board | string | The name of the board |
boot | string | Which slot that are in use |
data_disk | string | Device which is used for holding OS data persistent |
boot_slots | dict | Dictionary of boot slots keyed by name |
Example response:
{
"version": "4.3",
"version_latest": "5.0",
"update_available": true,
"board": "ova",
"boot": "slot1",
"data_disk": "BJTD4R-0x123456789",
"boot_slots": {
"A": {
"state": "inactive",
"status": "good",
"version": "10.1"
},
"B": {
"state": "active",
"status": "good",
"version": "10.2"
}
}
}
Update Home Assistant OS
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
Change the active boot slot, This will also reboot the device!
Payload:
key | type | description |
---|---|---|
boot_slot | string | Boot slot to change to. See options in boot_slots from /os/info API. |
Returns possible targets for the new data partition.
Returned data:
key | type | description |
---|---|---|
devices | list | List of IDs of possible data disk targets |
disks | list | List of disks which are possible data disk targets |
Example response:
{
"devices": [
"Generic-Flash-Disk-123ABC456",
"SSK-SSK-Storage-ABC123DEF"
],
"disks": [
{
"name": "Generic Flash Disk (123ABC456)",
"vendor": "Generic",
"model": "Flash Disk",
"serial": "123ABC456",
"size": 8054112256,
"id": "Generic-Flash-Disk-123ABC456",
"dev_path": "/dev/sda"
},
{
"name": "SSK SSK Storage (ABC123DEF)",
"vendor": "SSK",
"model": "SSK Storage",
"serial": "ABC123DEF",
"size": 250059350016,
"id": "SSK-SSK-Storage-ABC123DEF",
"dev_path": "/dev/sdb"
}
]
}
Move datadisk to a new location, This will also reboot the device!
Payload:
key | type | description |
---|---|---|
device | string | ID of the disk device which should be used as the target for the data migration |
Wipe the datadisk including all user data and settings, This will also reboot the device! This API requires an admin token
This API will wipe all config/settings for addons, Home Assistant and the Operating System and any locally stored data in config, backups, media, etc. The machine will reboot during this.
After the reboot completes the latest stable version of Home Assistant and Supervisor will be downloaded. Once the process is complete the user will see onboarding, like during initial setup.
This wipe also includes network settings. So after the reboot the user may need to reconfigure those in order to access Home Assistant again.
The operating system version as well as its boot configuration will be preserved.
Returns information about your board if it has features or settings
that can be modified from Home Assistant. The value for board
is the value in the board
field returned by /os/info
.
Boards with such options are documented below.
If running on a yellow board, returns current values for its settings.
Returned data:
key | type | description |
---|---|---|
disk_led | boolean | Is the disk LED enabled |
heartbeat_led | boolean | Is the heartbeat LED enabled |
power_led | boolean | Is the power LED enabled |
Example response:
{
"disk_led": true,
"heartbeat_led": true,
"power_led": false
}
If running on a yellow board, changes one or more of its settings.
Payload:
key | type | description |
---|---|---|
disk_led | boolean | Enable/disable the disk LED |
heartbeat_led | boolean | Enable/disable the heartbeat LED |
power_led | boolean | Enable/disable the power LED |
If running on a green board, returns current values for its settings.
Returned data:
key | type | description |
---|---|---|
activity_led | boolean | Is the green activity LED enabled |
power_led | boolean | Is the white power LED enabled |
system_health_led | boolean | Is the yellow system health LED enabled |
Example response:
{
"activity_led": true,
"power_led": true,
"system_health_led": false
}
If running on a green board, changes one or more of its settings.
Payload:
key | type | description |
---|---|---|
activity_led | boolean | Enable/disable the green activity LED |
power_led | boolean | Enable/disable the white power LED |
system_health_led | boolean | Enable/disable the yellow system health LED |
Resolution
Returned data:
key | type | description |
---|---|---|
unsupported | list | A list of reasons why an installation is marked as unsupported (container, dbus, docker_configuration, docker_version, lxc, network_manager, os, privileged, systemd) |
unhealthy | list | A list of reasons why an installation is marked as unhealthy (docker, supervisor, privileged, setup) |
issues | list | A list of Issue models |
suggestions | list | A list of Suggestion models actions |
checks | list | A list of Check models |
Example response:
{
"unsupported": ["os"],
"unhealthy": ["docker"],
"issues": [
{
"uuid": "A89924620F9A11EBBDC3C403FC2CA371",
"type": "free_space",
"context": "system",
"reference": null
}
],
"suggestions": [
{
"uuid": "B9923620C9A11EBBDC3C403FC2CA371",
"type": "clear_backups",
"context": "system",
"reference": null,
"auto": false
}
],
"checks": [
{
"slug": "free_space",
"enabled": true
}
]
}
Apply a suggested action
Dismiss a suggested action
Get suggestions that would fix an issue if applied.
Returned data:
key | type | description |
---|---|---|
suggestions | list | A list of Suggestion models actions |
Example response:
{
"suggestions": [
{
"uuid": "B9923620C9A11EBBDC3C403FC2CA371",
"type": "clear_backups",
"context": "system",
"reference": null,
"auto": false
}
]
}
Dismiss an issue
Execute a healthcheck and autofix & notifcation.
Set options for this check.
Payload:
key | type | description |
---|---|---|
enabled | bool | If the check should be enabled or disabled |
Execute a specific check right now.
Service
Returned data:
key | type | description |
---|---|---|
services | dictionary | dictionary of Service models |
Example response:
{
"services": [
{
"slug": "name",
"available": true,
"providers": ["awesome_addon"]
}
]
}
Returned data:
key | type | description |
---|---|---|
addon | string | The add-on slug |
host | string | The IP of the addon running the service |
port | string | The port the service is running on |
ssl | boolean | true if SSL is in use |
username | string | The username for the service |
password | string | The password for the service |
protocol | string | The MQTT protocol |
Example response:
{
"addon": "awesome_mqtt",
"host": "172.0.0.17",
"port": "8883",
"ssl": true,
"username": "awesome_user",
"password": "strong_password",
"protocol": "3.1.1"
}
Create a service definition
Payload:
key | type | description |
---|---|---|
host | string | The IP of the addon running the service |
port | string | The port the service is running on |
ssl | boolean | true if SSL is in use |
username | string | The username for the service |
password | string | The password for the service |
protocol | string | The MQTT protocol |
Deletes the service definitions
Returned data:
key | type | description |
---|---|---|
addon | string | The add-on slug |
host | string | The IP of the addon running the service |
port | string | The port the service is running on |
ssl | boolean | true if SSL is in use |
username | string | The username for the service |
password | string | The password for the service |
protocol | string | The MQTT protocol |
Example response:
{
"addon": "awesome_mysql",
"host": "172.0.0.17",
"port": "8883",
"username": "awesome_user",
"password": "strong_password"
}
Create a service definition
Payload:
key | type | description |
---|---|---|
host | string | The IP of the addon running the service |
port | string | The port the service is running on |
username | string | The username for the service |
password | string | The password for the service |
Deletes the service definitions
Store
Returns add-on store information.
Example response:
{ "addons":
[
{
"name": "Awesome add-on",
"slug": "7kshd7_awesome",
"description": "Awesome description",
"repository": "https://example.com/addons",
"version": "1.0.0",
"installed": "1.0.0",
"icon": false,
"logo": true,
"state": "started"
}
],
"repositories": [
{
"slug": "awesom_repository",
"name": "Awesome Repository",
"source": "https://example.com/addons",
"url": "https://example.com/addons",
"maintainer": "Awesome Maintainer"
}
]
}
Returns a list of store add-ons
Example response:
[
{
"name": "Awesome add-on",
"slug": "7kshd7_awesome",
"description": "Awesome description",
"repository": "https://example.com/addons",
"version": "1.0.0",
"installed": "1.0.0",
"icon": false,
"logo": true,
"state": "started"
}
]
Returns information about a store add-on
Example response:
{
"advanced": false,
"apparmor": "default",
"arch": ["armhf", "aarch64", "i386", "amd64"],
"auth_api": true,
"available": true,
"build": false,
"description": "Awesome description",
"detached": false,
"docker_api": false,
"documentation": true,
"full_access": true,
"hassio_api": false,
"hassio_role": "manager",
"homeassistant_api": true,
"homeassistant": "2021.2.0b0",
"host_network": false,
"host_pid": false,
"icon": false,
"ingress": true,
"installed": false,
"logo": true,
"long_description": "lorem ipsum",
"name": "Awesome add-on",
"rating": 5,
"repository": "core",
"signed": false,
"slug": "7kshd7_awesome",
"stage": "stable",
"update_available": false,
"url": "https://example.com/addons/tree/main/awesome_addon",
"version_latest": "1.0.0",
"version": "1.0.0"
}
Install an add-on from the store.
Update an add-on from the store.
Payload:
key | type | description |
---|---|---|
backup | boolean | Create a partial backup of the add-on, default is false |
Reloads the information stored about add-ons.
Returns a list of store repositories
Example response:
[
{
"slug": "awesom_repository",
"name": "Awesome Repository",
"source": "https://example.com/addons",
"url": "https://example.com/addons",
"maintainer": "Awesome Maintainer"
}
]
Add an addon repository to the store
Payload:
key | type | description |
---|---|---|
repository | string | URL of the addon repository to add to the store. |
Example payload:
{
"repository": "https://example.com/addons"
}
Returns information about a store repository
Example response:
{
"slug": "awesom_repository",
"name": "Awesome Repository",
"source": "https://example.com/addons",
"url": "https://example.com/addons",
"maintainer": "Awesome Maintainer"
}
Remove an unused addon repository from the store.
Security
Returns information about the security features
Returned data:
key | type | description |
---|---|---|
content_trust | bool | If content-trust is enabled or disabled on the backend |
pwned | bool | If pwned check is enabled or disabled on the backend |
force_security | bool | If force-security is enabled or disabled on the backend |
Example response:
{
"content_trust": true,
"pwned": true,
"force_security": false,
}
Payload:
key | type | description |
---|---|---|
content_trust | bool | Disable/Enable content-trust |
pwned | bool | Disable/Enable pwned |
force_security | bool | Disable/Enable force-security |
Run a full platform integrity check.
Returned data:
key | type | description |
---|---|---|
supervisor | str | pass , error , failed , untested |
core | str | pass , error , failed , untested |
plugins | dict | A dictionary with key per plugin as pass , error , failed , untested |
addons | dict | A dictionary with key per addon as pass , error , failed , untested |
Example response:
{
"supervisor": "pass",
"core": "pass",
"plugins": {
"audio": "pass",
"cli": "pass"
},
"addons": {
"core_ssh": "untested",
"xj3493_test": "pass"
}
}
Supervisor
Returns information about the supervisor
Returned data:
key | type | description |
---|---|---|
version | string | The installed supervisor version |
version_latest | string | The latest published version in the active channel |
update_available | boolean | true if an update is available |
arch | string | The architecture of the host (armhf, aarch64, i386, amd64) |
channel | string | The active channel (stable, beta, dev) |
timezone | string | The current timezone |
healthy | bool | The supervisor is in a healthy state |
supported | bool | The environment is supported |
logging | string | The current log level (debug, info, warning, error, critical) |
ip_address | string | The internal docker IP address to the supervisor |
wait_boot | int | Max time to wait during boot |
debug | bool | Debug is active |
debug_block | bool | true if debug block is enabled |
diagnostics | bool or null | Sending diagnostics is enabled |
addons_repositories | list | A list of add-on repository URL's as strings |
auto_update | bool | Is auto update enabled for supervisor |
Example response:
{
"version": "246",
"version_latest": "version_latest",
"update_available": true,
"arch": "amd64",
"channel": "dev",
"timezone": "TIMEZONE",
"healthy": true,
"supported": false,
"logging": "debug",
"ip_address": "172.0.0.2",
"wait_boot": 800,
"debug": false,
"debug_block": false,
"diagnostics": null,
"addons_repositories": ["https://example.com/addons"],
"auto_update": true
}
Get logs for the Supervisor container via the Systemd journal backend. If the Systemd journal gateway fails to provide the logs, raw Docker container logs are returned as the fallback.
The endpoint accepts the same headers and provides the same functionality as
/host/logs
.
Identical to /supervisor/logs
except it continuously returns new log entries.
Get logs for the Supervisor container related to a specific boot.
The bootid
parameter is interpreted in the same way as in
/host/logs/boots/<bootid>
and the endpoint otherwise provides the same
functionality as /host/logs
.
Identical to /supervisor/logs/boots/<bootid>
except it continuously returns
new log entries.
Update options for the supervisor, you need to supply at least one of the payload keys to the API call.
You need to call /supervisor/reload
after updating the options.
Payload:
key | type | description |
---|---|---|
channel | string | Set the active channel (stable, beta, dev) |
timezone | string | Set the timezone |
wait_boot | int | Set the time to wait for boot |
debug | bool | Enable debug |
debug_block | bool | Enable debug block |
logging | string | Set logging level |
addons_repositories | list | Set a list of URL's as strings for add-on repositories |
auto_update | bool | Enable/disable auto update for supervisor |
Ping the supervisor to check if it can return a response.
Reload parts of the supervisor, this enable new options, and check for updates.
Restart the supervisor, can help to get the supervisor healthy again.
Repair docker overlay issues, and lost images.
Returns a Stats model for the supervisor.
Example response:
{
"cpu_percent": 14.0,
"memory_usage": 288888,
"memory_limit": 322222,
"memory_percent": 32.4,
"network_tx": 110,
"network_rx": 902,
"blk_read": 12,
"blk_write": 27
}
Update the supervisor
Payload:
key | type | description |
---|---|---|
version | string | The version you want to install, default is the latest version |
Placeholders
Some of the endpoints uses placeholders indicated with <...>
in the endpoint URL.
placeholder | description |
---|---|
addon | The slug for the addon, to get the slug you can call /addons , to call endpoints for the add-on calling the endpoints you can use self as the slug. |
application | The name of an application, call /audio/info to get the correct name |
interface | A valid interface name, example eth0 , to get the interface name you can call /network/info . You can use default to get the primary interface |
registry | A registry hostname defined in the container registry configuration, to get the hostname you can call /docker/registries |
service | The service name for a service on the host. |
backup | A valid backup slug, example skuwe823 , to get the slug you can call /backups |
suggestion | A valid suggestion, example clear_full_backup , to get the suggestion you can call /resolution |
uuid | The UUID of a discovery service, to get the UUID you can call /discovery |