mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-06-02 05:44:03 +02:00
Added Ingress autologin
Cleanup of previous tests remains
This commit is contained in:
@@ -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 #
|
||||||
################
|
################
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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"
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
upstream backend {
|
upstream backend {
|
||||||
server 127.0.0.1:8080;
|
server 127.0.0.1:8083;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
Reference in New Issue
Block a user