mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-06-01 05:14:04 +02:00
GitHub bot: fix linting issues (nobuild)
This commit is contained in:
@@ -16,39 +16,40 @@ set -euo pipefail
|
|||||||
|
|
||||||
# Run outside HA? then do nothing
|
# Run outside HA? then do nothing
|
||||||
if [[ ! -d /config ]] || ! bashio::supervisor.ping &>/dev/null; then
|
if [[ ! -d /config ]] || ! bashio::supervisor.ping &>/dev/null; then
|
||||||
echo "..."
|
echo "..."
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
slug="${HOSTNAME/-/_}" ; slug="${slug#*_}"
|
slug="${HOSTNAME/-/_}"
|
||||||
|
slug="${slug#*_}"
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------
|
||||||
# Resolve CONFIGSOURCE #
|
# Resolve CONFIGSOURCE #
|
||||||
# -----------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------
|
||||||
if [[ ! -f /config/configuration.yaml && ! -f /config/configuration.json ]]; then
|
if [[ ! -f /config/configuration.yaml && ! -f /config/configuration.json ]]; then
|
||||||
CONFIGLOCATION="/config" # New architecture
|
CONFIGLOCATION="/config" # New architecture
|
||||||
CONFIGFILEBROWSER="/addon_configs/${HOSTNAME/-/_}/config.yaml"
|
CONFIGFILEBROWSER="/addon_configs/${HOSTNAME/-/_}/config.yaml"
|
||||||
else
|
else
|
||||||
CONFIGLOCATION="/config/addons_config/${slug}" # Legacy architecture
|
CONFIGLOCATION="/config/addons_config/${slug}" # Legacy architecture
|
||||||
CONFIGFILEBROWSER="/homeassistant/addons_config/${slug}/config.yaml"
|
CONFIGFILEBROWSER="/homeassistant/addons_config/${slug}/config.yaml"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir -p "$CONFIGLOCATION"
|
mkdir -p "$CONFIGLOCATION"
|
||||||
CONFIGSOURCE="$CONFIGLOCATION/config.yaml"
|
CONFIGSOURCE="$CONFIGLOCATION/config.yaml"
|
||||||
|
|
||||||
if bashio::config.has_value 'CONFIG_LOCATION'; then
|
if bashio::config.has_value 'CONFIG_LOCATION'; then
|
||||||
CONFIGSOURCE="$(bashio::config "CONFIG_LOCATION")"
|
CONFIGSOURCE="$(bashio::config "CONFIG_LOCATION")"
|
||||||
[[ "$CONFIGSOURCE" == *.* ]] && CONFIGSOURCE="$(dirname "$CONFIGSOURCE")"
|
[[ "$CONFIGSOURCE" == *.* ]] && CONFIGSOURCE="$(dirname "$CONFIGSOURCE")"
|
||||||
[[ "$CONFIGSOURCE" != *.yaml ]] && CONFIGSOURCE="${CONFIGSOURCE%/}/config.yaml"
|
[[ "$CONFIGSOURCE" != *.yaml ]] && CONFIGSOURCE="${CONFIGSOURCE%/}/config.yaml"
|
||||||
case "$CONFIGSOURCE" in
|
case "$CONFIGSOURCE" in
|
||||||
/share/*|/config/*|/data/*) :;;
|
/share/* | /config/* | /data/*) : ;;
|
||||||
*) bashio::log.red "CONFIG_LOCATION must be in /share, /config or /data – defaulting." && CONFIGSOURCE="$CONFIGLOCATION/config.yaml";;
|
*) bashio::log.red "CONFIG_LOCATION must be in /share, /config or /data – defaulting." && CONFIGSOURCE="$CONFIGLOCATION/config.yaml" ;;
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ "$CONFIGLOCATION" == "/config" && -f "/homeassistant/addons_config/${slug}/config.yaml" && ! -L "/homeassistant/addons_config/${slug}" ]]; then
|
if [[ "$CONFIGLOCATION" == "/config" && -f "/homeassistant/addons_config/${slug}/config.yaml" && ! -L "/homeassistant/addons_config/${slug}" ]]; then
|
||||||
echo "Migrating config.yaml to $CONFIGLOCATION"
|
echo "Migrating config.yaml to $CONFIGLOCATION"
|
||||||
mv "/homeassistant/addons_config/${slug}/config.yaml" "$CONFIGSOURCE"
|
mv "/homeassistant/addons_config/${slug}/config.yaml" "$CONFIGSOURCE"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
chmod -R 755 "$(dirname "$CONFIGSOURCE")"
|
chmod -R 755 "$(dirname "$CONFIGSOURCE")"
|
||||||
@@ -58,19 +59,19 @@ chmod -R 755 "$(dirname "$CONFIGSOURCE")"
|
|||||||
####################
|
####################
|
||||||
|
|
||||||
if [[ ! -f "$CONFIGSOURCE" ]]; then
|
if [[ ! -f "$CONFIGSOURCE" ]]; then
|
||||||
echo "... no config file, creating one from template."
|
echo "... no config file, creating one from template."
|
||||||
mkdir -p "$(dirname "$CONFIGSOURCE")"
|
mkdir -p "$(dirname "$CONFIGSOURCE")"
|
||||||
if [[ -f /templates/config.yaml ]]; then
|
if [[ -f /templates/config.yaml ]]; then
|
||||||
cp /templates/config.yaml "$CONFIGSOURCE"
|
cp /templates/config.yaml "$CONFIGSOURCE"
|
||||||
else
|
else
|
||||||
curl -fsSL "https://raw.githubusercontent.com/alexbelgium/hassio-addons/master/.templates/config.template" -o "$CONFIGSOURCE"
|
curl -fsSL "https://raw.githubusercontent.com/alexbelgium/hassio-addons/master/.templates/config.template" -o "$CONFIGSOURCE"
|
||||||
fi
|
fi
|
||||||
bashio::log.green "Edit $CONFIGSOURCE then restart the add‑on."
|
bashio::log.green "Edit $CONFIGSOURCE then restart the add‑on."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! grep -qE '^[[:space:]]*[A-Za-z0-9_]+:' "$CONFIGSOURCE"; then
|
if ! grep -qE '^[[:space:]]*[A-Za-z0-9_]+:' "$CONFIGSOURCE"; then
|
||||||
bashio::log.green "... no env variables found, exiting"
|
bashio::log.green "... no env variables found, exiting"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
############################################
|
############################################
|
||||||
@@ -78,7 +79,7 @@ fi
|
|||||||
############################################
|
############################################
|
||||||
# Prints flattened KEY=value lines for scalar leaves.
|
# Prints flattened KEY=value lines for scalar leaves.
|
||||||
read_yaml() {
|
read_yaml() {
|
||||||
python3 - "$1" <<'PY'
|
python3 - "$1" <<'PY'
|
||||||
import sys, yaml, json, pathlib
|
import sys, yaml, json, pathlib
|
||||||
from collections.abc import Mapping, Sequence
|
from collections.abc import Mapping, Sequence
|
||||||
|
|
||||||
@@ -106,7 +107,7 @@ PY
|
|||||||
############################################
|
############################################
|
||||||
# Uses printf %q – POSIX‑sh safe quoting.
|
# Uses printf %q – POSIX‑sh safe quoting.
|
||||||
shell_escape() {
|
shell_escape() {
|
||||||
printf '%q' "$1"
|
printf '%q' "$1"
|
||||||
}
|
}
|
||||||
|
|
||||||
############################################
|
############################################
|
||||||
@@ -116,7 +117,7 @@ SECRETSFILE="/config/secrets.yaml"
|
|||||||
[[ -f "$SECRETSFILE" ]] || SECRETSFILE="/homeassistant/secrets.yaml"
|
[[ -f "$SECRETSFILE" ]] || SECRETSFILE="/homeassistant/secrets.yaml"
|
||||||
|
|
||||||
get_secret() {
|
get_secret() {
|
||||||
python3 - "$SECRETSFILE" "$1" <<'PY'
|
python3 - "$SECRETSFILE" "$1" <<'PY'
|
||||||
import sys, yaml, pathlib
|
import sys, yaml, pathlib
|
||||||
sec, key = sys.argv[1:3]
|
sec, key = sys.argv[1:3]
|
||||||
try:
|
try:
|
||||||
@@ -132,22 +133,23 @@ PY
|
|||||||
# MAIN LOOP #
|
# MAIN LOOP #
|
||||||
############################################
|
############################################
|
||||||
while IFS= read -r PAIR; do
|
while IFS= read -r PAIR; do
|
||||||
KEY="${PAIR%%=*}" ; VALUE="${PAIR#*=}"
|
KEY="${PAIR%%=*}"
|
||||||
|
VALUE="${PAIR#*=}"
|
||||||
|
|
||||||
# !secret support
|
# !secret support
|
||||||
if [[ "$VALUE" =~ ^!secret[[:space:]]+(.+) ]]; then
|
if [[ "$VALUE" =~ ^!secret[[:space:]]+(.+) ]]; then
|
||||||
NAME="${BASH_REMATCH[1]}"
|
NAME="${BASH_REMATCH[1]}"
|
||||||
VALUE="$(get_secret "$NAME")"
|
VALUE="$(get_secret "$NAME")"
|
||||||
[[ -z "$VALUE" ]] && bashio::exit.nok "Secret '$NAME' not found in $SECRETSFILE"
|
[[ -z "$VALUE" ]] && bashio::exit.nok "Secret '$NAME' not found in $SECRETSFILE"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
SAFE_VALUE=$(shell_escape "$VALUE")
|
SAFE_VALUE=$(shell_escape "$VALUE")
|
||||||
|
|
||||||
# 1) Export to current shell
|
# 1) Export to current shell
|
||||||
export "$KEY=$VALUE"
|
export "$KEY=$VALUE"
|
||||||
|
|
||||||
# 2) env.py (idempotent)
|
# 2) env.py (idempotent)
|
||||||
python3 - "$KEY" "$VALUE" <<'PY'
|
python3 - "$KEY" "$VALUE" <<'PY'
|
||||||
import json, os, pathlib, sys
|
import json, os, pathlib, sys
|
||||||
k, v = sys.argv[1:3]
|
k, v = sys.argv[1:3]
|
||||||
p = pathlib.Path('/env.py')
|
p = pathlib.Path('/env.py')
|
||||||
@@ -158,27 +160,27 @@ with p.open('a') as f:
|
|||||||
os.environ[k] = v
|
os.environ[k] = v
|
||||||
PY
|
PY
|
||||||
|
|
||||||
# 3) .env & /etc/environment (double‑quoted, internal " escaped)
|
# 3) .env & /etc/environment (double‑quoted, internal " escaped)
|
||||||
env_val="${VALUE//\"/\"}"
|
env_val="${VALUE//\"/\"}"
|
||||||
printf '%s="%s"\n' "$KEY" "$env_val" >> /.env
|
printf '%s="%s"\n' "$KEY" "$env_val" >>/.env
|
||||||
printf '%s="%s"\n' "$KEY" "$env_val" >> /etc/environment
|
printf '%s="%s"\n' "$KEY" "$env_val" >>/etc/environment
|
||||||
|
|
||||||
# 4) s6 container_environment (raw value)
|
# 4) s6 container_environment (raw value)
|
||||||
if [[ -d /var/run/s6/container_environment ]]; then
|
if [[ -d /var/run/s6/container_environment ]]; then
|
||||||
printf '%s' "$VALUE" > "/var/run/s6/container_environment/$KEY"
|
printf '%s' "$VALUE" >"/var/run/s6/container_environment/$KEY"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 5) Prepend export to service scripts
|
# 5) Prepend export to service scripts
|
||||||
for script in /etc/services.d/*/*run* /etc/cont-init.d/*run*; do
|
for script in /etc/services.d/*/*run* /etc/cont-init.d/*run*; do
|
||||||
[[ -f $script ]] || continue
|
[[ -f $script ]] || continue
|
||||||
grep -q "^export $KEY=" "$script" || sed -i "1i export $KEY=$SAFE_VALUE" "$script"
|
grep -q "^export $KEY=" "$script" || sed -i "1i export $KEY=$SAFE_VALUE" "$script"
|
||||||
done
|
done
|
||||||
|
|
||||||
# 6) Persist for interactive shells
|
# 6) Persist for interactive shells
|
||||||
grep -q "^export $KEY=" ~/.bashrc || echo "export $KEY=$SAFE_VALUE" >> ~/.bashrc
|
grep -q "^export $KEY=" ~/.bashrc || echo "export $KEY=$SAFE_VALUE" >>~/.bashrc
|
||||||
|
|
||||||
# 7) Log (truncate long values)
|
# 7) Log (truncate long values)
|
||||||
bashio::log.blue "$KEY='${VALUE:0:60}'${VALUE:60:+…}"
|
bashio::log.blue "$KEY='${VALUE:0:60}'${VALUE:60:+…}"
|
||||||
done < <(read_yaml "$CONFIGSOURCE")
|
done < <(read_yaml "$CONFIGSOURCE")
|
||||||
|
|
||||||
bashio::log.green "Environment variables successfully loaded."
|
bashio::log.green "Environment variables successfully loaded."
|
||||||
|
|||||||
Reference in New Issue
Block a user