GitHub bot: fix linting issues (nobuild)

This commit is contained in:
github-actions
2025-07-05 08:25:41 +00:00
parent 82295fdb81
commit b477a329ce

View File

@@ -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 addon." bashio::log.green "Edit $CONFIGSOURCE then restart the addon."
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 POSIXsh safe quoting. # Uses printf %q POSIXsh 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 (doublequoted, internal " escaped) # 3) .env & /etc/environment (doublequoted, 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."