add regex for header value

This commit is contained in:
Christian Groschupp 2023-06-14 10:18:20 +02:00
parent 3673b3668b
commit 6836b7103d

View file

@ -37,7 +37,7 @@ type Config struct {
var (
headerRegexp = regexp.MustCompile(`^[a-zA-Z\d\-_]+$`)
valueRegexp = regexp.MustCompile(`^[a-zA-Z\d\_ :;.,\/"'?!(){}[]@<>=-\+\*#$&<|~^%]+$`)
valueRegexp = regexp.MustCompile(`^[a-zA-Z\d_ :;.,\\/"'?!(){}\[\]@<>=\-+*#$&\x60|~^%]+$`)
)
// ValidHeader checks is the provided string satisfies the header's name regex
@ -78,10 +78,10 @@ func (a customHeaders) Parse(ing *networking.Ingress) (interface{}, error) {
for header, value := range clientHeadersMapContents.Data {
if !ValidHeader(header) {
return nil, ing_errors.NewLocationDenied("invalid client-headers in configmap")
return nil, ing_errors.NewLocationDenied("invalid header name in configmap")
}
if !ValidValue(value) {
return nil, ing_errors.NewLocationDenied("invalid client-headers in configmap")
return nil, ing_errors.NewLocationDenied("invalid header value in configmap")
}
if !slices.Contains(defBackend.AllowedResponseHeaders, header) {
return nil, ing_errors.NewLocationDenied(fmt.Sprintf("header %s is not allowed, defined allowed headers inside global-allowed-response-headers %v", header, defBackend.AllowedResponseHeaders))