chore(k8s): gen templates.

This commit is contained in:
Fernandez Ludovic 2018-01-31 16:28:27 +01:00 committed by Traefiker
parent 62df067fac
commit c944d203fb

View file

@ -782,20 +782,28 @@ func templatesEurekaTmpl() (*asset, error) {
return a, nil return a, nil
} }
var _templatesKubernetesTmpl = []byte(`[backends]{{range $backendName, $backend := .Backends}} var _templatesKubernetesTmpl = []byte(`[backends]
[backends."{{$backendName}}"] {{range $backendName, $backend := .Backends }}
{{if $backend.CircuitBreaker}}
[backends."{{$backendName}}".circuitbreaker] [backends."{{ $backendName }}"]
expression = "{{$backend.CircuitBreaker.Expression}}"
{{if $backend.CircuitBreaker }}
[backends."{{ $backendName }} ".circuitBreaker]
expression = "{{ $backend.CircuitBreaker.Expression }}"
{{end}} {{end}}
[backends."{{$backendName}}".loadbalancer]
method = "{{$backend.LoadBalancer.Method}}" [backends."{{ $backendName }}".loadBalancer]
{{if $backend.LoadBalancer.Sticky}} method = "{{ $backend.LoadBalancer.Method }}"
sticky = true sticky = {{ $backend.LoadBalancer.Sticky }}
{{if $backend.LoadBalancer.Stickiness }}
[backends."{{ $backendName }}".loadBalancer.stickiness]
cookieName = "{{ $backend.LoadBalancer.Stickiness.CookieName }}"
{{end}} {{end}}
{{if $backend.LoadBalancer.Stickiness}}
[backends."{{$backendName}}".loadbalancer.stickiness] {{if $backend.MaxConn }}
cookieName = "{{$backend.LoadBalancer.Stickiness.CookieName}}" [backends.backend-{{ $backendName }}.maxConn]
amount = {{ $backend.MaxConn.Amount }}
extractorFunc = "{{ $backend.MaxConn.ExtractorFunc }}"
{{end}} {{end}}
{{if $backend.Buffering }} {{if $backend.Buffering }}
@ -807,95 +815,128 @@ var _templatesKubernetesTmpl = []byte(`[backends]{{range $backendName, $backend
retryExpression = "{{ $backend.Buffering.RetryExpression }}" retryExpression = "{{ $backend.Buffering.RetryExpression }}"
{{end}} {{end}}
{{range $serverName, $server := $backend.Servers}} {{range $serverName, $server := $backend.Servers }}
[backends."{{$backendName}}".servers."{{$serverName}}"] [backends."{{ $backendName }}".servers."{{ $serverName }}"]
url = "{{$server.URL}}" url = "{{ $server.URL }}"
weight = {{$server.Weight}} weight = {{ $server.Weight }}
{{end}} {{end}}
{{end}} {{end}}
[frontends]{{range $frontendName, $frontend := .Frontends}} [frontends]
[frontends."{{$frontendName}}"] {{range $frontendName, $frontend := .Frontends }}
backend = "{{$frontend.Backend}}"
priority = {{$frontend.Priority}} [frontends."{{ $frontendName }}"]
passHostHeader = {{$frontend.PassHostHeader}} backend = "{{ $frontend.Backend }}"
entryPoints = [{{range $frontend.EntryPoints}} priority = {{ $frontend.Priority }}
"{{.}}", passHostHeader = {{ $frontend.PassHostHeader }}
{{end}}] passTLSCert = {{ $frontend.PassTLSCert }}
basicAuth = [{{range $frontend.BasicAuth}}
"{{.}}", entryPoints = [{{range $frontend.EntryPoints }}
{{end}}]
whitelistSourceRange = [{{range $frontend.WhitelistSourceRange}}
"{{.}}", "{{.}}",
{{end}}] {{end}}]
{{if $frontend.Redirect}} basicAuth = [{{range $frontend.BasicAuth }}
[frontends."{{$frontendName}}".redirect] "{{.}}",
entryPoint = "{{$frontend.Redirect.EntryPoint}}" {{end}}]
regex = "{{$frontend.Redirect.Regex}}"
replacement = "{{$frontend.Redirect.Replacement}}" whitelistSourceRange = [{{range $frontend.WhitelistSourceRange }}
"{{.}}",
{{end}}]
{{if $frontend.Redirect }}
[frontends."{{ $frontendName }}".redirect]
entryPoint = "{{ $frontend.Redirect.EntryPoint }}"
regex = "{{ $frontend.Redirect.Regex }}"
replacement = "{{ $frontend.Redirect.Replacement }}"
{{end}}
{{if $frontend.Errors }}
[frontends."frontend-{{ $frontendName }}".errors]
{{range $pageName, $page := $frontend.Errors }}
[frontends."frontend-{{ $frontendName }}".errors.{{ $pageName }}]
status = [{{range $page.Status }}
"{{.}}",
{{end}}]
backend = "{{ $page.Backend }}"
query = "{{ $page.Query }}"
{{end}}
{{end}}
{{if $frontend.RateLimit }}
[frontends."frontend-{{ $frontendName }}".rateLimit]
extractorFunc = "{{ $frontend.RateLimit.ExtractorFunc }}"
[frontends."frontend-{{ $frontendName }}".rateLimit.rateSet]
{{range $limitName, $limit := $frontend.RateLimit.RateSet }}
[frontends."frontend-{{ $frontendName }}".rateLimit.rateSet.{{ $limitName }}]
period = "{{ $limit.Period }}"
average = {{ $limit.Average }}
burst = {{ $limit.Burst }}
{{end}}
{{end}} {{end}}
{{if $frontend.Headers }} {{if $frontend.Headers }}
[frontends."{{$frontendName}}".headers] [frontends."{{ $frontendName }}".headers]
SSLRedirect = {{$frontend.Headers.SSLRedirect}} SSLRedirect = {{ $frontend.Headers.SSLRedirect }}
SSLTemporaryRedirect = {{$frontend.Headers.SSLTemporaryRedirect}} SSLTemporaryRedirect = {{ $frontend.Headers.SSLTemporaryRedirect }}
SSLHost = "{{$frontend.Headers.SSLHost}}" SSLHost = "{{ $frontend.Headers.SSLHost }}"
STSSeconds = {{$frontend.Headers.STSSeconds}} STSSeconds = {{ $frontend.Headers.STSSeconds }}
STSIncludeSubdomains = {{$frontend.Headers.STSIncludeSubdomains}} STSIncludeSubdomains = {{ $frontend.Headers.STSIncludeSubdomains }}
STSPreload = {{$frontend.Headers.STSPreload}} STSPreload = {{ $frontend.Headers.STSPreload }}
ForceSTSHeader = {{$frontend.Headers.ForceSTSHeader}} ForceSTSHeader = {{ $frontend.Headers.ForceSTSHeader }}
FrameDeny = {{$frontend.Headers.FrameDeny}} FrameDeny = {{ $frontend.Headers.FrameDeny }}
CustomFrameOptionsValue = "{{$frontend.Headers.CustomFrameOptionsValue}}" CustomFrameOptionsValue = "{{ $frontend.Headers.CustomFrameOptionsValue }}"
ContentTypeNosniff = {{$frontend.Headers.ContentTypeNosniff}} ContentTypeNosniff = {{ $frontend.Headers.ContentTypeNosniff }}
BrowserXSSFilter = {{$frontend.Headers.BrowserXSSFilter}} BrowserXSSFilter = {{ $frontend.Headers.BrowserXSSFilter }}
ContentSecurityPolicy = "{{$frontend.Headers.ContentSecurityPolicy}}" ContentSecurityPolicy = "{{ $frontend.Headers.ContentSecurityPolicy }}"
PublicKey = "{{$frontend.Headers.PublicKey}}" PublicKey = "{{ $frontend.Headers.PublicKey }}"
ReferrerPolicy = "{{$frontend.Headers.ReferrerPolicy}}" ReferrerPolicy = "{{ $frontend.Headers.ReferrerPolicy }}"
IsDevelopment = {{$frontend.Headers.IsDevelopment}} IsDevelopment = {{ $frontend.Headers.IsDevelopment }}
{{if $frontend.Headers.AllowedHosts}} {{if $frontend.Headers.AllowedHosts }}
AllowedHosts = [{{range $frontend.Headers.AllowedHosts}} AllowedHosts = [{{range $frontend.Headers.AllowedHosts }}
"{{.}}", "{{.}}",
{{end}}] {{end}}]
{{end}} {{end}}
{{if $frontend.Headers.HostsProxyHeaders}} {{if $frontend.Headers.HostsProxyHeaders }}
HostsProxyHeaders = [{{range $frontend.Headers.HostsProxyHeaders}} HostsProxyHeaders = [{{range $frontend.Headers.HostsProxyHeaders }}
"{{.}}", "{{.}}",
{{end}}] {{end}}]
{{end}} {{end}}
{{if $frontend.Headers.CustomRequestHeaders}} {{if $frontend.Headers.CustomRequestHeaders }}
[frontends."{{$frontendName}}".headers.customrequestheaders] [frontends."{{ $frontendName }}".headers.customRequestHeaders]
{{range $k, $v := $frontend.Headers.CustomRequestHeaders}} {{range $k, $v := $frontend.Headers.CustomRequestHeaders }}
{{$k}} = "{{$v}}" {{ $k }} = "{{ $v }}"
{{end}} {{end}}
{{end}}
{{if $frontend.Headers.CustomResponseHeaders}}
[frontends."{{$frontendName}}".headers.customresponseheaders]
{{range $k, $v := $frontend.Headers.CustomResponseHeaders}}
{{$k}} = "{{$v}}"
{{end}} {{end}}
{{end}} {{if $frontend.Headers.CustomResponseHeaders }}
{{if $frontend.Headers.SSLProxyHeaders}} [frontends."{{ $frontendName }}".headers.customResponseHeaders]
[frontends."{{$frontendName}}".headers.SSLProxyHeaders] {{range $k, $v := $frontend.Headers.CustomResponseHeaders }}
{{range $k, $v := $frontend.Headers.SSLProxyHeaders}} {{ $k }} = "{{ $v }}"
{{$k}} = "{{$v}}"
{{end}} {{end}}
{{end}}
{{end}}
{{range $routeName, $route := $frontend.Routes}}
[frontends."{{$frontendName}}".routes."{{$routeName}}"]
rule = "{{$route.Rule}}"
{{end}} {{end}}
{{if $frontend.Headers.SSLProxyHeaders }}
[frontends."{{ $frontendName }}".headers.SSLProxyHeaders]
{{range $k, $v := $frontend.Headers.SSLProxyHeaders }}
{{ $k }} = "{{ $v }}"
{{end}}
{{end}}
{{end}}
{{range $routeName, $route := $frontend.Routes }}
[frontends."{{ $frontendName }}".routes."{{ $routeName }}"]
rule = "{{ $route.Rule }}"
{{end}}
{{end}} {{end}}
{{range $tls := .TLS}} {{range $tls := .TLS }}
[[tls]] [[tls]]
entryPoints = [{{range $tls.EntryPoints}} entryPoints = [{{range $tls.EntryPoints }}
"{{.}}", "{{.}}",
{{end}}] {{end}}]
[tls.certificate] [tls.certificate]
certFile = """{{$tls.Certificate.CertFile}}""" certFile = """{{ $tls.Certificate.CertFile }}"""
keyFile = """{{$tls.Certificate.KeyFile}}""" keyFile = """{{ $tls.Certificate.KeyFile }}"""
{{end}} {{end}}
`) `)