Custom component to support Automower.
This Home Assistant integration provides status and control of supported Husqvarna Automowers. The official Husqvarna API uses websocket connection for pushed updates, so no polling is performed. Park and Start commands including schedule overrides are supported by the integration allowing for robust automations to be implemented in Home Assistant. Diagnostic and statics provided by the API are included with the integration for monitoring mower usage and performance.
Husqvarna Automowers with built-in Automower® Connect or with the Automower® Connect Module are supported. This integration does not support Bluetooth connectivity with Automowers.
Requires Home Assistant 2023.3.0 or newer.
Installation using Home Assistant Community Store (HACS) is recommended.
-
If HACS is not installed, follow HACS installation and configuration at https://hacs.xyz/.
-
In HACS, search under integrations for Husqvarna Automower and install.
-
Restart Home Assistant!
-
Download the
husqvarna_automower.zip
file from the repository release section. -
Extract and copy the content into the path
/config/custom_components/husqvarna_automower
of your HA installation.Do not download directly from the
main
branch. -
Restart Home Assistant!
In order to use this integration you must properly configure OAuth2 credentials using your Husqvarna account. Refer to this guide for general overview of the process. Username/password authentication for this integration is no longer supported as of version 2022.7.0.
Your Husqvarna account username/password used for the Automower® Connect phone app is required. Most users probably created a Husqvarna account during initial mower setup.
-
Make sure, that the exgernal url on the page
Settings -> Network
in the fieldInternet
is set to your external url. -
Go to https://developer.husqvarnagroup.cloud/ and sign in with Husqvarna account. Sign in page has password recovery/reset using registered email address if needed. Authorize Developer Porthole to access Husqvarna account when prompted.
-
After signing in you will be automatically redirected to "Your applications". (Otherwise go to: https://developer.husqvarnagroup.cloud/applications)
-
Create a new application:
-
Name is required but can be anything, for example "My Home Assistant"
-
Description is optional
-
Redirect URL:
https://my.home-assistant.io/redirect/oauth
Confirm no extra spaces were appended at end of URL from copy and paste.
-
Click CREATE. Application Key and Application Secret will be generated and shown. Protect these like a username and password.
-
-
Click on CONNECT NEW API and connect the Authentication API.
-
Click on CONNECT NEW API again and connect the Husqvarna Automower API.
-
Leave this tab open in browser and continue with Home Assistant configuration.
The My Home Assistant redirect feature needs to be setup to redirect to your home assistant installation. See https://my.home-assistant.io/faq/ for additional information.
-
Add the integration to your home assistant installation and test the redirect feature by following below link:
-
Acknowledge prompts to open link, install Husqvarna Automower integration.
-
Acknowledge prompt to setup application credentials.
-
Enter the following from the Husqvrana developer tab:
- The name of the application assigned in Step 3 above
- Copy and paste the Application Key into the OAuth Client ID field
- Copy and paste the Application Secret into the OAuth Client Secret field
-
Click Create
-
Browser will be redirected to Husqvarna Developer site. Sign in and Authorize the integration to connect with your Husqvarna account
-
After authorizing the integration the browser will show the my Home Assistant redirect link to link this account. Click on Link Account.
-
Confirm successful connection of mower and assign to an HA area if desired.
The camera entity is disabled by default. The camera entity will plot the current coordinates and location history of the mower on a user provided image. To configure the entity you need to upload your desired map image and determine the coordinates of the top left corner and the bottom right corner of your selected image.
The camera entity is configured via the configure option on the integration. To enter the coordinates, ensure that they are in Signed Degree format and separated by a comma for example: 40.689209,-74.044661
You can then provide the path to the image you would like to use for the map and mower. This has been tested with the PNG format, other formats may work. The .../resources/map_image.png
default image is over written when the integration is updated, store the custom image in another location.
-
vacuum.start
The mower continues to mow, within the specified schedule -
vacuum.pause
Pauses the mower until a new command -
vacuum.stop
The mower returns to the base and parks there until the next schedule starts -
vacuum.return_to_base
The mower returns to the base and parks there until it gets a new start command -
number.automower_park_for
Override schedule to park mower for specified number of minutes. -
number.automower_mow_for
Override schedule to mow for specified number of minutes. -
number.automower_cutting_height
Set mower cutting height. -
select.automower_headlight_mode
Set the mower headlight operating mode
-
husqvarna_automower.calendar
Allows mower schedule to be revised. Supports single schedule per day, this will override existing schedule.service: husqvarna_automower.calendar data: start: '11:45:00' end: '21:30:00' monday: true tuesday: true wednesday: true thursday: true friday: true saturday: false sunday: false target: entity_id: vacuum.automower
start
must be less thanend
. Seconds are ignored. -
husqvarna_automower.custom_command
Allows custom JSON formatted commands to be sent.Example equivalent to
vacuum.start
service: husqvarna_automower.custom_command data: command_type: actions json_string: >- { "data": {"type": "ResumeSchedule"} } target: entity_id: vacuum.automower
See Husqvarna API reference for additional details.
Let your mower only mow during daytime to protect wildlife. Schedule is updated daily.
- alias: Automower_set_schedule
id: "enklfjf76"
description: "Mow from dawn till dusk"
trigger:
- platform: time
at: "23:58"
action:
service: husqvarna_automower.calendar
data:
start: '{{ states("sensor.sun_next_rising") | as_timestamp| timestamp_custom("%H:%M") }}'
end: '{{ states("sensor.sun_next_setting") | as_timestamp| timestamp_custom("%H:%M") }}'
monday: true
tuesday: true
wednesday: true
thursday: true
friday: true
saturday: true
sunday: true
target:
entity_id: vacuum.haffi
To enable debug logging for this integration and related libraries you can control this in your Home Assistant configuration.yaml
file.
Example:
logger:
default: info
logs:
custom_components.husqvarna_automower: debug
aioautomower: debug
After a restart detailed log entries will appear in /config/home-assistant.log
.
The OAuth2 credentials can be removed from the home assistant user interface. Navigate to the Integrations tab under settings. Access the Application Credentials menu by clicking on the Kebab (3 vertical dot menu icon) or direct link.
Dialog box stating the component is not configured. Please follow the documentation. This error is resolved by removing OAuth2 credentials