Delete installer.sh
This commit is contained in:
parent
b642964cb1
commit
ece9fcc946
1 changed files with 0 additions and 274 deletions
274
installer.sh
274
installer.sh
|
@ -1,274 +0,0 @@
|
|||
#!/usr/bin/env bash
|
||||
set -e
|
||||
|
||||
declare -a MISSING_PACKAGES
|
||||
|
||||
function info { echo -e "\e[32m[info] $*\e[39m"; }
|
||||
function warn { echo -e "\e[33m[warn] $*\e[39m"; }
|
||||
function error { echo -e "\e[31m[error] $*\e[39m"; exit 1; }
|
||||
|
||||
warn ""
|
||||
warn "If you want more control over your own system, run"
|
||||
warn "Home Assistant as a VM or run Home Assistant Core"
|
||||
warn "via a Docker container."
|
||||
warn ""
|
||||
warn "If you want to abort, hit ctrl+c within 10 seconds..."
|
||||
warn ""
|
||||
|
||||
sleep 10
|
||||
|
||||
ARCH=$(uname -m)
|
||||
|
||||
IP_ADDRESS=$(hostname -I | awk '{ print $1 }')
|
||||
|
||||
BINARY_DOCKER=/usr/bin/docker
|
||||
|
||||
DOCKER_REPO=homeassistant
|
||||
|
||||
SERVICE_DOCKER="docker.service"
|
||||
SERVICE_NM="NetworkManager.service"
|
||||
|
||||
FILE_DOCKER_CONF="/etc/docker/daemon.json"
|
||||
FILE_INTERFACES="/etc/network/interfaces"
|
||||
FILE_NM_CONF="/etc/NetworkManager/NetworkManager.conf"
|
||||
FILE_NM_CONNECTION="/etc/NetworkManager/system-connections/default"
|
||||
|
||||
URL_RAW_BASE="https://raw.githubusercontent.com/home-assistant/supervised-installer/master/files"
|
||||
URL_VERSION_HOST="version.home-assistant.io"
|
||||
URL_VERSION="https://${URL_VERSION_HOST}/stable.json"
|
||||
URL_BIN_APPARMOR="${URL_RAW_BASE}/hassio-apparmor"
|
||||
URL_BIN_HASSIO="${URL_RAW_BASE}/hassio-supervisor"
|
||||
URL_DOCKER_DAEMON="${URL_RAW_BASE}/docker_daemon.json"
|
||||
URL_HA="${URL_RAW_BASE}/ha"
|
||||
URL_INTERFACES="${URL_RAW_BASE}/interfaces"
|
||||
URL_NM_CONF="${URL_RAW_BASE}/NetworkManager.conf"
|
||||
URL_NM_CONNECTION="${URL_RAW_BASE}/system-connection-default"
|
||||
URL_SERVICE_APPARMOR="${URL_RAW_BASE}/hassio-apparmor.service"
|
||||
URL_SERVICE_HASSIO="${URL_RAW_BASE}/hassio-supervisor.service"
|
||||
URL_APPARMOR_PROFILE="https://version.home-assistant.io/apparmor.txt"
|
||||
|
||||
# Check env
|
||||
command -v systemctl > /dev/null 2>&1 || MISSING_PACKAGES+=("systemd")
|
||||
command -v nmcli > /dev/null 2>&1 || MISSING_PACKAGES+=("network-manager")
|
||||
command -v apparmor_parser > /dev/null 2>&1 || MISSING_PACKAGES+=("apparmor")
|
||||
command -v docker > /dev/null 2>&1 || MISSING_PACKAGES+=("docker")
|
||||
command -v jq > /dev/null 2>&1 || MISSING_PACKAGES+=("jq")
|
||||
command -v curl > /dev/null 2>&1 || MISSING_PACKAGES+=("curl")
|
||||
command -v dbus-daemon > /dev/null 2>&1 || MISSING_PACKAGES+=("dbus")
|
||||
|
||||
|
||||
if [ ! -z "${MISSING_PACKAGES}" ]; then
|
||||
warn "The following is missing on the host and needs "
|
||||
warn "to be installed and configured before running this script again"
|
||||
error "missing: ${MISSING_PACKAGES[@]}"
|
||||
fi
|
||||
|
||||
# Check if Modem Manager is enabled
|
||||
if systemctl is-enabled ModemManager.service &> /dev/null; then
|
||||
warn "ModemManager service is enabled. This might cause issue when using serial devices."
|
||||
fi
|
||||
|
||||
# Detect wrong docker logger config
|
||||
if [ ! -f "$FILE_DOCKER_CONF" ]; then
|
||||
# Write default configuration
|
||||
info "Creating default docker daemon configuration $FILE_DOCKER_CONF"
|
||||
curl -sL ${URL_DOCKER_DAEMON} > "${FILE_DOCKER_CONF}"
|
||||
|
||||
# Restart Docker service
|
||||
info "Restarting docker service"
|
||||
systemctl restart "$SERVICE_DOCKER"
|
||||
else
|
||||
STORAGE_DRIVER=$(docker info -f "{{json .}}" | jq -r -e .Driver)
|
||||
LOGGING_DRIVER=$(docker info -f "{{json .}}" | jq -r -e .LoggingDriver)
|
||||
if [[ "$STORAGE_DRIVER" != "overlay2" ]]; then
|
||||
warn "Docker is using $STORAGE_DRIVER and not 'overlay2' as the storage 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
|
||||
|
||||
# Check dmesg access
|
||||
if [[ "$(sysctl --values kernel.dmesg_restrict)" != "0" ]]; then
|
||||
info "Fix kernel dmesg restriction"
|
||||
echo 0 > /proc/sys/kernel/dmesg_restrict
|
||||
echo "kernel.dmesg_restrict=0" >> /etc/sysctl.conf
|
||||
fi
|
||||
|
||||
# Create config for NetworkManager
|
||||
info "Creating NetworkManager configuration"
|
||||
curl -sL "${URL_NM_CONF}" > "${FILE_NM_CONF}"
|
||||
if [ ! -f "$FILE_NM_CONNECTION" ]; then
|
||||
curl -sL "${URL_NM_CONNECTION}" > "${FILE_NM_CONNECTION}"
|
||||
fi
|
||||
|
||||
warn "Changes are needed to the /etc/network/interfaces file"
|
||||
info "If you have modified the network on the host manualy, those can now be overwritten"
|
||||
info "If you do not overwrite this now you need to manually adjust it later"
|
||||
info "Do you want to proceed with overwriting the /etc/network/interfaces file? [N/y] "
|
||||
read answer < /dev/tty
|
||||
|
||||
if [[ "$answer" =~ "y" ]] || [[ "$answer" =~ "Y" ]]; then
|
||||
info "Replacing /etc/network/interfaces"
|
||||
curl -sL "${URL_INTERFACES}" > "${FILE_INTERFACES}";
|
||||
fi
|
||||
|
||||
info "Restarting NetworkManager"
|
||||
systemctl restart "${SERVICE_NM}"
|
||||
|
||||
# Parse command line parameters
|
||||
while [[ $# -gt 0 ]]; do
|
||||
arg="$1"
|
||||
|
||||
case $arg in
|
||||
-m|--machine)
|
||||
MACHINE=$2
|
||||
shift
|
||||
;;
|
||||
-d|--data-share)
|
||||
DATA_SHARE=$2
|
||||
shift
|
||||
;;
|
||||
-p|--prefix)
|
||||
PREFIX=$2
|
||||
shift
|
||||
;;
|
||||
-s|--sysconfdir)
|
||||
SYSCONFDIR=$2
|
||||
shift
|
||||
;;
|
||||
*)
|
||||
error "Unrecognized option $1"
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
PREFIX=${PREFIX:-/usr}
|
||||
SYSCONFDIR=${SYSCONFDIR:-/etc}
|
||||
DATA_SHARE=${DATA_SHARE:-$PREFIX/share/hassio}
|
||||
CONFIG=$SYSCONFDIR/hassio.json
|
||||
|
||||
# Generate hardware options
|
||||
case $ARCH in
|
||||
"i386" | "i686")
|
||||
MACHINE=${MACHINE:=qemux86}
|
||||
HASSIO_DOCKER="$DOCKER_REPO/i386-hassio-supervisor"
|
||||
;;
|
||||
"x86_64")
|
||||
MACHINE=${MACHINE:=qemux86-64}
|
||||
HASSIO_DOCKER="$DOCKER_REPO/amd64-hassio-supervisor"
|
||||
;;
|
||||
"arm" |"armv6l")
|
||||
if [ -z $MACHINE ]; then
|
||||
error "Please set machine for $ARCH"
|
||||
fi
|
||||
HASSIO_DOCKER="$DOCKER_REPO/armhf-hassio-supervisor"
|
||||
;;
|
||||
"armv7l")
|
||||
if [ -z $MACHINE ]; then
|
||||
error "Please set machine for $ARCH"
|
||||
fi
|
||||
HASSIO_DOCKER="$DOCKER_REPO/armv7-hassio-supervisor"
|
||||
;;
|
||||
"aarch64")
|
||||
if [ -z $MACHINE ]; then
|
||||
error "Please set machine for $ARCH"
|
||||
fi
|
||||
HASSIO_DOCKER="$DOCKER_REPO/aarch64-hassio-supervisor"
|
||||
;;
|
||||
*)
|
||||
error "$ARCH unknown!"
|
||||
;;
|
||||
esac
|
||||
|
||||
if [[ ! "${MACHINE}" =~ ^(generic-x86-64|odroid-c2|odroid-n2|odroid-xu|qemuarm|qemuarm-64|qemux86|qemux86-64|raspberrypi|raspberrypi2|raspberrypi3|raspberrypi4|raspberrypi3-64|raspberrypi4-64|tinker|khadas-vim3)$ ]]; then
|
||||
error "Unknown machine type ${MACHINE}!"
|
||||
fi
|
||||
|
||||
### Main
|
||||
|
||||
# Init folders
|
||||
if [ ! -d "$DATA_SHARE" ]; then
|
||||
mkdir -p "$DATA_SHARE"
|
||||
fi
|
||||
|
||||
if [ ! -d "${PREFIX}/sbin" ]; then
|
||||
mkdir -p "${PREFIX}/sbin"
|
||||
fi
|
||||
|
||||
if [ ! -d "${PREFIX}/bin" ]; then
|
||||
mkdir -p "${PREFIX}/bin"
|
||||
fi
|
||||
# Read infos from web
|
||||
while ! ping -c 1 -W 1 ${URL_VERSION_HOST}; do
|
||||
info "Waiting for ${URL_VERSION_HOST} - network interface might be down..."
|
||||
sleep 2
|
||||
done
|
||||
HASSIO_VERSION=$(curl -s $URL_VERSION | jq -e -r '.supervisor')
|
||||
|
||||
##
|
||||
# Write configuration
|
||||
cat > "$CONFIG" <<- EOF
|
||||
{
|
||||
"supervisor": "${HASSIO_DOCKER}",
|
||||
"machine": "${MACHINE}",
|
||||
"data": "${DATA_SHARE}"
|
||||
}
|
||||
EOF
|
||||
|
||||
##
|
||||
# Pull supervisor image
|
||||
info "Install supervisor Docker container"
|
||||
docker pull "$HASSIO_DOCKER:$HASSIO_VERSION" > /dev/null
|
||||
docker tag "$HASSIO_DOCKER:$HASSIO_VERSION" "$HASSIO_DOCKER:latest" > /dev/null
|
||||
|
||||
##
|
||||
# Install Hass.io Supervisor
|
||||
info "Install supervisor startup scripts"
|
||||
curl -sL ${URL_BIN_HASSIO} > "${PREFIX}/sbin/hassio-supervisor"
|
||||
curl -sL ${URL_SERVICE_HASSIO} > "${SYSCONFDIR}/systemd/system/hassio-supervisor.service"
|
||||
|
||||
sed -i "s,%%HASSIO_CONFIG%%,${CONFIG},g" "${PREFIX}"/sbin/hassio-supervisor
|
||||
sed -i -e "s,%%BINARY_DOCKER%%,${BINARY_DOCKER},g" \
|
||||
-e "s,%%SERVICE_DOCKER%%,${SERVICE_DOCKER},g" \
|
||||
-e "s,%%BINARY_HASSIO%%,${PREFIX}/sbin/hassio-supervisor,g" \
|
||||
"${SYSCONFDIR}/systemd/system/hassio-supervisor.service"
|
||||
|
||||
chmod a+x "${PREFIX}/sbin/hassio-supervisor"
|
||||
systemctl enable hassio-supervisor.service > /dev/null 2>&1;
|
||||
|
||||
#
|
||||
# Install Hass.io AppArmor
|
||||
info "Install AppArmor scripts"
|
||||
mkdir -p "${DATA_SHARE}/apparmor"
|
||||
curl -sL ${URL_BIN_APPARMOR} > "${PREFIX}/sbin/hassio-apparmor"
|
||||
curl -sL ${URL_SERVICE_APPARMOR} > "${SYSCONFDIR}/systemd/system/hassio-apparmor.service"
|
||||
curl -sL ${URL_APPARMOR_PROFILE} > "${DATA_SHARE}/apparmor/hassio-supervisor"
|
||||
|
||||
sed -i "s,%%HASSIO_CONFIG%%,${CONFIG},g" "${PREFIX}/sbin/hassio-apparmor"
|
||||
sed -i -e "s,%%SERVICE_DOCKER%%,${SERVICE_DOCKER},g" \
|
||||
-e "s,%%HASSIO_APPARMOR_BINARY%%,${PREFIX}/sbin/hassio-apparmor,g" \
|
||||
"${SYSCONFDIR}/systemd/system/hassio-apparmor.service"
|
||||
|
||||
chmod a+x "${PREFIX}/sbin/hassio-apparmor"
|
||||
systemctl enable hassio-apparmor.service > /dev/null 2>&1;
|
||||
systemctl start hassio-apparmor.service
|
||||
|
||||
|
||||
##
|
||||
# Init system
|
||||
info "Start Home Assistant Supervised"
|
||||
systemctl start hassio-supervisor.service
|
||||
|
||||
##
|
||||
# Setup CLI
|
||||
info "Installing the 'ha' cli"
|
||||
curl -sL ${URL_HA} > "${PREFIX}/bin/ha"
|
||||
chmod a+x "${PREFIX}/bin/ha"
|
||||
|
||||
info
|
||||
info "Home Assistant supervised is now installed"
|
||||
info "First setup will take some time, when it's ready you can reach it here:"
|
||||
info "http://${IP_ADDRESS}:8123"
|
||||
info
|
Loading…
Reference in a new issue