Add default daemon config, and check for journald (#104)
* Add default daemon config, and check for journald * Remove snap * Add storage-driver check * Remove exit * Change echo -> info
This commit is contained in:
parent
756f6db062
commit
928e46db76
1 changed files with 29 additions and 11 deletions
40
installer.sh
40
installer.sh
|
@ -1,6 +1,7 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
|
function info { echo -e "[Info] $*"; }
|
||||||
function error { echo -e "[Error] $*"; exit 1; }
|
function error { echo -e "[Error] $*"; exit 1; }
|
||||||
function warn { echo -e "[Warning] $*"; }
|
function warn { echo -e "[Warning] $*"; }
|
||||||
|
|
||||||
|
@ -14,6 +15,7 @@ ARCH=$(uname -m)
|
||||||
DOCKER_BINARY=/usr/bin/docker
|
DOCKER_BINARY=/usr/bin/docker
|
||||||
DOCKER_REPO=homeassistant
|
DOCKER_REPO=homeassistant
|
||||||
DOCKER_SERVICE=docker.service
|
DOCKER_SERVICE=docker.service
|
||||||
|
DOCKER_DAEMON_CONFIG=/etc/docker/daemon.json
|
||||||
URL_VERSION="https://version.home-assistant.io/stable.json"
|
URL_VERSION="https://version.home-assistant.io/stable.json"
|
||||||
URL_HA="https://raw.githubusercontent.com/home-assistant/supervised-installer/master/files/ha"
|
URL_HA="https://raw.githubusercontent.com/home-assistant/supervised-installer/master/files/ha"
|
||||||
URL_BIN_HASSIO="https://raw.githubusercontent.com/home-assistant/supervised-installer/master/files/hassio-supervisor"
|
URL_BIN_HASSIO="https://raw.githubusercontent.com/home-assistant/supervised-installer/master/files/hassio-supervisor"
|
||||||
|
@ -38,12 +40,28 @@ if systemctl list-unit-files ModemManager.service | grep enabled; then
|
||||||
warn "ModemManager service is enabled. This might cause issue when using serial devices."
|
warn "ModemManager service is enabled. This might cause issue when using serial devices."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Detect if running on snapped docker
|
# Detect wrong docker logger config
|
||||||
if snap list docker >/dev/null 2>&1; then
|
if [ ! -f "$DOCKER_DAEMON_CONFIG" ]; then
|
||||||
DOCKER_BINARY=/snap/bin/docker
|
# Write default configuration
|
||||||
DATA_SHARE=/root/snap/docker/common/hassio
|
info "Creating default docker deamon configuration $DOCKER_DAEMON_CONFIG"
|
||||||
CONFIG=$DATA_SHARE/hassio.json
|
cat > "$DOCKER_DAEMON_CONFIG" <<- EOF
|
||||||
DOCKER_SERVICE="snap.docker.dockerd.service"
|
{
|
||||||
|
"log-driver": "journald",
|
||||||
|
"storage-driver": "overlay2"
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
# Restart Docker service
|
||||||
|
info "Restarting docker service"
|
||||||
|
systemctl restart "$DOCKER_SERVICE"
|
||||||
|
else
|
||||||
|
STORRAGE_DRIVER=$(docker info -f "{{json .}}" | jq -r -e .Driver)
|
||||||
|
LOGGING_DRIVER=$(docker info -f "{{json .}}" | jq -r -e .LoggingDriver)
|
||||||
|
if [[ "$STORRAGE_DRIVER" != "overlay2" ]]; then
|
||||||
|
warn "Docker is using $STORRAGE_DRIVER and not 'overlay2' as the storrage driver, this is not supported."
|
||||||
|
fi
|
||||||
|
if [[ "$LOGGING_DRIVER" != "journald" ]]; then
|
||||||
|
warn "Docker is using $LOGGING_DRIVER and not 'journald' as the logging driver, this is not supported."
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Parse command line parameters
|
# Parse command line parameters
|
||||||
|
@ -138,13 +156,13 @@ EOF
|
||||||
|
|
||||||
##
|
##
|
||||||
# Pull supervisor image
|
# Pull supervisor image
|
||||||
echo "[Info] Install supervisor Docker container"
|
info "Install supervisor Docker container"
|
||||||
docker pull "$HASSIO_DOCKER:$HASSIO_VERSION" > /dev/null
|
docker pull "$HASSIO_DOCKER:$HASSIO_VERSION" > /dev/null
|
||||||
docker tag "$HASSIO_DOCKER:$HASSIO_VERSION" "$HASSIO_DOCKER:latest" > /dev/null
|
docker tag "$HASSIO_DOCKER:$HASSIO_VERSION" "$HASSIO_DOCKER:latest" > /dev/null
|
||||||
|
|
||||||
##
|
##
|
||||||
# Install Hass.io Supervisor
|
# Install Hass.io Supervisor
|
||||||
echo "[Info] Install supervisor startup scripts"
|
info "Install supervisor startup scripts"
|
||||||
curl -sL ${URL_BIN_HASSIO} > "${PREFIX}/sbin/hassio-supervisor"
|
curl -sL ${URL_BIN_HASSIO} > "${PREFIX}/sbin/hassio-supervisor"
|
||||||
curl -sL ${URL_SERVICE_HASSIO} > "${SYSCONFDIR}/systemd/system/hassio-supervisor.service"
|
curl -sL ${URL_SERVICE_HASSIO} > "${SYSCONFDIR}/systemd/system/hassio-supervisor.service"
|
||||||
|
|
||||||
|
@ -160,7 +178,7 @@ systemctl enable hassio-supervisor.service
|
||||||
#
|
#
|
||||||
# Install Hass.io AppArmor
|
# Install Hass.io AppArmor
|
||||||
if command -v apparmor_parser > /dev/null 2>&1; then
|
if command -v apparmor_parser > /dev/null 2>&1; then
|
||||||
echo "[Info] Install AppArmor scripts"
|
info "Install AppArmor scripts"
|
||||||
mkdir -p "${DATA_SHARE}/apparmor"
|
mkdir -p "${DATA_SHARE}/apparmor"
|
||||||
curl -sL ${URL_BIN_APPARMOR} > "${PREFIX}/sbin/hassio-apparmor"
|
curl -sL ${URL_BIN_APPARMOR} > "${PREFIX}/sbin/hassio-apparmor"
|
||||||
curl -sL ${URL_SERVICE_APPARMOR} > "${SYSCONFDIR}/systemd/system/hassio-apparmor.service"
|
curl -sL ${URL_SERVICE_APPARMOR} > "${SYSCONFDIR}/systemd/system/hassio-apparmor.service"
|
||||||
|
@ -178,11 +196,11 @@ fi
|
||||||
|
|
||||||
##
|
##
|
||||||
# Init system
|
# Init system
|
||||||
echo "[Info] Run Home Assistant Supervised"
|
info "Run Home Assistant Supervised"
|
||||||
systemctl start hassio-supervisor.service
|
systemctl start hassio-supervisor.service
|
||||||
|
|
||||||
##
|
##
|
||||||
# Setup CLI
|
# Setup CLI
|
||||||
echo "[Info] Install cli 'ha'"
|
info "Install cli 'ha'"
|
||||||
curl -sL ${URL_HA} > "${PREFIX}/bin/ha"
|
curl -sL ${URL_HA} > "${PREFIX}/bin/ha"
|
||||||
chmod a+x "${PREFIX}/bin/ha"
|
chmod a+x "${PREFIX}/bin/ha"
|
||||||
|
|
Loading…
Reference in a new issue