Added Ingress autologin

Cleanup of previous tests remains
This commit is contained in:
Marco Lusini
2022-06-09 18:51:03 +02:00
parent 1b9f053e82
commit 4ffc0d5689
6 changed files with 52 additions and 39 deletions

View File

@@ -62,6 +62,10 @@ RUN if ! command -v bash >/dev/null 2>/dev/null; then (apt-get update && apt-get
&& eval /./automatic_packages.sh "${PACKAGES:-}" \ && eval /./automatic_packages.sh "${PACKAGES:-}" \
&& rm /automatic_packages.sh || printf '%s\n' "${PACKAGES:-}" > /ENVFILE && rm /automatic_packages.sh || printf '%s\n' "${PACKAGES:-}" > /ENVFILE
# Install sqlite3 & set defaults
RUN if ! command -v sqlite3 >/dev/null 2>/dev/null; then (apt-get update && apt-get install -yqq --no-install-recommends sqlite3 || apk add --no-cache sqlite3) >/dev/null; fi \
&& sqlite3 /defaults/app.db 'update settings set config_reverse_proxy_login_header_name="X-WebAuth-User",config_allow_reverse_proxy_header_login=1'
################ ################
# 4 Entrypoint # # 4 Entrypoint #
################ ################

View File

@@ -62,10 +62,10 @@
}, },
"panel_icon": "mdi:library", "panel_icon": "mdi:library",
"ports": { "ports": {
"8083/tcp": 8083 "8083/tcp": null
}, },
"ports_description": { "ports_description": {
"8083/tcp": "calibre-web webui" "8083/tcp": "Calibre-web webui (Not required for Ingress)"
}, },
"privileged": [ "privileged": [
"SYS_ADMIN", "SYS_ADMIN",
@@ -81,10 +81,11 @@
"cifspassword": "str?", "cifspassword": "str?",
"cifsusername": "str?", "cifsusername": "str?",
"localdisks": "str?", "localdisks": "str?",
"networkdisks": "str?" "networkdisks": "str?",
"ingress_user": "str?"
}, },
"slug": "calibre-web", "slug": "calibre-web",
"url": "https://github.com/alexbelgium/hassio-addons/tree/master/calibre-web", "url": "https://github.com/alexbelgium/hassio-addons/tree/master/calibre-web",
"version": "0.6.18-ls164", "version": "0.6.18-ls164-test5",
"video": true "video": true
} }

View File

@@ -4,45 +4,52 @@
################# #################
# NGINX SETTING # # NGINX SETTING #
################# #################
declare port #declare port
declare certfile #declare certfile
declare ingress_user
declare ingress_interface declare ingress_interface
declare ingress_port declare ingress_port
declare keyfile #declare keyfile
port=$(bashio::addon.port 80) #port=$(bashio::addon.port 80)
if bashio::var.has_value "${port}"; then #if bashio::var.has_value "${port}"; then
bashio::config.require.ssl # bashio::config.require.ssl
#
# if bashio::config.true 'ssl'; then
# certfile=$(bashio::config 'certfile')
# keyfile=$(bashio::config 'keyfile')
#
# mv /etc/nginx/servers/direct-ssl.disabled /etc/nginx/servers/direct.conf
# sed -i "s/%%certfile%%/${certfile}/g" /etc/nginx/servers/direct.conf
# sed -i "s/%%keyfile%%/${keyfile}/g" /etc/nginx/servers/direct.conf
#
# else
# mv /etc/nginx/servers/direct.disabled /etc/nginx/servers/direct.conf
# fi
#fi
if bashio::config.true 'ssl'; then ## Force scheme
certfile=$(bashio::config 'certfile') #if bashio::config.true 'force_scheme_https'; then
keyfile=$(bashio::config 'keyfile') # # shellcheck disable=SC2016
# sed -i 's|$scheme|https|g' /etc/nginx/servers/ingress.conf
#fi
mv /etc/nginx/servers/direct-ssl.disabled /etc/nginx/servers/direct.conf ## Force external port
sed -i "s/%%certfile%%/${certfile}/g" /etc/nginx/servers/direct.conf #if bashio::config.has_value 'force_external_port'; then
sed -i "s/%%keyfile%%/${keyfile}/g" /etc/nginx/servers/direct.conf # sed -i "s|%%haport%%|$(bashio::config 'force_external_port')|g" /etc/nginx/servers/ingress.conf
#fi
else ingress_user='admin'
mv /etc/nginx/servers/direct.disabled /etc/nginx/servers/direct.conf if bashio::config.has_value 'ingress_user'; then
fi ingress_user=$(bashio::config 'ingress_user')
fi
# Force scheme
if bashio::config.true 'force_scheme_https'; then
# shellcheck disable=SC2016
sed -i 's|$scheme|https|g' /etc/nginx/servers/ingress.conf
fi
# Force external port
if bashio::config.has_value 'force_external_port'; then
sed -i "s|%%haport%%|$(bashio::config 'force_external_port')|g" /etc/nginx/servers/ingress.conf
fi fi
ingress_port=$(bashio::addon.ingress_port) ingress_port=$(bashio::addon.ingress_port)
ingress_interface=$(bashio::addon.ip_address) ingress_interface=$(bashio::addon.ip_address)
ha_port=$(bashio::core.port) #ha_port=$(bashio::core.port)
sed -i "s/%%ingress_user%%/${ingress_user}/g" /etc/nginx/servers/ingress.conf
sed -i "s/%%port%%/${ingress_port}/g" /etc/nginx/servers/ingress.conf sed -i "s/%%port%%/${ingress_port}/g" /etc/nginx/servers/ingress.conf
sed -i "s/%%haport%%/${ha_port}/g" /etc/nginx/servers/ingress.conf #sed -i "s/%%haport%%/${ha_port}/g" /etc/nginx/servers/ingress.conf
sed -i "s/%%interface%%/${ingress_interface}/g" /etc/nginx/servers/ingress.conf sed -i "s/%%interface%%/${ingress_interface}/g" /etc/nginx/servers/ingress.conf
sed -i "s|%%UIPATH%%|$(bashio::addon.ingress_entry)|g" /etc/nginx/servers/ingress.conf sed -i "s|%%UIPATH%%|$(bashio::addon.ingress_entry)|g" /etc/nginx/servers/ingress.conf

View File

@@ -9,9 +9,7 @@ if bashio::config.has_value 'TZ'; then
ln -snf /usr/share/zoneinfo/"$TIMEZONE" /etc/localtime && echo "$TIMEZONE" >/etc/timezone ln -snf /usr/share/zoneinfo/"$TIMEZONE" /etc/localtime && echo "$TIMEZONE" >/etc/timezone
fi fi
# Disable session protection # Set Ingress login
# https://forums.unraid.net/topic/71927-support-linuxserverio-calibre-web/page/5/#comment-1015352 sqlite3 /config/addons_config/calibre-web/app.db 'update settings set config_reverse_proxy_login_header_name="X-WebAuth-User",config_allow_reverse_proxy_header_login=1'
#echo "**** patching calibre-web - removing session protection ****"
#sed -i "/lm.session_protection = 'strong'/d" /app/calibre-web/cps/__init__.py || true
bashio::log.info "Default username:password is admin:admin123" bashio::log.info "Default username:password is admin:admin123"

View File

@@ -1,3 +1,3 @@
upstream backend { upstream backend {
server 127.0.0.1:8080; server 127.0.0.1:8083;
} }

View File

@@ -5,7 +5,10 @@ server {
client_max_body_size 0; client_max_body_size 0;
location / { location / {
allow 172.30.32.2;
deny all;
proxy_set_header X-WebAuth-User %%ingress_user%%;
# Base from https://github.com/janeczku/calibre-web/wiki/Setup-Reverse-Proxy#nginx # Base from https://github.com/janeczku/calibre-web/wiki/Setup-Reverse-Proxy#nginx
proxy_bind $server_addr; proxy_bind $server_addr;
proxy_pass http://127.0.0.1:8083; proxy_pass http://127.0.0.1:8083;
@@ -14,7 +17,7 @@ server {
proxy_set_header Host $http_host; proxy_set_header Host $http_host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Script-Name %%UIPATH%%; # IMPORTANT: path has NO trailing slash proxy_set_header X-Script-Name %%UIPATH%%; # IMPORTANT: path has NO trailing slash
# Optimisation # Optimisation
proxy_buffering off; proxy_buffering off;
proxy_read_timeout 30; proxy_read_timeout 30;