This quick start is suitable for the following:
- Rasbian Buster on
armv7
(e.g. RaspberryPi models 3 & 4). - Ubuntu 18.04 systems on
amd64
andaarch64
(e.g. nVidia Jetson Nano)
Not all capabilities of Home Assistant are supported on any platform other than as specified below.
Docker CE >= 19.03
Systemd >= 239
NetworkManager >= 1.14.6
AppArmor == 2.13.x (built into the kernel)
Debian Linux Debian 11 aka Bullseye (no derivatives)
Home Assistant OS-Agent (Only the latest release is supported)
These instructions are indended to provide guidance for installation on additional platforms, notably Rasbian, Ubuntu, and the nVidia Jetson Jetpack distributions (Ubuntu-based).
🎯 TL/DR Commands to be executed for installation; see end of document for summary.
- Home Assistant (supervised)
- Motion Ã👁 with three (3) AI's
Download OS image and flash SD card using Balena Etcher
These installation instructions have only been tested on the following.
- Raspberry Pi OS armhf-32bit
- Ubuntu 18.04
amd64
aarch64
Future:
- Raspberry Pi OS aarch-64bit
- Debian 11 (Bullseye) armhf-64bit
- Ubuntu 20.04.03 LTS aarch-64-bit
Modify the flashed file-system image as appropriate to the platform; not all options are available for all platforms.
Specify a WiFi SSID and pre-shared key (PSK) in the /wpa_supplicant.conf
file, typically mounted in /Volumes/boot
on macOS; for example:
ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev
network={
ssid="<YOUR_SSID>"
psk="<YOUR_PASSWORD>"
key_mgmt=WPA-PSK
}
Create a zero-length file called /ssh
on the flashed media to enable remote access; for example:
touch /Volumes/boot/ssh
Specify a hostname and a public ssh
key to enable remote, headless, access to the device. The file is typically mounted at /Volumes/RASPIFIRM/sysconf.txt
Uncomment the line with root_authorized_keys
with the contents of ~/.ssh/id_rsa.pub
file.
root_authorized_key=ssh-rsa <YOUR KEY> you@yourhost
Uncomment the line with hostname
with the desird name, for example:
hostname: motion-ai
Eject uSD card from the host computer, insert into device, attach ethernet cord -- not required for Rasbian iff the wpa_supplicant.conf
was created -- and provide power.
Access device using ssh
ssh <ip> -l pi
ssh <hostname>.local -l root
ssh <ip> -l ubuntu
Update software repositories and install base programs (as root).
sudo apt update -qq -y
sudo apt install -qq -y curl wget jq sudo git make gettext ssh
SSID=<yourwifi-name>
PSK=<yourwifi-password>
nmcli dev wifi connect ${SSID} password ${PSK}
Install Docker-CE (community edition) with the following command:
curl -fsSL get.docker.com | sh
See the instructions to install Home Assistant in a supervised configuration; TL/DR, do the following:
To install Home Assistant there are a number of prerequisite software packages; install using the following:
sudo apt install -qq -y --no-install-recommends udisks2 libglib2.0-bin dbus apparmor
WARNING Before installing network-manager
specify that MAC address randomization should be turned off, otherwise the device will need to be power-cycled; for example (as root, n.b. sudo -s
):
mkdir -p /etc/NetworkManager/conf.d
echo '[connection]' > /etc/NetworkManager/conf.d/100-disable-wifi-mac-randomization.conf
echo 'wifi.mac-address-randomization=1' >> /etc/NetworkManager/conf.d/100-disable-wifi-mac-randomization.conf
echo '[device]' >> /etc/NetworkManager/conf.d/100-disable-wifi-mac-randomization.conf
echo 'wifi.scan-rand-mac-address=no' >> /etc/NetworkManager/conf.d/100-disable-wifi-mac-randomization.conf
Then install network-manager
; for example:
sudo apt install -qq -y --no-install-recommends network-manager
The Agent for Home Assistant OS provides services for the host OS.
Download the appropriate architecture package and install.
wget https://github.com/home-assistant/os-agent/releases/download/1.2.2/os-agent_1.2.2_linux_armv7.deb
sudo dpkg -i os-agent_1.2.2_linux_armv7.deb
wget https://github.com/home-assistant/os-agent/releases/download/1.2.2/os-agent_1.2.2_linux_aarch64.deb
sudo dpkg -i os-agent_1.2.2_linux_aarch64.deb
wget https://github.com/home-assistant/os-agent/releases/download/1.2.2/os-agent_1.2.2_linux_x86_64.deb
sudo dpkg -i os-agent_1.2.2_linux_x86_64.deb
The installation will prompt for end-user specification of architecture (DAMW)
Install the supervised version of Home Assistant with all its friends using the Debian package; suitable for all architectures.
wget https://github.com/home-assistant/supervised-installer/releases/latest/download/homeassistant-supervised.deb
sudo dpkg -i homeassistant-supervised.deb
Installation may be verified by visiting the Home Assistant server on the host at port 8123. If AppArmor is not enabled per the supervisor, please refer to these instructions.
Additional Home Assistant add-ons are utilized for cameras, messaging, and uploading; these services should be installed and started prior to the next step.
- The username and password defaults are
username
andpassword
and have corresponding options. - Any secret must be enclosed in quotations, but literal values do not.
The standard add-on is in the built-in Add-On Store catalog. Visit the Supervisor panel item and view the Add-on Store. MQTT credentials for at least one user must be provided; there is no anonymous MQTT support. For example:
logins:
- username: username
password: password
customize:
active: false
folder: mosquitto
certfile: fullchain.pem
keyfile: privkey.pem
require_certificate: false
MQTT topics are specified as group, device, and camera with corresponding sub-topics, including AI services; example: any group, device, and camera (+
) end events with any annotation: +/+/+/event/end/+
.
end
image
annotated
face
alpr
The Motion Classic add-on is cataloged in the repository https://github.com/dcmartin/hassio-addons
which must be added in the Home Assistant Add-On Store.
The add-on's default configuration includes secrets, but may override with literal values; for example:
group: motion
device: my-device-name
client: +
timezone: America/Los_Angeles
latitude: 32.7
longitude: -121.8
default:
netcam_userpass: my-netcam-username:my-netcam-password
password: '!secret motioncam-password'
username: '!secret motioncam-username'
mqtt:
host: core-mosquitto
password: password
port: 1883
username: username
A basic FTP server is provided in the built-in community add-on catalog. Visit the Supervisor panel item and view the Add-on Store.
Clone the repository and copy into the Home Assistant installation directory, for example:
git clone https://github.com/dcmartin/motion-ai /tmp/motion-ai
cd /tmp/motion-ai
tar cvf - . | ( cd /usr/share/hassio ; sudo tar xvf - )
ln -s /usr/share/hassio ~/motion-ai
rm -fr /tmp/motion-ai
Setup is automatic, however options are specified through environment variables and/or local files with the same name. There is a sample script config.sh
which can be changed to meet local conditions. Once configured, run the make
command to buid the initial YAML and JSON.
Configurations for both Home Assistant and the Motion Classic add-on parameters are calculated from the options, but may be overruled in the add-on configuration, e.g. timezone, latitude, longitude, etc... See the documentation for more information.
Secrets (e.g. !secret motioncam-username
) are only evaluated when HA is started; consequently changes in the Motion Classic add-on may require HA restart.
Run the installation script; it will download additional containers for the entity, face, and license plate AI's as well as model weights where appropriate.
This process will take a long time.
cd /usr/share/hassio
make
./sh/get.motion-ai.sh
When the script has completed there will now be three additional containers running; each listens for REST API calls with the default returning service status
yolo4motion
- entity detectionface4motion
- face detectionalpr4motion
- license plate detection
For example:
curl http://localhost:4662/
Manual rebuilding of the YAML and JSON may be performed; there are two options:
- Recovery - run
make
in the directory/usr/share/hassio/
; this will utilize the options specified or defaults. - Rebuild - run
make
in the directory/usr/share/hassio/homeassistant/
; this will utilize the current specifications; stored in the file/usr/share/hassio/homeassistant/setup.json
After recovery or rebuild the homeassistant
container must be restarted or the device rebooted; for example to rebuild the YAML and JSON using current specification:
cd /usr/share/hassio/homeassistant
make
docker restart homeassistant
Servies may also be started manually from the installation directory; scripts use the options specified or defaults, notably for MQTT, including:
MQTT_HOST
,MQTT_USERNAME
,MQTT_PASSWORD
MOTION_GROUP
,MOTTION_DEVICE
,MOTION_CLIENT
Each AI service has it's own start-up script which should be executed from the HA installation directory (n.b. /usr/share/hassio
)
- Entity -
./sh/yolo4motion.sh
- Face -
./sh/face4motion.sh
- License plate -
./sh/alpr4motion.sh
Automated installation on a RaspberryPi 3B+; additional steps are required to setup the add-ons.
For a system installation flashed with Rasbian 32bit.
# turn off prompt for sudo command
echo "${USER} ALL=(ALL) NOPASSWD: ALL" | sudo tee /etc/sudoers.d/010_${USER}-nopasswd
# become root
sudo -s
# turn off wifi mac randomization
mkdir -p /etc/NetworkManager/conf.d
cat > /etc/NetworkManager/conf.d/100-disable-wifi-mac-randomization.conf << EOF
[connection]
wifi.mac-address-randomization=1
[device]
wifi.scan-rand-mac-address=no
EOF
# update and install prerequisites
sudo apt update -qq -y
sudo apt install -qq -y --no-install-recommends \
curl wget jq sudo git make gettext ssh \
udisks2 libglib2.0-bin dbus apparmor network-manager
# get docker
curl -fsSL get.docker.com | sh
sudo addgroup ${USER} docker
# install home assistant OS agent (architecture dependent)
wget https://github.com/home-assistant/os-agent/releases/download/1.2.2/os-agent_1.2.2_linux_armv7.deb
sudo dpkg -i os-agent_1.2.2_linux_armv7.deb
# install home assistant supervised container stack
wget https://github.com/home-assistant/supervised-installer/releases/latest/download/homeassistant-supervised.deb
sudo dpkg -i homeassistant-supervised.deb
After successful completion of these steps the generic Home Assistant web UI will be available on port 8123; please wait 10-15 minutes. The add-ons for MQTT and Motion Classic can be added after Home Assistant completes initial setup.
AppArmor may require the following to be added /boot/cmdline.txt
file; add to the end of the first, and only, line.
apparmor=1 security=apparmor
HACS (Home Assistant Community Store) can be installed using the following:
wget -O - https://get.hacs.xyz | sudo bash -
These steps may be peformed once Home Assistant has been installed, configured, and is operational; in addition to these commands, the add-ons must be installed, configured, and started.
git clone https://github.com/dcmartin/motion-ai /tmp/motion-ai
cd /tmp/motion-ai
tar cf - . | ( cd /usr/share/hassio ; sudo tar xf - )
ln -s /usr/share/hassio ~/motion-ai
rm -fr /tmp/motion-ai
cd /usr/share/hassio
make
sudo ./sh/get.weights.sh
for i in yolo face alpr; do sudo ./sh/${i}4motion.sh; done
sudo docker restart homeassistant
The Motion Ã👁 setup script downloads and starts the AI's and replaces the default Home Assistant interface on port 8123; the Web UI will now be available on port 80. Reboot is recommended after the AI's and add-ons are installed, configured, and started.