mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-14 06:46:27 +03:00
forwardauth: Support renaming copied headers, block support (#4783)
This commit is contained in:
parent
050d6e0aeb
commit
0b6f764356
2 changed files with 142 additions and 7 deletions
|
@ -0,0 +1,116 @@
|
||||||
|
:8881
|
||||||
|
|
||||||
|
forward_auth localhost:9000 {
|
||||||
|
uri /auth
|
||||||
|
copy_headers A>1 B C>3 {
|
||||||
|
D
|
||||||
|
E>5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
----------
|
||||||
|
{
|
||||||
|
"apps": {
|
||||||
|
"http": {
|
||||||
|
"servers": {
|
||||||
|
"srv0": {
|
||||||
|
"listen": [
|
||||||
|
":8881"
|
||||||
|
],
|
||||||
|
"routes": [
|
||||||
|
{
|
||||||
|
"handle": [
|
||||||
|
{
|
||||||
|
"handle_response": [
|
||||||
|
{
|
||||||
|
"match": {
|
||||||
|
"status_code": [
|
||||||
|
2
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"routes": [
|
||||||
|
{
|
||||||
|
"handle": [
|
||||||
|
{
|
||||||
|
"handler": "headers",
|
||||||
|
"request": {
|
||||||
|
"set": {
|
||||||
|
"1": [
|
||||||
|
"{http.reverse_proxy.header.A}"
|
||||||
|
],
|
||||||
|
"3": [
|
||||||
|
"{http.reverse_proxy.header.C}"
|
||||||
|
],
|
||||||
|
"5": [
|
||||||
|
"{http.reverse_proxy.header.E}"
|
||||||
|
],
|
||||||
|
"B": [
|
||||||
|
"{http.reverse_proxy.header.B}"
|
||||||
|
],
|
||||||
|
"D": [
|
||||||
|
"{http.reverse_proxy.header.D}"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"routes": [
|
||||||
|
{
|
||||||
|
"handle": [
|
||||||
|
{
|
||||||
|
"exclude": [
|
||||||
|
"Connection",
|
||||||
|
"Keep-Alive",
|
||||||
|
"Te",
|
||||||
|
"Trailers",
|
||||||
|
"Transfer-Encoding",
|
||||||
|
"Upgrade"
|
||||||
|
],
|
||||||
|
"handler": "copy_response_headers"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"handle": [
|
||||||
|
{
|
||||||
|
"handler": "copy_response"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"handler": "reverse_proxy",
|
||||||
|
"headers": {
|
||||||
|
"request": {
|
||||||
|
"set": {
|
||||||
|
"X-Forwarded-Method": [
|
||||||
|
"{http.request.method}"
|
||||||
|
],
|
||||||
|
"X-Forwarded-Uri": [
|
||||||
|
"{http.request.uri}"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"rewrite": {
|
||||||
|
"method": "GET",
|
||||||
|
"uri": "/auth"
|
||||||
|
},
|
||||||
|
"upstreams": [
|
||||||
|
{
|
||||||
|
"dial": "localhost:9000"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -17,6 +17,7 @@ package forwardauth
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"github.com/caddyserver/caddy/v2"
|
"github.com/caddyserver/caddy/v2"
|
||||||
"github.com/caddyserver/caddy/v2/caddyconfig"
|
"github.com/caddyserver/caddy/v2/caddyconfig"
|
||||||
|
@ -115,7 +116,7 @@ func parseCaddyfile(h httpcaddyfile.Helper) ([]httpcaddyfile.ConfigValue, error)
|
||||||
// collect the headers to copy from the auth response
|
// collect the headers to copy from the auth response
|
||||||
// onto the original request, so they can get passed
|
// onto the original request, so they can get passed
|
||||||
// through to a backend app
|
// through to a backend app
|
||||||
headersToCopy := []string{}
|
headersToCopy := make(map[string]string)
|
||||||
|
|
||||||
// read the subdirectives for configuring the forward_auth shortcut
|
// read the subdirectives for configuring the forward_auth shortcut
|
||||||
// NOTE: we delete the tokens as we go so that the reverse_proxy
|
// NOTE: we delete the tokens as we go so that the reverse_proxy
|
||||||
|
@ -141,10 +142,28 @@ func parseCaddyfile(h httpcaddyfile.Helper) ([]httpcaddyfile.ConfigValue, error)
|
||||||
|
|
||||||
case "copy_headers":
|
case "copy_headers":
|
||||||
args := dispenser.RemainingArgs()
|
args := dispenser.RemainingArgs()
|
||||||
dispenser.Delete()
|
hadBlock := false
|
||||||
for _, headerField := range args {
|
for nesting := dispenser.Nesting(); dispenser.NextBlock(nesting); {
|
||||||
|
hadBlock = true
|
||||||
|
args = append(args, dispenser.Val())
|
||||||
|
}
|
||||||
|
|
||||||
|
dispenser.Delete() // directive name
|
||||||
|
if hadBlock {
|
||||||
|
dispenser.Delete() // opening brace
|
||||||
|
dispenser.Delete() // closing brace
|
||||||
|
}
|
||||||
|
for range args {
|
||||||
dispenser.Delete()
|
dispenser.Delete()
|
||||||
headersToCopy = append(headersToCopy, headerField)
|
}
|
||||||
|
|
||||||
|
for _, headerField := range args {
|
||||||
|
if strings.Contains(headerField, ">") {
|
||||||
|
parts := strings.Split(headerField, ">")
|
||||||
|
headersToCopy[parts[0]] = parts[1]
|
||||||
|
} else {
|
||||||
|
headersToCopy[headerField] = headerField
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if len(headersToCopy) == 0 {
|
if len(headersToCopy) == 0 {
|
||||||
return nil, dispenser.ArgErr()
|
return nil, dispenser.ArgErr()
|
||||||
|
@ -180,9 +199,9 @@ func parseCaddyfile(h httpcaddyfile.Helper) ([]httpcaddyfile.ConfigValue, error)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, headerField := range headersToCopy {
|
for from, to := range headersToCopy {
|
||||||
handler.Request.Set[headerField] = []string{
|
handler.Request.Set[to] = []string{
|
||||||
"{http.reverse_proxy.header." + headerField + "}",
|
"{http.reverse_proxy.header." + from + "}",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue