// Code generated by go-bindata. // sources: // templates/consul_catalog.tmpl // templates/docker.tmpl // templates/ecs.tmpl // templates/eureka.tmpl // templates/kubernetes.tmpl // templates/kv.tmpl // templates/marathon.tmpl // templates/mesos.tmpl // templates/notFound.tmpl // templates/rancher.tmpl // DO NOT EDIT! package gentemplates import ( "fmt" "io/ioutil" "os" "path/filepath" "strings" "time" ) type asset struct { bytes []byte info os.FileInfo } type bindataFileInfo struct { name string size int64 mode os.FileMode modTime time.Time } func (fi bindataFileInfo) Name() string { return fi.name } func (fi bindataFileInfo) Size() int64 { return fi.size } func (fi bindataFileInfo) Mode() os.FileMode { return fi.mode } func (fi bindataFileInfo) ModTime() time.Time { return fi.modTime } func (fi bindataFileInfo) IsDir() bool { return false } func (fi bindataFileInfo) Sys() interface{} { return nil } var _templatesConsul_catalogTmpl = []byte(`[backends] {{range $index, $node := .Nodes}} [backends."backend-{{getBackend $node}}".servers."{{getBackendName $node $index}}"] url = "{{getAttribute "protocol" $node.Service.Tags "http"}}://{{getBackendAddress $node}}:{{$node.Service.Port}}" {{$weight := getAttribute "backend.weight" $node.Service.Tags "0"}} {{with $weight}} weight = {{$weight}} {{end}} {{end}} {{range .Services}} {{$service := .ServiceName}} {{$circuitBreaker := getAttribute "backend.circuitbreaker" .Attributes ""}} {{with $circuitBreaker}} [backends."backend-{{$service}}".circuitbreaker] expression = "{{$circuitBreaker}}" {{end}} [backends."backend-{{$service}}".loadbalancer] method = "{{getAttribute "backend.loadbalancer" .Attributes "wrr"}}" sticky = {{getSticky .Attributes}} {{if hasStickinessLabel .Attributes}} [backends."backend-{{$service}}".loadbalancer.stickiness] cookieName = "{{getStickinessCookieName .Attributes}}" {{end}} {{if hasMaxconnAttributes .Attributes}} [backends."backend-{{$service}}".maxconn] amount = {{getAttribute "backend.maxconn.amount" .Attributes "" }} extractorfunc = "{{getAttribute "backend.maxconn.extractorfunc" .Attributes "" }}" {{end}} {{end}} [frontends] {{range .Services}} [frontends."frontend-{{.ServiceName}}"] backend = "backend-{{.ServiceName}}" passHostHeader = {{getAttribute "frontend.passHostHeader" .Attributes "true"}} priority = {{getAttribute "frontend.priority" .Attributes "0"}} {{$entryPoints := getAttribute "frontend.entrypoints" .Attributes ""}} {{with $entryPoints}} entrypoints = [{{range getEntryPoints $entryPoints}} "{{.}}", {{end}}] {{end}} basicAuth = [{{range getBasicAuth .Attributes}} "{{.}}", {{end}}] [frontends."frontend-{{.ServiceName}}".routes."route-host-{{.ServiceName}}"] rule = "{{getFrontendRule .}}" {{end}} `) func templatesConsul_catalogTmplBytes() ([]byte, error) { return _templatesConsul_catalogTmpl, nil } func templatesConsul_catalogTmpl() (*asset, error) { bytes, err := templatesConsul_catalogTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/consul_catalog.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesDockerTmpl = []byte(`{{$backendServers := .Servers}} [backends] {{range $backendName, $backend := .Backends}} {{if hasCircuitBreakerLabel $backend}} [backends.backend-{{$backendName}}.circuitBreaker] expression = "{{getCircuitBreakerExpression $backend}}" {{end}} {{if hasLoadBalancerLabel $backend}} [backends.backend-{{$backendName}}.loadBalancer] method = "{{getLoadBalancerMethod $backend}}" sticky = {{getSticky $backend}} {{if hasStickinessLabel $backend}} [backends.backend-{{$backendName}}.loadBalancer.stickiness] cookieName = "{{getStickinessCookieName $backend}}" {{end}} {{end}} {{if hasMaxConnLabels $backend}} [backends.backend-{{$backendName}}.maxConn] amount = {{getMaxConnAmount $backend}} extractorFunc = "{{getMaxConnExtractorFunc $backend}}" {{end}} {{if hasHealthCheckLabels $backend}} [backends.backend-{{$backendName}}.healthCheck] path = "{{getHealthCheckPath $backend}}" port = {{getHealthCheckPort $backend}} interval = "{{getHealthCheckInterval $backend}}" {{end}} {{$servers := index $backendServers $backendName}} {{range $serverName, $server := $servers}} {{if hasServices $server}} {{$services := getServiceNames $server}} {{range $serviceIndex, $serviceName := $services}} [backends.backend-{{getServiceBackend $server $serviceName}}.servers.service-{{$serverName}}] url = "{{getServiceProtocol $server $serviceName}}://{{getIPAddress $server}}:{{getServicePort $server $serviceName}}" weight = {{getServiceWeight $server $serviceName}} {{end}} {{else}} [backends.backend-{{$backendName}}.servers.server-{{$server.Name | replace "/" "" | replace "." "-"}}] url = "{{getProtocol $server}}://{{getIPAddress $server}}:{{getPort $server}}" weight = {{getWeight $server}} {{end}} {{end}} {{end}} [frontends] {{range $frontend, $containers := .Frontends}} {{$container := index $containers 0}} {{if hasServices $container}} {{$services := getServiceNames $container}} {{range $serviceIndex, $serviceName := $services}} [frontends."frontend-{{getServiceBackend $container $serviceName}}"] backend = "backend-{{getServiceBackend $container $serviceName}}" priority = {{getServicePriority $container $serviceName}} passHostHeader = {{getServicePassHostHeader $container $serviceName}} passTLSCert = {{getServicePassTLSCert $container $serviceName}} entryPoints = [{{range getServiceEntryPoints $container $serviceName}} "{{.}}", {{end}}] {{if getServiceWhitelistSourceRange $container $serviceName}} whitelistSourceRange = [{{range getServiceWhitelistSourceRange $container $serviceName}} "{{.}}", {{end}}] {{end}} basicAuth = [{{range getServiceBasicAuth $container $serviceName}} "{{.}}", {{end}}] {{if hasServiceRedirect $container $serviceName}} [frontends."frontend-{{getServiceBackend $container $serviceName}}".redirect] entryPoint = "{{getServiceRedirectEntryPoint $container $serviceName}}" regex = "{{getServiceRedirectRegex $container $serviceName}}" replacement = "{{getServiceRedirectReplacement $container $serviceName}}" {{end}} {{ if hasServiceErrorPages $container $serviceName }} [frontends."frontend-{{getServiceBackend $container $serviceName}}".errors] {{ range $pageName, $page := getServiceErrorPages $container $serviceName }} [frontends."frontend-{{getServiceBackend $container $serviceName}}".errors.{{$pageName}}] status = [{{range $page.Status}} "{{.}}", {{end}}] backend = "{{$page.Backend}}" query = "{{$page.Query}}" {{end}} {{end}} {{ if hasServiceRateLimits $container $serviceName }} [frontends."frontend-{{getServiceBackend $container $serviceName}}".rateLimit] extractorFunc = "{{ getRateLimitsExtractorFunc $container $serviceName }}" [frontends."frontend-{{getServiceBackend $container $serviceName}}".rateLimit.rateSet] {{ range $limitName, $rateLimit := getServiceRateLimits $container $serviceName }} [frontends."frontend-{{getServiceBackend $container $serviceName}}".rateLimit.rateSet.{{ $limitName }}] period = "{{ $rateLimit.Period }}" average = {{ $rateLimit.Average }} burst = {{ $rateLimit.Burst }} {{end}} {{end}} [frontends."frontend-{{getServiceBackend $container $serviceName}}".routes."service-{{$serviceName | replace "/" "" | replace "." "-"}}"] rule = "{{getServiceFrontendRule $container $serviceName}}" {{if hasServiceRequestHeaders $container $serviceName}} [frontends."frontend-{{getServiceBackend $container $serviceName}}".headers.customRequestHeaders] {{range $k, $v := getServiceRequestHeaders $container $serviceName}} {{$k}} = "{{$v}}" {{end}} {{end}} {{if hasServiceResponseHeaders $container $serviceName}} [frontends."frontend-{{getServiceBackend $container $serviceName}}".headers.customResponseHeaders] {{range $k, $v := getServiceResponseHeaders $container $serviceName}} {{$k}} = "{{$v}}" {{end}} {{end}} {{end}} ## end range services {{else}} [frontends."frontend-{{$frontend}}"] backend = "backend-{{getBackend $container}}" priority = {{getPriority $container}} passHostHeader = {{getPassHostHeader $container}} passTLSCert = {{getPassTLSCert $container}} entryPoints = [{{range getEntryPoints $container}} "{{.}}", {{end}}] {{if getWhitelistSourceRange $container}} whitelistSourceRange = [{{range getWhitelistSourceRange $container}} "{{.}}", {{end}}] {{end}} basicAuth = [{{range getBasicAuth $container}} "{{.}}", {{end}}] {{if hasRedirect $container}} [frontends."frontend-{{$frontend}}".redirect] entryPoint = "{{getRedirectEntryPoint $container}}" regex = "{{getRedirectRegex $container}}" replacement = "{{getRedirectReplacement $container}}" {{end}} {{ if hasErrorPages $container }} [frontends."frontend-{{$frontend}}".errors] {{ range $pageName, $page := getErrorPages $container }} [frontends."frontend-{{$frontend}}".errors.{{ $pageName }}] status = [{{range $page.Status}} "{{.}}", {{end}}] backend = "{{$page.Backend}}" query = "{{$page.Query}}" {{end}} {{end}} {{ if hasRateLimits $container }} [frontends."frontend-{{$frontend}}".rateLimit] extractorFunc = "{{ getRateLimitsExtractorFunc $container }}" [frontends."frontend-{{$frontend}}".rateLimit.rateSet] {{ range $limitName, $rateLimit := getRateLimits $container }} [frontends."frontend-{{$frontend}}".rateLimit.rateSet.{{ $limitName }}] period = "{{ $rateLimit.Period }}" average = {{ $rateLimit.Average }} burst = {{ $rateLimit.Burst }} {{end}} {{end}} [frontends."frontend-{{$frontend}}".headers] {{if hasSSLRedirectHeaders $container}} SSLRedirect = {{getSSLRedirectHeaders $container}} {{end}} {{if hasSSLTemporaryRedirectHeaders $container}} SSLTemporaryRedirect = {{getSSLTemporaryRedirectHeaders $container}} {{end}} {{if hasSSLHostHeaders $container}} SSLHost = "{{getSSLHostHeaders $container}}" {{end}} {{if hasSTSSecondsHeaders $container}} STSSeconds = {{getSTSSecondsHeaders $container}} {{end}} {{if hasSTSIncludeSubdomainsHeaders $container}} STSIncludeSubdomains = {{getSTSIncludeSubdomainsHeaders $container}} {{end}} {{if hasSTSPreloadHeaders $container}} STSPreload = {{getSTSPreloadHeaders $container}} {{end}} {{if hasForceSTSHeaderHeaders $container}} ForceSTSHeader = {{getForceSTSHeaderHeaders $container}} {{end}} {{if hasFrameDenyHeaders $container}} FrameDeny = {{getFrameDenyHeaders $container}} {{end}} {{if hasCustomFrameOptionsValueHeaders $container}} CustomFrameOptionsValue = "{{getCustomFrameOptionsValueHeaders $container}}" {{end}} {{if hasContentTypeNosniffHeaders $container}} ContentTypeNosniff = {{getContentTypeNosniffHeaders $container}} {{end}} {{if hasBrowserXSSFilterHeaders $container}} BrowserXSSFilter = {{getBrowserXSSFilterHeaders $container}} {{end}} {{if hasContentSecurityPolicyHeaders $container}} ContentSecurityPolicy = "{{getContentSecurityPolicyHeaders $container}}" {{end}} {{if hasPublicKeyHeaders $container}} PublicKey = "{{getPublicKeyHeaders $container}}" {{end}} {{if hasReferrerPolicyHeaders $container}} ReferrerPolicy = "{{getReferrerPolicyHeaders $container}}" {{end}} {{if hasIsDevelopmentHeaders $container}} IsDevelopment = {{getIsDevelopmentHeaders $container}} {{end}} {{if hasAllowedHostsHeaders $container}} AllowedHosts = [{{range getAllowedHostsHeaders $container}} "{{.}}", {{end}}] {{end}} {{if hasHostsProxyHeaders $container}} HostsProxyHeaders = [{{range getHostsProxyHeaders $container}} "{{.}}", {{end}}] {{end}} {{if hasRequestHeaders $container}} [frontends."frontend-{{$frontend}}".headers.customRequestHeaders] {{range $k, $v := getRequestHeaders $container}} {{$k}} = "{{$v}}" {{end}} {{end}} {{if hasResponseHeaders $container}} [frontends."frontend-{{$frontend}}".headers.customResponseHeaders] {{range $k, $v := getResponseHeaders $container}} {{$k}} = "{{$v}}" {{end}} {{end}} {{if hasSSLProxyHeaders $container}} [frontends."frontend-{{$frontend}}".headers.SSLProxyHeaders] {{range $k, $v := getSSLProxyHeaders $container}} {{$k}} = "{{$v}}" {{end}} {{end}} [frontends."frontend-{{$frontend}}".routes."route-frontend-{{$frontend}}"] rule = "{{getFrontendRule $container}}" {{end}} {{end}} `) func templatesDockerTmplBytes() ([]byte, error) { return _templatesDockerTmpl, nil } func templatesDockerTmpl() (*asset, error) { bytes, err := templatesDockerTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/docker.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesEcsTmpl = []byte(`[backends]{{range $serviceName, $instances := .Services}} [backends.backend-{{ $serviceName }}.loadbalancer] method = "{{ getLoadBalancerMethod $instances}}" sticky = {{ getSticky $instances}} {{if hasStickinessLabel $instances}} [backends.backend-{{ $serviceName }}.loadbalancer.stickiness] cookieName = "{{getStickinessCookieName $instances}}" {{end}} {{ if hasHealthCheckLabels $instances }} [backends.backend-{{ $serviceName }}.healthcheck] path = "{{getHealthCheckPath $instances }}" interval = "{{getHealthCheckInterval $instances }}" {{end}} {{range $index, $i := $instances}} [backends.backend-{{ $i.Name }}.servers.server-{{ $i.Name }}{{ $i.ID }}] url = "{{ getProtocol $i }}://{{ getHost $i }}:{{ getPort $i }}" weight = {{ getWeight $i}} {{end}} {{end}} [frontends]{{range $serviceName, $instances := .Services}} {{range filterFrontends $instances}} [frontends.frontend-{{ $serviceName }}] backend = "backend-{{ $serviceName }}" passHostHeader = {{ getPassHostHeader .}} priority = {{ getPriority .}} entryPoints = [{{range getEntryPoints .}} "{{.}}", {{end}}] basicAuth = [{{range getBasicAuth .}} "{{.}}", {{end}}] [frontends.frontend-{{ $serviceName }}.routes.route-frontend-{{ $serviceName }}] rule = "{{getFrontendRule .}}" {{end}} {{end}}`) func templatesEcsTmplBytes() ([]byte, error) { return _templatesEcsTmpl, nil } func templatesEcsTmpl() (*asset, error) { bytes, err := templatesEcsTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/ecs.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesEurekaTmpl = []byte(`[backends]{{range .Applications}} {{ $app := .}} {{range .Instances}} [backends.backend{{$app.Name}}.servers.server-{{ getInstanceID . }}] url = "{{ getProtocol . }}://{{ .IpAddr }}:{{ getPort . }}" weight = {{ getWeight . }} {{end}}{{end}} [frontends]{{range .Applications}} [frontends.frontend{{.Name}}] backend = "backend{{.Name}}" entryPoints = ["http"] [frontends.frontend{{.Name }}.routes.route-host{{.Name}}] rule = "Host:{{ .Name | tolower }}" {{end}} `) func templatesEurekaTmplBytes() ([]byte, error) { return _templatesEurekaTmpl, nil } func templatesEurekaTmpl() (*asset, error) { bytes, err := templatesEurekaTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/eureka.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesKubernetesTmpl = []byte(`[backends]{{range $backendName, $backend := .Backends}} [backends."{{$backendName}}"] {{if $backend.CircuitBreaker}} [backends."{{$backendName}}".circuitbreaker] expression = "{{$backend.CircuitBreaker.Expression}}" {{end}} [backends."{{$backendName}}".loadbalancer] method = "{{$backend.LoadBalancer.Method}}" {{if $backend.LoadBalancer.Sticky}} sticky = true {{end}} {{if $backend.LoadBalancer.Stickiness}} [backends."{{$backendName}}".loadbalancer.stickiness] cookieName = "{{$backend.LoadBalancer.Stickiness.CookieName}}" {{end}} {{range $serverName, $server := $backend.Servers}} [backends."{{$backendName}}".servers."{{$serverName}}"] url = "{{$server.URL}}" weight = {{$server.Weight}} {{end}} {{end}} [frontends]{{range $frontendName, $frontend := .Frontends}} [frontends."{{$frontendName}}"] backend = "{{$frontend.Backend}}" priority = {{$frontend.Priority}} passHostHeader = {{$frontend.PassHostHeader}} entryPoints = [{{range $frontend.EntryPoints}} "{{.}}", {{end}}] basicAuth = [{{range $frontend.BasicAuth}} "{{.}}", {{end}}] whitelistSourceRange = [{{range $frontend.WhitelistSourceRange}} "{{.}}", {{end}}] {{if $frontend.Redirect}} [frontends."{{$frontendName}}".redirect] entryPoint = "{{$frontend.RedirectEntryPoint}}" regex = "{{$frontend.RedirectRegex}}" replacement = "{{$frontend.RedirectReplacement}}" {{end}} [frontends."{{$frontendName}}".headers] SSLRedirect = {{$frontend.Headers.SSLRedirect}} SSLTemporaryRedirect = {{$frontend.Headers.SSLTemporaryRedirect}} SSLHost = "{{$frontend.Headers.SSLHost}}" STSSeconds = {{$frontend.Headers.STSSeconds}} STSIncludeSubdomains = {{$frontend.Headers.STSIncludeSubdomains}} STSPreload = {{$frontend.Headers.STSPreload}} ForceSTSHeader = {{$frontend.Headers.ForceSTSHeader}} FrameDeny = {{$frontend.Headers.FrameDeny}} CustomFrameOptionsValue = "{{$frontend.Headers.CustomFrameOptionsValue}}" ContentTypeNosniff = {{$frontend.Headers.ContentTypeNosniff}} BrowserXSSFilter = {{$frontend.Headers.BrowserXSSFilter}} ContentSecurityPolicy = "{{$frontend.Headers.ContentSecurityPolicy}}" PublicKey = "{{$frontend.Headers.PublicKey}}" ReferrerPolicy = "{{$frontend.Headers.ReferrerPolicy}}" IsDevelopment = {{$frontend.Headers.IsDevelopment}} {{if $frontend.Headers.AllowedHosts}} AllowedHosts = [{{range $frontend.Headers.AllowedHosts}} "{{.}}", {{end}}] {{end}} {{if $frontend.Headers.HostsProxyHeaders}} HostsProxyHeaders = [{{range $frontend.Headers.HostsProxyHeaders}} "{{.}}", {{end}}] {{end}} {{if $frontend.Headers.CustomRequestHeaders}} [frontends."{{$frontendName}}".headers.customrequestheaders] {{range $k, $v := $frontend.Headers.CustomRequestHeaders}} {{$k}} = "{{$v}}" {{end}} {{end}} {{if $frontend.Headers.CustomResponseHeaders}} [frontends."{{$frontendName}}".headers.customresponseheaders] {{range $k, $v := $frontend.Headers.CustomResponseHeaders}} {{$k}} = "{{$v}}" {{end}} {{end}} {{if $frontend.Headers.SSLProxyHeaders}} [frontends."{{$frontendName}}".headers.SSLProxyHeaders] {{range $k, $v := $frontend.Headers.SSLProxyHeaders}} {{$k}} = "{{$v}}" {{end}} {{end}} {{range $routeName, $route := $frontend.Routes}} [frontends."{{$frontendName}}".routes."{{$routeName}}"] rule = "{{$route.Rule}}" {{end}} {{end}} `) func templatesKubernetesTmplBytes() ([]byte, error) { return _templatesKubernetesTmpl, nil } func templatesKubernetesTmpl() (*asset, error) { bytes, err := templatesKubernetesTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/kubernetes.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesKvTmpl = []byte(`{{$frontends := List .Prefix "/frontends/" }} {{$backends := List .Prefix "/backends/"}} {{$tlsconfiguration := List .Prefix "/tlsconfiguration/"}} [backends]{{range $backends}} {{$backend := .}} {{$backendName := Last $backend}} {{$servers := ListServers $backend }} {{$circuitBreaker := Get "" . "/circuitbreaker/" "expression"}} {{with $circuitBreaker}} [backends."{{$backendName}}".circuitBreaker] expression = "{{$circuitBreaker}}" {{end}} {{$loadBalancer := Get "" . "/loadbalancer/" "method"}} {{with $loadBalancer}} [backends."{{$backendName}}".loadBalancer] method = "{{$loadBalancer}}" sticky = {{ getSticky . }} {{if hasStickinessLabel $backend}} [backends."{{$backendName}}".loadBalancer.stickiness] cookieName = "{{getStickinessCookieName $backend}}" {{end}} {{end}} {{$healthCheck := Get "" . "/healthcheck/" "path"}} {{with $healthCheck}} [backends."{{$backendName}}".healthCheck] path = "{{$healthCheck}}" interval = "{{ Get "30s" $backend "/healthcheck/" "interval" }}" {{end}} {{$maxConnAmt := Get "" . "/maxconn/" "amount"}} {{$maxConnExtractorFunc := Get "" . "/maxconn/" "extractorfunc"}} {{with $maxConnAmt}} {{with $maxConnExtractorFunc}} [backends."{{$backendName}}".maxConn] amount = {{$maxConnAmt}} extractorFunc = "{{$maxConnExtractorFunc}}" {{end}} {{end}} {{range $servers}} [backends."{{$backendName}}".servers."{{Last .}}"] url = "{{Get "" . "/url"}}" weight = {{Get "0" . "/weight"}} {{end}} {{end}} [frontends]{{range $frontends}} {{$frontend := Last .}} {{$entryPoints := SplitGet . "/entrypoints"}} [frontends."{{$frontend}}"] backend = "{{Get "" . "/backend"}}" passHostHeader = {{Get "true" . "/passHostHeader"}} priority = {{Get "0" . "/priority"}} entryPoints = [{{range $entryPoints}} "{{.}}", {{end}}] {{$routes := List . "/routes/"}} {{range $routes}} [frontends."{{$frontend}}".routes."{{Last .}}"] rule = "{{Get "" . "/rule"}}" {{end}} {{end}} {{range $tlsconfiguration}} {{$entryPoints := SplitGet . "/entrypoints"}} [[tlsConfiguration]] entryPoints = [{{range $entryPoints}} "{{.}}", {{end}}] [tlsConfiguration.certificate] certFile = """{{Get "" . "/certificate" "/certfile"}}""" keyFile = """{{Get "" . "/certificate" "/keyfile"}}""" {{end}} `) func templatesKvTmplBytes() ([]byte, error) { return _templatesKvTmpl, nil } func templatesKvTmpl() (*asset, error) { bytes, err := templatesKvTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/kv.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesMarathonTmpl = []byte(`{{$apps := .Applications}} [backends] {{range $app := $apps}} {{range $serviceIndex, $serviceName := getServiceNames $app}} [backends."{{getBackend $app $serviceName }}"] {{ if hasCircuitBreakerLabels $app }} [backends."{{getBackend $app $serviceName }}".circuitBreaker] expression = "{{getCircuitBreakerExpression $app }}" {{end}} {{ if hasLoadBalancerLabels $app }} [backends."{{getBackend $app $serviceName }}".loadBalancer] method = "{{getLoadBalancerMethod $app }}" sticky = {{getSticky $app}} {{if hasStickinessLabel $app}} [backends."{{getBackend $app $serviceName }}".loadBalancer.stickiness] cookieName = "{{getStickinessCookieName $app}}" {{end}} {{end}} {{ if hasMaxConnLabels $app }} [backends."{{getBackend $app $serviceName }}".maxConn] amount = {{getMaxConnAmount $app }} extractorFunc = "{{getMaxConnExtractorFunc $app }}" {{end}} {{ if hasHealthCheckLabels $app }} [backends."{{getBackend $app $serviceName }}".healthCheck] path = "{{getHealthCheckPath $app }}" port = {{getHealthCheckPort $app}} interval = "{{getHealthCheckInterval $app }}" {{end}} {{end}} {{range $task := $app.Tasks}} {{range $serviceIndex, $serviceName := getServiceNames $app}} [backends."{{getBackend $app $serviceName}}".servers."server-{{$task.ID | replace "." "-"}}{{getServiceNameSuffix $serviceName }}"] url = "{{getProtocol $app $serviceName}}://{{getBackendServer $task $app}}:{{getPort $task $app $serviceName}}" weight = {{getWeight $app $serviceName}} {{end}} {{end}} {{end}} [frontends] {{range $app := $apps}} {{range $serviceIndex, $serviceName := getServiceNames .}} [frontends."{{ getFrontendName $app $serviceName }}"] backend = "{{getBackend $app $serviceName}}" priority = {{getPriority $app $serviceName}} passHostHeader = {{getPassHostHeader $app $serviceName}} passTLSCert = {{getPassTLSCert $app $serviceName}} entryPoints = [{{range getEntryPoints $app $serviceName}} "{{.}}", {{end}}] {{if getWhitelistSourceRange $app $serviceName}} whitelistSourceRange = [{{range getWhitelistSourceRange $app $serviceName}} "{{.}}", {{end}}] {{end}} basicAuth = [{{range getBasicAuth $app $serviceName}} "{{.}}", {{end}}] {{if hasRedirect $app $serviceName}} [frontends."{{ getFrontendName $app $serviceName }}".redirect] entryPoint = "{{getRedirectEntryPoint $app $serviceName}}" regex = "{{getRedirectRegex $app $serviceName}}" replacement = "{{getRedirectReplacement $app $serviceName}}" {{end}} {{ if hasErrorPages $app $serviceName }} [frontends."{{ getFrontendName $app $serviceName }}".errors] {{ range $pageName, $page := getErrorPages $app $serviceName }} [frontends."{{ getFrontendName $app $serviceName }}".errors.{{ $pageName }}] status = [{{range $page.Status}} "{{.}}", {{end}}] backend = "{{$page.Backend}}" query = "{{$page.Query}}" {{end}} {{end}} {{ if hasRateLimits $app $serviceName }} [frontends."{{ getFrontendName $app $serviceName }}".rateLimit] extractorFunc = "{{ getRateLimitsExtractorFunc $app $serviceName }}" [frontends."{{ getFrontendName $app $serviceName }}".rateLimit.rateSet] {{ range $limitName, $rateLimit := getRateLimits $app $serviceName }} [frontends."{{ getFrontendName $app $serviceName }}".rateLimit.rateSet.{{ $limitName }}] period = "{{ $rateLimit.Period }}" average = {{ $rateLimit.Average }} burst = {{ $rateLimit.Burst }} {{end}} {{end}} [frontends."{{ getFrontendName $app $serviceName }}".headers] {{if hasSSLRedirectHeaders $app $serviceName}} SSLRedirect = {{getSSLRedirectHeaders $app $serviceName}} {{end}} {{if hasSSLTemporaryRedirectHeaders $app $serviceName}} SSLTemporaryRedirect = {{getSSLTemporaryRedirectHeaders $app $serviceName}} {{end}} {{if hasSSLHostHeaders $app $serviceName}} SSLHost = "{{getSSLHostHeaders $app $serviceName}}" {{end}} {{if hasSTSSecondsHeaders $app $serviceName}} STSSeconds = {{getSTSSecondsHeaders $app $serviceName}} {{end}} {{if hasSTSIncludeSubdomainsHeaders $app $serviceName}} STSIncludeSubdomains = {{getSTSIncludeSubdomainsHeaders $app $serviceName}} {{end}} {{if hasSTSPreloadHeaders $app $serviceName}} STSPreload = {{getSTSPreloadHeaders $app $serviceName}} {{end}} {{if hasForceSTSHeaderHeaders $app $serviceName}} ForceSTSHeader = {{getForceSTSHeaderHeaders $app $serviceName}} {{end}} {{if hasFrameDenyHeaders $app $serviceName}} FrameDeny = {{getFrameDenyHeaders $app $serviceName}} {{end}} {{if hasCustomFrameOptionsValueHeaders $app $serviceName}} CustomFrameOptionsValue = "{{getCustomFrameOptionsValueHeaders $app $serviceName}}" {{end}} {{if hasContentTypeNosniffHeaders $app $serviceName}} ContentTypeNosniff = {{getContentTypeNosniffHeaders $app $serviceName}} {{end}} {{if hasBrowserXSSFilterHeaders $app $serviceName}} BrowserXSSFilter = {{getBrowserXSSFilterHeaders $app $serviceName}} {{end}} {{if hasContentSecurityPolicyHeaders $app $serviceName}} ContentSecurityPolicy = "{{getContentSecurityPolicyHeaders $app $serviceName}}" {{end}} {{if hasPublicKeyHeaders $app $serviceName}} PublicKey = "{{getPublicKeyHeaders $app $serviceName}}" {{end}} {{if hasReferrerPolicyHeaders $app $serviceName}} ReferrerPolicy = "{{getReferrerPolicyHeaders $app $serviceName}}" {{end}} {{if hasIsDevelopmentHeaders $app $serviceName}} IsDevelopment = {{getIsDevelopmentHeaders $app $serviceName}} {{end}} {{if hasAllowedHostsHeaders $app $serviceName}} AllowedHosts = [{{range getAllowedHostsHeaders $app $serviceName}} "{{.}}", {{end}}] {{end}} {{if hasHostsProxyHeaders $app $serviceName}} HostsProxyHeaders = [{{range getHostsProxyHeaders $app $serviceName}} "{{.}}", {{end}}] {{end}} {{if hasRequestHeaders $app $serviceName}} [frontends."{{ getFrontendName $app $serviceName }}".headers.customRequestHeaders] {{range $k, $v := getRequestHeaders $app $serviceName}} {{$k}} = "{{$v}}" {{end}} {{end}} {{if hasResponseHeaders $app $serviceName}} [frontends."{{ getFrontendName $app $serviceName }}".headers.customResponseHeaders] {{range $k, $v := getResponseHeaders $app $serviceName}} {{$k}} = "{{$v}}" {{end}} {{end}} {{if hasSSLProxyHeaders $app $serviceName}} [frontends."{{ getFrontendName $app $serviceName }}".headers.SSLProxyHeaders] {{range $k, $v := getSSLProxyHeaders $app $serviceName}} {{$k}} = "{{$v}}" {{end}} {{end}} [frontends."{{ getFrontendName $app $serviceName }}".routes."route-host{{$app.ID | replace "/" "-"}}{{getServiceNameSuffix $serviceName }}"] rule = "{{getFrontendRule $app $serviceName}}" {{end}} {{end}} `) func templatesMarathonTmplBytes() ([]byte, error) { return _templatesMarathonTmpl, nil } func templatesMarathonTmpl() (*asset, error) { bytes, err := templatesMarathonTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/marathon.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesMesosTmpl = []byte(`{{$apps := .Applications}} [backends]{{range .Tasks}} [backends.backend{{getBackend . $apps}}.servers.server-{{getID .}}] url = "{{getProtocol . $apps}}://{{getHost .}}:{{getPort . $apps}}" weight = {{getWeight . $apps}} {{end}} [frontends]{{range .Applications}} [frontends.frontend-{{getFrontEndName .}}] backend = "backend{{getFrontendBackend .}}" passHostHeader = {{getPassHostHeader .}} priority = {{getPriority .}} entryPoints = [{{range getEntryPoints .}} "{{.}}", {{end}}] [frontends.frontend-{{getFrontEndName .}}.routes.route-host{{getFrontEndName .}}] rule = "{{getFrontendRule .}}" {{end}} `) func templatesMesosTmplBytes() ([]byte, error) { return _templatesMesosTmpl, nil } func templatesMesosTmpl() (*asset, error) { bytes, err := templatesMesosTmplBytes() if err != nil { return nil, err } info := bindataFileInfo{name: "templates/mesos.tmpl", size: 0, mode: os.FileMode(0), modTime: time.Unix(0, 0)} a := &asset{bytes: bytes, info: info} return a, nil } var _templatesNotfoundTmpl = []byte(`