This commit is contained in:
zino
2023-12-05 21:22:05 +01:00
parent a12784be3c
commit 097d30eadd

View File

@@ -16,33 +16,53 @@ server {
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always; add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;
location = /validate { location / {
# forward the /validate request to Vouch Proxy # forward the /validate request to Vouch Proxy
proxy_pass http://vouch:9090; proxy_pass http://vouch:9090/validate;
# # be sure to pass the original host header # be sure to pass the original host header
# proxy_set_header Host $http_host; proxy_set_header Host $http_host;
# # Vouch Proxy only acts on the request headers # Vouch Proxy only acts on the request headers
# proxy_pass_request_body off; proxy_pass_request_body off;
# proxy_set_header Content-Length ""; proxy_set_header Content-Length "";
# # optionally add X-Vouch-User as returned by Vouch Proxy along with the request # optionally add X-Vouch-User as returned by Vouch Proxy along with the request
# auth_request_set $auth_resp_x_vouch_user $upstream_http_x_vouch_user; auth_request_set $auth_resp_x_vouch_user $upstream_http_x_vouch_user;
# # these return values are used by the @error401 call # these return values are used by the @error401 call
# auth_request_set $auth_resp_jwt $upstream_http_x_vouch_jwt; auth_request_set $auth_resp_jwt $upstream_http_x_vouch_jwt;
# auth_request_set $auth_resp_err $upstream_http_x_vouch_err; auth_request_set $auth_resp_err $upstream_http_x_vouch_err;
# auth_request_set $auth_resp_failcount $upstream_http_x_vouch_failcount; auth_request_set $auth_resp_failcount $upstream_http_x_vouch_failcount;
} }
# # if validate returns `401 not authorized` then forward the request to the error401block # location = /validate {
# error_page 401 = @error401; # # forward the /validate request to Vouch Proxy
# proxy_pass http://vouch:9090/validate;
# location @error401 { # # be sure to pass the original host header
# # redirect to Vouch Proxy for login # proxy_set_header Host $http_host;
# return 302 https://vouch.armos.zinomedia.de/login?url=$scheme://$http_host$request_uri&vouch-failcount=$auth_resp_failcount&X-Vouch-Token=$auth_resp_jwt&error=$auth_resp_err;
# # Vouch Proxy only acts on the request headers
# proxy_pass_request_body off;
# proxy_set_header Content-Length "";
# # optionally add X-Vouch-User as returned by Vouch Proxy along with the request
# auth_request_set $auth_resp_x_vouch_user $upstream_http_x_vouch_user;
# # these return values are used by the @error401 call
# auth_request_set $auth_resp_jwt $upstream_http_x_vouch_jwt;
# auth_request_set $auth_resp_err $upstream_http_x_vouch_err;
# auth_request_set $auth_resp_failcount $upstream_http_x_vouch_failcount;
# } # }
# if validate returns `401 not authorized` then forward the request to the error401block
error_page 401 = @error401;
location @error401 {
# redirect to Vouch Proxy for login
return 302 https://vouch.armos.zinomedia.de/login?url=$scheme://$http_host$request_uri&vouch-failcount=$auth_resp_failcount&X-Vouch-Token=$auth_resp_jwt&error=$auth_resp_err;
}
} }
server { server {