Update Home Assistant integration docs Extra care should be taken to proxy only /auth endpoint through Authentik. Signed-off-by: Sergii Bogomolov <sergii@bogomolov.io> Co-authored-by: Tana M Berry <tanamarieberry@yahoo.com>
3.6 KiB
title, sidebar_label
| title | sidebar_label |
|---|---|
| Integrate with Home Assistant | Home Assistant |
Home Assistant
Support level: Community
What is Home Assistant
Open source home automation that puts local control and privacy first. Powered by a worldwide community of tinkerers and DIY enthusiasts. Perfect to run on a Raspberry Pi or a local server.
:::caution
You might run into CSRF errors, this is caused by a technology Home-assistant uses and not authentik, see this GitHub issue.
:::
:::caution
Only prefixes starting with /auth need to be proxied (excluding prefixes starting with /auth/token), see this GitHub issue. This can be configured in the reverse proxy (e.g. nginx, Traefik) or in authentik Provider's Unauthorized Paths.
:::
:::note
For Home Assistant to work with authentik, a custom integration needs to be installed for Home Assistant.
:::
Preparation
The following placeholders will be used:
hass.companyis the FQDN of the Home Assistant install.authentik.companyis the FQDN of the authentik install.
authentik configuration
-
Create a Proxy Provider under Applications > Providers using the following settings:
- Name: Home Assistant
- Authentication flow: default-authentication-flow
- Authorization flow: default-provider-authorization-explicit-consent
- External Host: Set this to the external URL you will be accessing Home Assistant from
- Internal Host:
http://hass.company:8123
-
Create an Application under Applications > Applications using the following settings:
- Name: Home Assistant
- Slug: homeassistant
- Provider: Home Assistant (the provider you created in step 1)
-
Create an outpost deployment for the provider you've created above, as described here. Deploy this Outpost either on the same host or a different host that can access Home Assistant. The outpost will connect to authentik and configure itself.
Home Assistant configuration
- Configure trusted_proxies for the HTTP integration with the IP(s) of the Host(s) authentik is running on.
- If you don't already have it set up, https://github.com/BeryJu/hass-auth-header, using the installation guide.
- There are two ways to configure the custom component.
- To match on the user's authentik username, use the following configuration:
auth_header: username_header: X-authentik-username - Alternatively, you can associate an existing Home Assistant username to an authentik username.
- Within authentik, navigate to Directory > Users.
- Select Edit for the user then add the following configuration to the Attributes section. Be sure to replace
hassusernamewith the Home Assistant username. :::note This configuration will add an additional header for the authentik user which will contain the Home Assistant username and allow Home Assistant to authenticate based on that. :::additionalHeaders: X-ak-hass-user: hassusername - Then configure the Home Assistant custom component to use this header:
auth_header: username_header: X-ak-hass-user
- To match on the user's authentik username, use the following configuration: