ingress-nginx-helm/internal/ingress/annotations/annotations.go

222 lines
8.7 KiB
Go
Raw Normal View History

/*
Copyright 2017 The Kubernetes Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
2017-11-07 16:36:51 +00:00
package annotations
import (
2017-11-07 16:36:51 +00:00
"github.com/imdario/mergo"
"k8s.io/ingress-nginx/internal/ingress/annotations/canary"
"k8s.io/ingress-nginx/internal/ingress/annotations/modsecurity"
"k8s.io/ingress-nginx/internal/ingress/annotations/proxyssl"
"k8s.io/ingress-nginx/internal/ingress/annotations/sslcipher"
2020-08-08 23:31:02 +00:00
"k8s.io/klog/v2"
2017-09-17 18:42:31 +00:00
2018-05-26 23:08:07 +00:00
apiv1 "k8s.io/api/core/v1"
networking "k8s.io/api/networking/v1beta1"
2017-11-07 16:36:51 +00:00
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/alias"
"k8s.io/ingress-nginx/internal/ingress/annotations/auth"
"k8s.io/ingress-nginx/internal/ingress/annotations/authreq"
"k8s.io/ingress-nginx/internal/ingress/annotations/authreqglobal"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/authtls"
2018-08-05 22:43:45 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/backendprotocol"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/clientbodybuffersize"
"k8s.io/ingress-nginx/internal/ingress/annotations/connection"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/cors"
"k8s.io/ingress-nginx/internal/ingress/annotations/customhttperrors"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/defaultbackend"
"k8s.io/ingress-nginx/internal/ingress/annotations/fastcgi"
2020-12-24 16:39:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/globalratelimit"
"k8s.io/ingress-nginx/internal/ingress/annotations/http2pushpreload"
"k8s.io/ingress-nginx/internal/ingress/annotations/influxdb"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/ipwhitelist"
"k8s.io/ingress-nginx/internal/ingress/annotations/loadbalancing"
"k8s.io/ingress-nginx/internal/ingress/annotations/log"
"k8s.io/ingress-nginx/internal/ingress/annotations/mirror"
"k8s.io/ingress-nginx/internal/ingress/annotations/opentracing"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/parser"
"k8s.io/ingress-nginx/internal/ingress/annotations/portinredirect"
"k8s.io/ingress-nginx/internal/ingress/annotations/proxy"
"k8s.io/ingress-nginx/internal/ingress/annotations/ratelimit"
"k8s.io/ingress-nginx/internal/ingress/annotations/redirect"
"k8s.io/ingress-nginx/internal/ingress/annotations/rewrite"
"k8s.io/ingress-nginx/internal/ingress/annotations/satisfy"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/secureupstream"
"k8s.io/ingress-nginx/internal/ingress/annotations/serversnippet"
"k8s.io/ingress-nginx/internal/ingress/annotations/serviceupstream"
"k8s.io/ingress-nginx/internal/ingress/annotations/sessionaffinity"
"k8s.io/ingress-nginx/internal/ingress/annotations/snippet"
"k8s.io/ingress-nginx/internal/ingress/annotations/sslpassthrough"
"k8s.io/ingress-nginx/internal/ingress/annotations/upstreamhashby"
"k8s.io/ingress-nginx/internal/ingress/annotations/upstreamvhost"
2017-12-06 20:11:18 +00:00
"k8s.io/ingress-nginx/internal/ingress/annotations/xforwardedprefix"
2017-11-07 22:02:12 +00:00
"k8s.io/ingress-nginx/internal/ingress/errors"
"k8s.io/ingress-nginx/internal/ingress/resolver"
)
2017-11-07 16:36:51 +00:00
// DeniedKeyName name of the key that contains the reason to deny a location
const DeniedKeyName = "Denied"
// Ingress defines the valid annotations present in one NGINX Ingress rule
type Ingress struct {
metav1.ObjectMeta
2018-08-05 22:43:45 +00:00
BackendProtocol string
Aliases []string
2017-11-07 16:36:51 +00:00
BasicDigestAuth auth.Config
Canary canary.Config
2017-11-07 16:36:51 +00:00
CertificateAuth authtls.Config
ClientBodyBufferSize string
ConfigurationSnippet string
Connection connection.Config
2017-11-07 16:36:51 +00:00
CorsConfig cors.Config
CustomHTTPErrors []int
2018-05-26 23:08:07 +00:00
DefaultBackend *apiv1.Service
//TODO: Change this back into an error when https://github.com/imdario/mergo/issues/100 is resolved
FastCGI fastcgi.Config
2019-02-22 16:48:13 +00:00
Denied *string
2019-02-22 15:19:40 +00:00
ExternalAuth authreq.Config
EnableGlobalAuth bool
2019-02-22 15:19:40 +00:00
HTTP2PushPreload bool
Opentracing opentracing.Config
2019-02-22 15:19:40 +00:00
Proxy proxy.Config
ProxySSL proxyssl.Config
2019-02-22 15:19:40 +00:00
RateLimit ratelimit.Config
2020-12-24 16:39:12 +00:00
GlobalRateLimit globalratelimit.Config
2019-02-22 15:19:40 +00:00
Redirect redirect.Config
Rewrite rewrite.Config
Satisfy string
SecureUpstream secureupstream.Config
ServerSnippet string
ServiceUpstream bool
SessionAffinity sessionaffinity.Config
SSLPassthrough bool
UsePortInRedirects bool
UpstreamHashBy upstreamhashby.Config
LoadBalancing string
UpstreamVhost string
Whitelist ipwhitelist.SourceRange
2019-03-11 16:23:14 +00:00
XForwardedPrefix string
SSLCipher sslcipher.Config
2019-02-22 15:19:40 +00:00
Logs log.Config
InfluxDB influxdb.Config
ModSecurity modsecurity.Config
Mirror mirror.Config
2017-11-07 16:36:51 +00:00
}
// Extractor defines the annotation parsers to be used in the extraction of annotations
type Extractor struct {
2017-11-08 20:58:57 +00:00
annotations map[string]parser.IngressAnnotation
}
2017-11-07 16:36:51 +00:00
// NewAnnotationExtractor creates a new annotations extractor
2017-11-08 20:58:57 +00:00
func NewAnnotationExtractor(cfg resolver.Resolver) Extractor {
2017-11-07 16:36:51 +00:00
return Extractor{
map[string]parser.IngressAnnotation{
"Aliases": alias.NewParser(cfg),
"BasicDigestAuth": auth.NewParser(auth.AuthDirectory, cfg),
"Canary": canary.NewParser(cfg),
"CertificateAuth": authtls.NewParser(cfg),
2017-11-08 20:58:57 +00:00
"ClientBodyBufferSize": clientbodybuffersize.NewParser(cfg),
"ConfigurationSnippet": snippet.NewParser(cfg),
"Connection": connection.NewParser(cfg),
2017-11-08 20:58:57 +00:00
"CorsConfig": cors.NewParser(cfg),
"CustomHTTPErrors": customhttperrors.NewParser(cfg),
2017-11-07 16:36:51 +00:00
"DefaultBackend": defaultbackend.NewParser(cfg),
"FastCGI": fastcgi.NewParser(cfg),
2017-11-08 20:58:57 +00:00
"ExternalAuth": authreq.NewParser(cfg),
"EnableGlobalAuth": authreqglobal.NewParser(cfg),
"HTTP2PushPreload": http2pushpreload.NewParser(cfg),
"Opentracing": opentracing.NewParser(cfg),
"Proxy": proxy.NewParser(cfg),
"ProxySSL": proxyssl.NewParser(cfg),
"RateLimit": ratelimit.NewParser(cfg),
2020-12-24 16:39:12 +00:00
"GlobalRateLimit": globalratelimit.NewParser(cfg),
2017-11-08 20:58:57 +00:00
"Redirect": redirect.NewParser(cfg),
"Rewrite": rewrite.NewParser(cfg),
"Satisfy": satisfy.NewParser(cfg),
2017-05-14 22:14:27 +00:00
"SecureUpstream": secureupstream.NewParser(cfg),
2017-11-08 20:58:57 +00:00
"ServerSnippet": serversnippet.NewParser(cfg),
"ServiceUpstream": serviceupstream.NewParser(cfg),
"SessionAffinity": sessionaffinity.NewParser(cfg),
"SSLPassthrough": sslpassthrough.NewParser(cfg),
2017-11-07 16:36:51 +00:00
"UsePortInRedirects": portinredirect.NewParser(cfg),
2017-11-08 20:58:57 +00:00
"UpstreamHashBy": upstreamhashby.NewParser(cfg),
"LoadBalancing": loadbalancing.NewParser(cfg),
2017-11-08 20:58:57 +00:00
"UpstreamVhost": upstreamvhost.NewParser(cfg),
2017-11-07 16:36:51 +00:00
"Whitelist": ipwhitelist.NewParser(cfg),
2017-12-06 20:11:18 +00:00
"XForwardedPrefix": xforwardedprefix.NewParser(cfg),
"SSLCipher": sslcipher.NewParser(cfg),
"Logs": log.NewParser(cfg),
"InfluxDB": influxdb.NewParser(cfg),
2018-08-05 22:43:45 +00:00
"BackendProtocol": backendprotocol.NewParser(cfg),
"ModSecurity": modsecurity.NewParser(cfg),
"Mirror": mirror.NewParser(cfg),
},
}
}
2017-11-07 16:36:51 +00:00
// Extract extracts the annotations from an Ingress
func (e Extractor) Extract(ing *networking.Ingress) *Ingress {
2017-11-07 16:36:51 +00:00
pia := &Ingress{
ObjectMeta: ing.ObjectMeta,
}
data := make(map[string]interface{})
for name, annotationParser := range e.annotations {
val, err := annotationParser.Parse(ing)
2020-10-26 19:08:55 +00:00
klog.V(5).InfoS("Parsing Ingress annotation", "name", name, "ingress", klog.KObj(ing), "value", val)
if err != nil {
if errors.IsMissingAnnotations(err) {
continue
}
2017-08-25 15:50:08 +00:00
if !errors.IsLocationDenied(err) {
continue
}
if name == "CertificateAuth" && data[name] == nil {
data[name] = authtls.Config{
AuthTLSError: err.Error(),
}
// avoid mapping the result from the annotation
val = nil
}
2017-11-07 16:36:51 +00:00
_, alreadyDenied := data[DeniedKeyName]
if !alreadyDenied {
2019-02-22 16:48:13 +00:00
errString := err.Error()
data[DeniedKeyName] = &errString
2020-10-26 19:08:55 +00:00
klog.ErrorS(err, "error reading Ingress annotation", "name", name, "ingress", klog.KObj(ing))
continue
}
2020-10-26 19:08:55 +00:00
klog.V(5).ErrorS(err, "error reading Ingress annotation", "name", name, "ingress", klog.KObj(ing))
}
if val != nil {
2017-11-07 16:36:51 +00:00
data[name] = val
}
}
2017-11-11 18:26:36 +00:00
err := mergo.MapWithOverwrite(pia, data)
if err != nil {
2020-09-27 20:32:40 +00:00
klog.ErrorS(err, "unexpected error merging extracted annotations")
}
2017-11-07 16:36:51 +00:00
return pia
}