use templates and always adjust paths
This prepares for further customization of file locations.
This commit is contained in:
parent
429bb2c999
commit
b7fa6c0030
5 changed files with 13 additions and 20 deletions
|
@ -2,7 +2,7 @@
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
# Load configs
|
# Load configs
|
||||||
CONFIG_FILE=/etc/hassio.json
|
CONFIG_FILE=%%HASSIO_CONFIG%%
|
||||||
|
|
||||||
# Read configs
|
# Read configs
|
||||||
DATA="$(jq --raw-output '.data // "/usr/share/hassio"' ${CONFIG_FILE})"
|
DATA="$(jq --raw-output '.data // "/usr/share/hassio"' ${CONFIG_FILE})"
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=Hass.io AppArmor
|
Description=Hass.io AppArmor
|
||||||
Wants=hassio-supervisor.service
|
Wants=hassio-supervisor.service
|
||||||
Before=docker.service hassio-supervisor.service
|
Before=%%DOCKER_SERVICE%% hassio-supervisor.service
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
Type=oneshot
|
Type=oneshot
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
# Load configs
|
# Load configs
|
||||||
CONFIG_FILE=/etc/hassio.json
|
CONFIG_FILE=%%HASSIO_CONFIG%%
|
||||||
|
|
||||||
SUPERVISOR="$(jq --raw-output '.supervisor' ${CONFIG_FILE})"
|
SUPERVISOR="$(jq --raw-output '.supervisor' ${CONFIG_FILE})"
|
||||||
HOMEASSISTANT="$(jq --raw-output '.homeassistant' ${CONFIG_FILE})"
|
HOMEASSISTANT="$(jq --raw-output '.homeassistant' ${CONFIG_FILE})"
|
||||||
|
|
|
@ -1,15 +1,15 @@
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=Hass.io supervisor
|
Description=Hass.io supervisor
|
||||||
Requires=docker.service
|
Requires=%%DOCKER_SERVICE%%
|
||||||
After=docker.service dbus.socket
|
After=%%DOCKER_SERVICE%% dbus.socket
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
Type=simple
|
Type=simple
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=5s
|
RestartSec=5s
|
||||||
ExecStartPre=-/usr/bin/docker stop hassio_supervisor
|
ExecStartPre=-%%DOCKER_BINARY%% stop hassio_supervisor
|
||||||
ExecStart=/usr/sbin/hassio-supervisor
|
ExecStart=/usr/sbin/hassio-supervisor
|
||||||
ExecStop=-/usr/bin/docker stop hassio_supervisor
|
ExecStop=-%%DOCKER_BINARY%% stop hassio_supervisor
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
|
|
@ -3,7 +3,7 @@ set -e
|
||||||
|
|
||||||
ARCH=$(uname -m)
|
ARCH=$(uname -m)
|
||||||
DOCKER_DAEMON_CONFIG=/etc/docker/daemon.json
|
DOCKER_DAEMON_CONFIG=/etc/docker/daemon.json
|
||||||
SNAP=false
|
DOCKER_BINARY=/usr/bin/docker
|
||||||
DOCKER_REPO=homeassistant
|
DOCKER_REPO=homeassistant
|
||||||
DOCKER_SERVICE=docker.service
|
DOCKER_SERVICE=docker.service
|
||||||
DATA_SHARE=/usr/share/hassio
|
DATA_SHARE=/usr/share/hassio
|
||||||
|
@ -27,15 +27,14 @@ command -v nmcli > /dev/null 2>&1 || echo "[Warning] No NetworkManager support o
|
||||||
|
|
||||||
#detect if running on snapped docker
|
#detect if running on snapped docker
|
||||||
if snap list docker >/dev/null 2>&1; then
|
if snap list docker >/dev/null 2>&1; then
|
||||||
SNAP=true
|
|
||||||
DOCKER_DAEMON_CONFIG=/root/snap/docker/current/etc/docker/daemon.json
|
DOCKER_DAEMON_CONFIG=/root/snap/docker/current/etc/docker/daemon.json
|
||||||
|
DOCKER_BINARY=/snap/bin/docker
|
||||||
DATA_SHARE=/root/snap/docker/common/hassio
|
DATA_SHARE=/root/snap/docker/common/hassio
|
||||||
CONFIG=$DATA_SHARE/hassio.json
|
CONFIG=$DATA_SHARE/hassio.json
|
||||||
DOCKER_SERVICE="snap.docker.dockerd.service"
|
DOCKER_SERVICE="snap.docker.dockerd.service"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
function version_gt() { test "$(printf '%s\n' "$@" | sort -V | head -n 1)" != "$1"; }
|
function version_gt() { test "$(printf '%s\n' "$@" | sort -V | head -n 1)" != "$1"; }
|
||||||
function adjust_snap() { sed "s,/usr/bin/docker,/snap/bin/docker,; s,docker.service,$DOCKER_SERVICE,; s,/etc/hassio.json,$CONFIG," -i "$1"; }
|
|
||||||
|
|
||||||
# Parse command line parameters
|
# Parse command line parameters
|
||||||
while [[ $# -gt 0 ]]; do
|
while [[ $# -gt 0 ]]; do
|
||||||
|
@ -148,11 +147,8 @@ echo "[Info] Install supervisor startup scripts"
|
||||||
curl -sL ${URL_BIN_HASSIO} > /usr/sbin/hassio-supervisor
|
curl -sL ${URL_BIN_HASSIO} > /usr/sbin/hassio-supervisor
|
||||||
curl -sL ${URL_SERVICE_HASSIO} > /etc/systemd/system/hassio-supervisor.service
|
curl -sL ${URL_SERVICE_HASSIO} > /etc/systemd/system/hassio-supervisor.service
|
||||||
|
|
||||||
#adjust paths for snap
|
sed -i "s,%%HASSIO_CONFIG%%,${CONFIG},g" /usr/sbin/hassio-supervisor
|
||||||
if [ "$SNAP" = "true" ]; then
|
sed -i "s,%%DOCKER_BINARY%%,${DOCKER_BINARY},g; s,%%DOCKER_SERVICE%%,${DOCKER_SERVICE},g" /etc/systemd/system/hassio-supervisor.service
|
||||||
adjust_snap /usr/sbin/hassio-supervisor
|
|
||||||
adjust_snap /etc/systemd/system/hassio-supervisor.service
|
|
||||||
fi
|
|
||||||
|
|
||||||
chmod a+x /usr/sbin/hassio-supervisor
|
chmod a+x /usr/sbin/hassio-supervisor
|
||||||
systemctl enable hassio-supervisor.service
|
systemctl enable hassio-supervisor.service
|
||||||
|
@ -166,11 +162,8 @@ if command -v apparmor_parser > /dev/null 2>&1; then
|
||||||
curl -sL ${URL_SERVICE_APPARMOR} > /etc/systemd/system/hassio-apparmor.service
|
curl -sL ${URL_SERVICE_APPARMOR} > /etc/systemd/system/hassio-apparmor.service
|
||||||
curl -sL ${URL_APPARMOR_PROFILE} > "${DATA_SHARE}"/apparmor/hassio-supervisor
|
curl -sL ${URL_APPARMOR_PROFILE} > "${DATA_SHARE}"/apparmor/hassio-supervisor
|
||||||
|
|
||||||
#adjust paths for snap
|
sed -i "s,%%HASSIO_CONFIG%%,${CONFIG},g" /usr/sbin/hassio-apparmor
|
||||||
if [ "$SNAP" = "true" ]; then
|
sed -i "s,%%DOCKER_SERVICE%%,${DOCKER_SERVICE},g" /etc/systemd/system/hassio-apparmor.service
|
||||||
adjust_snap /usr/sbin/hassio-apparmor
|
|
||||||
adjust_snap /etc/systemd/system/hassio-apparmor.service
|
|
||||||
fi
|
|
||||||
|
|
||||||
chmod a+x /usr/sbin/hassio-apparmor
|
chmod a+x /usr/sbin/hassio-apparmor
|
||||||
systemctl enable hassio-apparmor.service
|
systemctl enable hassio-apparmor.service
|
||||||
|
|
Loading…
Reference in a new issue