Install Home Assistant Community Store?

I’m looking to install Home Assistant Community Store. https://hacs.xyz/

https://www.home-assistant.io/blog/2020/05/26/installation-methods-and-community-guides-wiki/


It looks like dietpi is using Home Assistant Core
Run the Home Assistant Core application directly on Python. It does not provide the full Supervisor experience, and thus does not provide the Supervisor panel and add-ons.

FYI dietpi could use Home Assistant Supervised
The full Home Assistant experience on a regular Linux operating system. This method was previously known as “Hass.io on generic Linux”, installed on top of, e.g., Debian.

From https://hacs.xyz/docs/setup/download

Home Assistant Core​

Open a terminal
Change to the user that is running Home Assistant
Run the HACS download script

wget -O - https://get.hacs.xyz | bash -

I’m to change to the user that is running Home Assistant. Htop says the user is homeassistant how ever I cant seem to login.

homeassistant:x:997:994::/home/homeassistant:/usr/sbin/nologin

Thoughts?

You should be able to switch by using following command.

sudo -u homeassistant bash
. /home/homeassistant/pyenv-activate.sh

Not sure how install process changed, but I did some test in the past on this https://dietpi.com/forum/t/home-assistant-supervised-on-dietpi/4726/8

Result was a system having software installed conflicting with DietPi

Any updates on this? Supervisor would be great for my setup.

nothing changed as Home Assistant - Supervised is still conflicting with DietPi network configuration.

what you cant figure out how to install HA supervised? Installing Home Assistant Supervised on a Raspberry Pi using Debian 12 - Community Guides - Home Assistant Community

Hello, what I did:

cd /mnt/dietpi_userdata/homeassistant
sudo su -c 'wget -O - https://get.hacs.xyz | bash -'
sudo chown homeassistant:homeassistant -R custom_components

And then following the Add Integration step (here).

3 Likes

nice that actually worked. Thanks

Starting next release, we will pre-download HACS plugin during HA install. However, activation would need to be done individually still as describe on HACS doc.

just to give everyone a heads up I was told on the hacs discord channel that dietpi installations were not supported.

so If you are having problems, you are on your own, with no support from hacs.

Maybe we should do same and accept DietPi script related questions only. Means to leave users with all their other questions alone.

I hope this is not what you decided on the end!

There seems to be an issue with HACS on dietpi-software installed home assistant. I don’t know if it can be fixed easily.

I can’t update HACS from the home assistant itself (previously it was working fine, not sure when it stopped). If I reinstall home assistant using dietpi-software reinstall, the newest version is put in place correctly. But if home assistant is updated using the script (/home/homeassistant/homeassistant-update.sh), old HACS remain.

Here’s a journalctl dump after triggering the update from within HACS:

Apr 24 02:05:16 DietPi Home Assistant[271676]: 2023-04-24 02:05:16.155 WARNING (SyncWorker_3) [custom_components.hacs] Could not create backup: [Errno 13] Permission denied: 'integration.py'
Apr 24 02:05:17 DietPi Home Assistant[271676]: 2023-04-24 02:05:17.115 ERROR (MainThread) [custom_components.hacs] <Integration hacs/integration> Download was not completed
Apr 24 02:05:17 DietPi Home Assistant[271676]: 2023-04-24 02:05:17.123 ERROR (MainThread) [homeassistant.components.websocket_api.http.connection] [547410394176] Error handling message: Unknown error (unknown_error) [MY_USERNAME_REDACTED] from 10.9.0.2 (Mozilla/5.0 (Linux; Android 12; [MY_AND_BROWSERDEVICE_REDACTED])
Apr 24 02:05:17 DietPi Home Assistant[271676]: Traceback (most recent call last):
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/home/homeassistant/.pyenv/versions/3.10.10/lib/python3.10/site-packages/homeassistant/components/websocket_api/decorators.py", line 26, in _handle_async_response
Apr 24 02:05:17 DietPi Home Assistant[271676]:     await func(hass, connection, msg)
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/mnt/dietpi_userdata/homeassistant/custom_components/hacs/websocket/repository.py", line 216, in hacs_repository_download
Apr 24 02:05:17 DietPi Home Assistant[271676]:     await repository.async_install()
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/mnt/dietpi_userdata/homeassistant/custom_components/hacs/repositories/base.py", line 899, in async_install
Apr 24 02:05:17 DietPi Home Assistant[271676]:     await self.async_install_repository()
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/mnt/dietpi_userdata/homeassistant/custom_components/hacs/repositories/base.py", line 993, in async_install_repository
Apr 24 02:05:17 DietPi Home Assistant[271676]:     await self.hacs.hass.async_add_executor_job(backup.restore)
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/home/homeassistant/.pyenv/versions/3.10.10/lib/python3.10/concurrent/futures/thread.py", line 58, in run
Apr 24 02:05:17 DietPi Home Assistant[271676]:     result = self.fn(*self.args, **self.kwargs)
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/mnt/dietpi_userdata/homeassistant/custom_components/hacs/utils/backup.py", line 93, in restore
Apr 24 02:05:17 DietPi Home Assistant[271676]:     shutil.rmtree(self.local_path)
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/home/homeassistant/.pyenv/versions/3.10.10/lib/python3.10/shutil.py", line 725, in rmtree
Apr 24 02:05:17 DietPi Home Assistant[271676]:     _rmtree_safe_fd(fd, path, onerror)
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/home/homeassistant/.pyenv/versions/3.10.10/lib/python3.10/shutil.py", line 658, in _rmtree_safe_fd
Apr 24 02:05:17 DietPi Home Assistant[271676]:     _rmtree_safe_fd(dirfd, fullname, onerror)
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/home/homeassistant/.pyenv/versions/3.10.10/lib/python3.10/shutil.py", line 681, in _rmtree_safe_fd
Apr 24 02:05:17 DietPi Home Assistant[271676]:     onerror(os.unlink, fullname, sys.exc_info())
Apr 24 02:05:17 DietPi Home Assistant[271676]:   File "/home/homeassistant/.pyenv/versions/3.10.10/lib/python3.10/shutil.py", line 679, in _rmtree_safe_fd
Apr 24 02:05:17 DietPi Home Assistant[271676]:     os.unlink(entry.name, dir_fd=topfd)
Apr 24 02:05:17 DietPi Home Assistant[271676]: PermissionError: [Errno 13] Permission denied: 'integration.py'

I am sure the whole folder and everything within is owned by user homeassistant.

The script will update HA core only and leave HACS untouched.

Yes. I just put it there to show what I tried. So - is it possible to update HACS without reinstalling home assistant?

Did a test on my Orange Pi 5 test system. Installed HACS 1.30 in first place and was able to update to 1.32.1 from HA web interface without issues. HACS was loading fine after HA service restart.

To be sure on file system permission, you can try following:

chown -R homeassistant:homeassistant /mnt/dietpi_userdata/homeassistant
systemctl restart home-assistant.service

Interesting. I this before but probably did not restart homeassistant. After chowning again and restarting, updating works. Thanks.

I got a huge red button on HACS app requesting the restart :slight_smile:

Anyway, good it has been solved now.

I meant restarting home assistant before trying to update HACS (and after, yes).

HA needs to be restarted after HACS update. And of course, everything inside /mnt/dietpi_userdata/homeassistant needs to be owned by homeassistant user/group.