Browse Source
Resolve "MFA Captive Portal" Closes #204 See merge request cyber5k/mistborn!91merge-requests/92/merge
7 changed files with 135 additions and 7 deletions
@ -0,0 +1,8 @@
@@ -0,0 +1,8 @@
|
||||
FROM nginx:1.21.1-alpine |
||||
|
||||
ADD run.sh /run.sh |
||||
ADD default.conf /etc/nginx/conf.d/default.conf |
||||
|
||||
RUN chmod +x /run.sh |
||||
|
||||
CMD ["/run.sh"] |
||||
@ -0,0 +1,29 @@
@@ -0,0 +1,29 @@
|
||||
map $http_x_forwarded_proto $redirect_scheme { |
||||
default $scheme; |
||||
https https; |
||||
} |
||||
|
||||
server { |
||||
listen 80; |
||||
listen [::]:80; |
||||
server_name ${SERVER_NAME}; |
||||
|
||||
# cherry picked from https://github.com/schmunk42/docker-nginx-redirect/pull/8 |
||||
if ($request_method = POST) { |
||||
return ${SERVER_REDIRECT_POST_CODE} ${SERVER_REDIRECT_SCHEME}://${SERVER_REDIRECT}${SERVER_REDIRECT_PATH}; |
||||
} |
||||
|
||||
if ($request_method ~ PUT|PATCH|DELETE) { |
||||
return ${SERVER_REDIRECT_PUT_PATCH_DELETE_CODE} ${SERVER_REDIRECT_SCHEME}://${SERVER_REDIRECT}${SERVER_REDIRECT_PATH}; |
||||
} |
||||
|
||||
return ${SERVER_REDIRECT_CODE} ${SERVER_REDIRECT_SCHEME}://${SERVER_REDIRECT}${SERVER_REDIRECT_PATH}; |
||||
|
||||
# redirect server error pages to the static page /50x.html |
||||
# |
||||
error_page 500 502 503 504 /50x.html; |
||||
location = /50x.html { |
||||
root /usr/share/nginx/html; |
||||
} |
||||
|
||||
} |
||||
@ -0,0 +1,54 @@
@@ -0,0 +1,54 @@
|
||||
#!/usr/bin/env sh |
||||
|
||||
if [ ! -n "$SERVER_REDIRECT" ] ; then |
||||
echo "Environment variable SERVER_REDIRECT is not set, exiting." |
||||
exit 1 |
||||
fi |
||||
|
||||
# set server name from optional ENV var |
||||
if [ ! -n "$SERVER_NAME" ] ; then |
||||
SERVER_NAME='localhost' |
||||
fi |
||||
|
||||
# set redirect code from optional ENV var |
||||
# allowed Status Codes are: 301, 302, 303, 307, 308 |
||||
expr match "$SERVER_REDIRECT_CODE" '30[12378]$' > /dev/null || SERVER_REDIRECT_CODE='301' |
||||
|
||||
# set redirect code from optional ENV var for POST requests |
||||
expr match "$SERVER_REDIRECT_POST_CODE" '30[12378]$' > /dev/null || SERVER_REDIRECT_POST_CODE=$SERVER_REDIRECT_CODE |
||||
|
||||
# set redirect code from optional ENV var for PUT, PATCH and DELETE requests |
||||
expr match "$SERVER_REDIRECT_PUT_PATCH_DELETE_CODE" '30[12378]$' > /dev/null || SERVER_REDIRECT_PUT_PATCH_DELETE_CODE=$SERVER_REDIRECT_CODE |
||||
|
||||
# set redirect path from optional ENV var |
||||
if [ ! -n "$SERVER_REDIRECT_PATH" ] ; then |
||||
SERVER_REDIRECT_PATH='$request_uri' |
||||
fi |
||||
|
||||
# set redirect scheme from optional ENV var |
||||
if [ ! -n "$SERVER_REDIRECT_SCHEME" ] ; then |
||||
SERVER_REDIRECT_SCHEME='$redirect_scheme' |
||||
fi |
||||
|
||||
# set access log location from optional ENV var |
||||
if [ ! -n "$SERVER_ACCESS_LOG" ] ; then |
||||
SERVER_ACCESS_LOG='/dev/stdout' |
||||
fi |
||||
|
||||
# set error log location from optional ENV var |
||||
if [ ! -n "$SERVER_ERROR_LOG" ] ; then |
||||
SERVER_ERROR_LOG='/dev/stderr' |
||||
fi |
||||
|
||||
sed -i "s|\${SERVER_REDIRECT}|${SERVER_REDIRECT}|" /etc/nginx/conf.d/default.conf |
||||
sed -i "s|\${SERVER_NAME}|${SERVER_NAME}|" /etc/nginx/conf.d/default.conf |
||||
sed -i "s|\${SERVER_REDIRECT_CODE}|${SERVER_REDIRECT_CODE}|" /etc/nginx/conf.d/default.conf |
||||
sed -i "s|\${SERVER_REDIRECT_POST_CODE}|${SERVER_REDIRECT_POST_CODE}|" /etc/nginx/conf.d/default.conf |
||||
sed -i "s|\${SERVER_REDIRECT_PUT_PATCH_DELETE_CODE}|${SERVER_REDIRECT_PUT_PATCH_DELETE_CODE}|" /etc/nginx/conf.d/default.conf |
||||
sed -i "s|\${SERVER_REDIRECT_PATH}|${SERVER_REDIRECT_PATH}|" /etc/nginx/conf.d/default.conf |
||||
sed -i "s|\${SERVER_REDIRECT_SCHEME}|${SERVER_REDIRECT_SCHEME}|" /etc/nginx/conf.d/default.conf |
||||
|
||||
ln -sfT "$SERVER_ACCESS_LOG" /var/log/nginx/access.log |
||||
ln -sfT "$SERVER_ERROR_LOG" /var/log/nginx/error.log |
||||
|
||||
exec nginx -g 'daemon off;' |
||||
Loading…
Reference in new issue