joshuar-go-hass-agent/docs/BREAKING_CHANGES.md

209 lines
8.5 KiB
Markdown
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# BREAKING CHANGES
## Table of Contents
- [BREAKING CHANGES](#breaking-changes)
- [Table of Contents](#table-of-contents)
- [Version 11.0.0](#version-1100)
- [Worker and Agent preferences merge](#worker-and-agent-preferences-merge)
- [What you need to do](#what-you-need-to-do)
- [Version 10.0.0](#version-1000)
- [New preferences file location and format](#new-preferences-file-location-and-format)
- [What you need to do](#what-you-need-to-do-1)
- [Run the upgrade command](#run-the-upgrade-command)
- [Manual upgrade steps (if the upgrade command failed)](#manual-upgrade-steps-if-the-upgrade-command-failed)
- [Log file location normalization](#log-file-location-normalization)
- [What you need to do](#what-you-need-to-do-2)
- [MQTT Device renamed](#mqtt-device-renamed)
- [What you need to do](#what-you-need-to-do-3)
- [Power controls renaming and consolidation (when using MQTT)](#power-controls-renaming-and-consolidation-when-using-mqtt)
- [What you need to do](#what-you-need-to-do-4)
## Version 11.0.0
### Worker and Agent preferences merge
Individual worker preferences, for adjusting preferences around different sensor
groups, were previously in their own files under the [configuration
directory](../README#-preferences). They now live in the agent preferences file
(`preferences.toml`), under the `worker` heading.
#### What you need to do
Any changes from the default values for worker preferences you have made will
need to be **manually** changed in the agent preferences file. All workers with
preferences should have their default preferences listed in the file, and you can
consult the list of sensors in the [README](../README.md#-sensors) which has
relevant preferences mentioned.
Once you have migrated any custom preferences, it is safe to delete the
individual preferences files (named `*_preferences.toml`).
## Version 10.0.0
### New preferences file location and format
The agent preferences file (`preferences.toml`) location has changed. The
configuration can be found in `~/.config/go-hass-agent/`.
The format of the file has changed as well it now contains more structure.
#### What you need to do
##### Run the upgrade command
The `upgrade` command has been added to Go Hass Agent that will attempt to
migrate a preferences file from an older version to the location and format used
by the new version. It uses reasonable efforts to migrate but may not succeed
and is harmless to run regardless. **It is the recommended remediation for this
breaking change.**
After you have installed the new version of Go Hass Agent:
1. Open a terminal.
2. Run `go-hass-agent upgrade`
3. If the upgrade command reports the upgrade was successful, great news! You
can run proceed to reviewing the [remaining breaking
changes](#table-of-contents) and performing required actions as applicable.
4. If the upgrade command reports an error. You'll need to proceed with the
[manual steps](#manual-upgrade-steps-if-the-upgrade-command-failed).
##### Manual upgrade steps (if the upgrade command failed)
> [!IMPORTANT]
>
> You only need to perform the manual upgrade steps here if the [upgrade
> command](#run-the-upgrade-command) failed.
These changes will require re-registering (see below) after upgrading.
> [!NOTE]
>
> As a result of re-registering, Go Hass Agent will appear as a new device in
> Home Assistant. Automations and dashboards using entities from the previous
> version of Go Hass Agent might need to be reconfigured. In most cases, the
> [repairs integration](https://www.home-assistant.io/integrations/repairs/)
> will alert and direct you to make any adjustments needed, after following the
> manual upgrade steps and restarting the agent.
To re-register:
1. Upgrade Go Hass Agent.
2. Stop Go Hass Agent if already running.
3. Open your Home Assistant ***mobile_app*** integrations page:
[![Open your Home Assistant instance to the mobile_app
integration.](https://my.home-assistant.io/badges/integration.svg)](https://my.home-assistant.io/redirect/integration/?domain=mobile_app)
4. Locate the entry for your existing Go Hass Agent device. It should be named
the same as the hostname of the device it is running on.
5. Click on the menu (three vertical dots) at the right of the entry:
![Delete Agent Example](../assets/screenshots/delete-from-mobile-app-integrations.png)
6. Choose **Delete**.
7. Follow the [first-run instructions](../README.md#-first-run) in the README to
re-register the agent.
8. Once the agent has successfully re-registered, you can remove the old
configuration directory and its contents. The old location will be
`~/.config/com.joshuar.go-hass-agent.debug`.
9. If you previously configured MQTT in Go Hass Agent, you will need to
[re-enable](../README.md#configuration) MQTT after re-registering.
- For users with headless installs, you'll need to edit `preferences.toml`
and manually add the appropriate config options. Add a section in the file
similar to the following:
```toml
[mqtt]
server = 'tcp://localhost:1883'
user = 'test-user' # optional, only if needed
password = 'password' # optional, only if needed
enabled = true
```
[⬆️ Back to Top](#table-of-contents)
### Log file location normalization
The agent will now write to a log file at
`~/.config/go-hass-agent/go-hass-agent.log`.
#### What you need to do
Previous versions may have written a log file to either
`~/.config/go-hass-agent.log` or
`~/.config/com.joshuar.go-hass-agent.debug/go-hass-agent.log`. You can delete
these files if desired.
If you do not wish Go Hass Agent to write any log file, pass `--no-log-file`
when running the agent.
[⬆️ Back to Top](#table-of-contents)
### MQTT Device renamed
The naming of Go Hass Agent in the MQTT integration in Home Assistant has
changed. It is now named after the hostname of the device running the agent,
rather than the generic “Go Hass Agent”. This makes it easier to navigate
between multiple devices running Go Hass Agent in Home Assistant.
#### What you need to do
As a result of this, you may end up with a deprecated, non-functional “Go Hass
Agent” device entry in Home Assistant. It can safely be removed.
> [!IMPORTANT]
>
> As the device has changed, existing automations or dashboards that are using
> entities from the old “Go Hass Agent” may be broken. In most cases, the
> [repairs integration](https://www.home-assistant.io/integrations/repairs/)
> will alert and direct you to make any adjustments needed.
<!-- #### As a last resort
1. Open Home Assistant to the **MQTT** integration page.
[![Open your Home Assistant instance and show the MQTT
integration.](https://my.home-assistant.io/badges/integration.svg)](https://my.home-assistant.io/redirect/integration/?domain=mqtt)
1. Click on the ***devices*** link:
![Open MQTT devices Example](../assets/screenshots/open-mqtt-devices.png)
2. Locate and click on the row for the agent. It should be named the same as
the hostname of the device it is running on.
3. Click on the menu (three vertical dots) below the device info:
![Open MQTT device options Example](../assets/screenshots/mqtt-device-options.png)
4. Choose **Delete**.
5. Restart Go Hass Agent.
6. The MQTT device for Go Hass Agent should reappear with the correct options. -->
[⬆️ Back to Top](#table-of-contents)
### Power controls renaming and consolidation (when using MQTT)
If you have [enabled MQTT](../README.md#mqtt-sensors-and-controls) in Go Hass
Agent, then you may have some controls for shutting down/suspending the device
running the agent and locking the screen/session of the user running the agent.
These controls have been consolidated and only the controls that are supported
by your device will be shown. Notably:
- On devices running with a graphical environment with `systemd-logind`
integration (KDE, Gnome), there will be two buttons available for
screen/session locking (***Lock Session*** and ***Unlock Session***).
- On other graphical environments (Xfce, Cinnamon) there will be a single
***Lock Screensaver*** button.
- Previously, buttons for all possible power states were created by Go Hass
Agent. In this version, only the controls that are supported on your device
will be available. For example, if your device does not support hibernation,
this control will not be shown.
#### What you need to do
Follow [what you need to do](#what-you-need-to-do-2) for the MQTT device
rename breaking change, if not done already.
[⬆️ Back to Top](#table-of-contents)