gatewayapi: adding support for TCPRoute and TLSRoute
Co-authored-by: Jean-Baptiste Doumenjou <925513+jbdoumenjou@users.noreply.github.com>
This commit is contained in:
parent
e1e1fd640c
commit
56f845c71a
72 changed files with 6241 additions and 208 deletions
|
@ -77,13 +77,13 @@ The [getting started guide](https://gateway-api.sigs.k8s.io/guides/getting-start
|
||||||
|
|
||||||
!!! note ""
|
!!! note ""
|
||||||
|
|
||||||
Keep in mind that the Traefik Gateway provider only supports the `v0.1.0`.
|
Keep in mind that the Traefik Gateway provider only supports the `v0.2.0`.
|
||||||
|
|
||||||
For now, the Traefik Gateway Provider can be used while following the below guides:
|
For now, the Traefik Gateway Provider can be used while following the below guides:
|
||||||
|
|
||||||
* [Simple Gateway](https://gateway-api.sigs.k8s.io/guides/simple-gateway/)
|
* [Simple Gateway](https://gateway-api.sigs.k8s.io/guides/simple-gateway/)
|
||||||
* [HTTP routing](https://gateway-api.sigs.k8s.io/guides/http-routing/)
|
* [HTTP routing](https://gateway-api.sigs.k8s.io/guides/http-routing/)
|
||||||
* [TLS](https://gateway-api.sigs.k8s.io/guides/tls/) (Partial support: only on listeners with terminate mode)
|
* [TLS](https://gateway-api.sigs.k8s.io/guides/tls/)
|
||||||
|
|
||||||
## Resource Configuration
|
## Resource Configuration
|
||||||
|
|
||||||
|
@ -96,7 +96,9 @@ Traefik implements the following resources:
|
||||||
|
|
||||||
* `GatewayClass` defines a set of Gateways that share a common configuration and behaviour.
|
* `GatewayClass` defines a set of Gateways that share a common configuration and behaviour.
|
||||||
* `Gateway` describes how traffic can be translated to Services within the cluster.
|
* `Gateway` describes how traffic can be translated to Services within the cluster.
|
||||||
* `HTTPRoute` define HTTP rules for mapping requests from a Gateway to Kubernetes Services.
|
* `HTTPRoute` defines HTTP rules for mapping requests from a Gateway to Kubernetes Services.
|
||||||
|
* `TCPRoute` defines TCP rules for mapping requests from a Gateway to Kubernetes Services.
|
||||||
|
* `TLSRoute` defines TLS rules for mapping requests from a Gateway to Kubernetes Services.
|
||||||
|
|
||||||
## Provider Configuration
|
## Provider Configuration
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,8 @@ rules:
|
||||||
- gatewayclasses
|
- gatewayclasses
|
||||||
- gateways
|
- gateways
|
||||||
- httproutes
|
- httproutes
|
||||||
|
- tcproutes
|
||||||
|
- tlsroutes
|
||||||
verbs:
|
verbs:
|
||||||
- get
|
- get
|
||||||
- list
|
- list
|
||||||
|
@ -30,6 +32,8 @@ rules:
|
||||||
- gatewayclasses/status
|
- gatewayclasses/status
|
||||||
- gateways/status
|
- gateways/status
|
||||||
- httproutes/status
|
- httproutes/status
|
||||||
|
- tcproutes/status
|
||||||
|
- tlsroutes/status
|
||||||
verbs:
|
verbs:
|
||||||
- update
|
- update
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,44 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
- protocol: HTTPS
|
||||||
|
port: 443
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
group: "core"
|
||||||
|
kind: "Secret"
|
||||||
|
name: "mysecret"
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: footcp
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9443
|
||||||
|
hostname: example.com
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
group: "core"
|
||||||
|
kind: "Secret"
|
||||||
|
name: "mysecret"
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: footls
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: HTTPRoute
|
kind: HTTPRoute
|
||||||
|
@ -55,3 +92,33 @@ spec:
|
||||||
name: myservice@file
|
name: myservice@file
|
||||||
weight: 1
|
weight: 1
|
||||||
port: 80
|
port: 80
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: footcp
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: footls
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
|
|
@ -9,6 +9,8 @@ Dynamic configuration with Kubernetes Gateway provider.
|
||||||
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_gatewayclasses.yaml"
|
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_gatewayclasses.yaml"
|
||||||
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_gateways.yaml"
|
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_gateways.yaml"
|
||||||
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_httproutes.yaml"
|
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_httproutes.yaml"
|
||||||
|
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_tcproutes.yaml"
|
||||||
|
--8<-- "content/reference/dynamic-configuration/networking.x-k8s.io_tlsroutes.yaml"
|
||||||
```
|
```
|
||||||
|
|
||||||
## Resources
|
## Resources
|
||||||
|
|
|
@ -0,0 +1,254 @@
|
||||||
|
|
||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
controller-gen.kubebuilder.io/version: v0.4.1
|
||||||
|
creationTimestamp: null
|
||||||
|
name: tcproutes.networking.x-k8s.io
|
||||||
|
spec:
|
||||||
|
group: networking.x-k8s.io
|
||||||
|
names:
|
||||||
|
kind: TCPRoute
|
||||||
|
listKind: TCPRouteList
|
||||||
|
plural: tcproutes
|
||||||
|
singular: tcproute
|
||||||
|
scope: Namespaced
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
description: TCPRoute is the Schema for the TCPRoute resource.
|
||||||
|
properties:
|
||||||
|
apiVersion:
|
||||||
|
description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
|
||||||
|
type: string
|
||||||
|
metadata:
|
||||||
|
type: object
|
||||||
|
spec:
|
||||||
|
description: Spec defines the desired state of TCPRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
default:
|
||||||
|
allow: SameNamespace
|
||||||
|
description: Gateways defines which Gateways can use this Route.
|
||||||
|
properties:
|
||||||
|
allow:
|
||||||
|
default: SameNamespace
|
||||||
|
description: 'Allow indicates which Gateways will be allowed to use this route. Possible values are: * All: Gateways in any namespace can use this route. * FromList: Only Gateways specified in GatewayRefs may use this route. * SameNamespace: Only Gateways in the same namespace may use this route.'
|
||||||
|
enum:
|
||||||
|
- All
|
||||||
|
- FromList
|
||||||
|
- SameNamespace
|
||||||
|
type: string
|
||||||
|
gatewayRefs:
|
||||||
|
description: GatewayRefs must be specified when Allow is set to "FromList". In that case, only Gateways referenced in this list will be allowed to use this route. This field is ignored for other values of "Allow".
|
||||||
|
items:
|
||||||
|
description: GatewayReference identifies a Gateway in a specified namespace.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
type: object
|
||||||
|
rules:
|
||||||
|
description: Rules are a list of TCP matchers and actions.
|
||||||
|
items:
|
||||||
|
description: TCPRouteRule is the configuration for a given rule.
|
||||||
|
properties:
|
||||||
|
forwardTo:
|
||||||
|
description: ForwardTo defines the backend(s) where matching requests should be sent.
|
||||||
|
items:
|
||||||
|
description: RouteForwardTo defines how a Route should forward a request.
|
||||||
|
properties:
|
||||||
|
backendRef:
|
||||||
|
description: "BackendRef is a reference to a backend to forward matched requests to. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
port:
|
||||||
|
description: "Port specifies the destination port number to use for the backend referenced by the ServiceName or BackendRef field. If unspecified, the destination port in the request is used when forwarding to a backendRef or serviceName. \n Support: Core"
|
||||||
|
format: int32
|
||||||
|
maximum: 65535
|
||||||
|
minimum: 1
|
||||||
|
type: integer
|
||||||
|
serviceName:
|
||||||
|
description: "ServiceName refers to the name of the Service to forward matched requests to. When specified, this takes the place of BackendRef. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n The protocol to use is defined using AppProtocol field (introduced in Kubernetes 1.18) in the Service resource. In the absence of the AppProtocol field a `networking.x-k8s.io/app-protocol` annotation on the BackendPolicy resource may be used to define the protocol. If the AppProtocol field is available, this annotation should not be used. The AppProtocol field, when populated, takes precedence over the annotation in the BackendPolicy resource. For custom backends, it is encouraged to add a semantically-equivalent field in the Custom Resource Definition. \n Support: Core"
|
||||||
|
maxLength: 253
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
default: 1
|
||||||
|
description: "Weight specifies the proportion of HTTP requests forwarded to the backend referenced by the ServiceName or BackendRef field. This is computed as weight/(sum of all weights in this ForwardTo list). For non-zero values, there may be some epsilon from the exact proportion defined here depending on the precision an implementation supports. Weight is not a percentage and the sum of weights does not need to equal 100. \n If only one backend is specified and it has a weight greater than 0, 100% of the traffic is forwarded to that backend. If weight is set to 0, no traffic should be forwarded for this entry. If unspecified, weight defaults to 1. \n Support: Extended"
|
||||||
|
format: int32
|
||||||
|
maximum: 1000000
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
matches:
|
||||||
|
description: Matches define conditions used for matching the rule against incoming TCP connections. Each match is independent, i.e. this rule will be matched if **any** one of the matches is satisfied. If unspecified, all requests from the associated gateway TCP listener will match.
|
||||||
|
items:
|
||||||
|
description: TCPRouteMatch defines the predicate used to match connections to a given action.
|
||||||
|
properties:
|
||||||
|
extensionRef:
|
||||||
|
description: "ExtensionRef is an optional, implementation-specific extension to the \"match\" behavior. For example, resource \"mytcproutematcher\" in group \"networking.acme.io\". If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- forwardTo
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- rules
|
||||||
|
type: object
|
||||||
|
status:
|
||||||
|
description: Status defines the current state of TCPRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
description: "Gateways is a list of Gateways that are associated with the route, and the status of the route with respect to each Gateway. When a Gateway selects this route, the controller that manages the Gateway must add an entry to this list when the controller first sees the route and should update the entry as appropriate when the route is modified. \n A maximum of 100 Gateways will be represented in this list. If this list is full, there may be additional Gateways using this Route that are not included in the list. An empty list means the route has not been admitted by any Gateway."
|
||||||
|
items:
|
||||||
|
description: RouteGatewayStatus describes the status of a route with respect to an associated Gateway.
|
||||||
|
properties:
|
||||||
|
conditions:
|
||||||
|
description: Conditions describes the status of the route with respect to the Gateway. The "Admitted" condition must always be specified by controllers to indicate whether the route has been admitted or rejected by the Gateway, and why. Note that the route's availability is also subject to the Gateway's own status conditions and listener status.
|
||||||
|
items:
|
||||||
|
description: "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }"
|
||||||
|
properties:
|
||||||
|
lastTransitionTime:
|
||||||
|
description: lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.
|
||||||
|
format: date-time
|
||||||
|
type: string
|
||||||
|
message:
|
||||||
|
description: message is a human readable message indicating details about the transition. This may be an empty string.
|
||||||
|
maxLength: 32768
|
||||||
|
type: string
|
||||||
|
observedGeneration:
|
||||||
|
description: observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.
|
||||||
|
format: int64
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
reason:
|
||||||
|
description: reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.
|
||||||
|
maxLength: 1024
|
||||||
|
minLength: 1
|
||||||
|
pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
description: status of the condition, one of True, False, Unknown.
|
||||||
|
enum:
|
||||||
|
- "True"
|
||||||
|
- "False"
|
||||||
|
- Unknown
|
||||||
|
type: string
|
||||||
|
type:
|
||||||
|
description: type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
|
||||||
|
maxLength: 316
|
||||||
|
pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- lastTransitionTime
|
||||||
|
- message
|
||||||
|
- reason
|
||||||
|
- status
|
||||||
|
- type
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
x-kubernetes-list-map-keys:
|
||||||
|
- type
|
||||||
|
x-kubernetes-list-type: map
|
||||||
|
gatewayRef:
|
||||||
|
description: GatewayRef is a reference to a Gateway object that is associated with the route.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- gatewayRef
|
||||||
|
type: object
|
||||||
|
maxItems: 100
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- gateways
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
subresources:
|
||||||
|
status: {}
|
||||||
|
status:
|
||||||
|
acceptedNames:
|
||||||
|
kind: ""
|
||||||
|
plural: ""
|
||||||
|
conditions: []
|
||||||
|
storedVersions: []
|
|
@ -0,0 +1,263 @@
|
||||||
|
|
||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
controller-gen.kubebuilder.io/version: v0.4.1
|
||||||
|
creationTimestamp: null
|
||||||
|
name: tlsroutes.networking.x-k8s.io
|
||||||
|
spec:
|
||||||
|
group: networking.x-k8s.io
|
||||||
|
names:
|
||||||
|
kind: TLSRoute
|
||||||
|
listKind: TLSRouteList
|
||||||
|
plural: tlsroutes
|
||||||
|
singular: tlsroute
|
||||||
|
scope: Namespaced
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
description: "The TLSRoute resource is similar to TCPRoute, but can be configured to match against TLS-specific metadata. This allows more flexibility in matching streams for a given TLS listener. \n If you need to forward traffic to a single target for a TLS listener, you could choose to use a TCPRoute with a TLS listener."
|
||||||
|
properties:
|
||||||
|
apiVersion:
|
||||||
|
description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
|
||||||
|
type: string
|
||||||
|
metadata:
|
||||||
|
type: object
|
||||||
|
spec:
|
||||||
|
description: Spec defines the desired state of TLSRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
default:
|
||||||
|
allow: SameNamespace
|
||||||
|
description: Gateways defines which Gateways can use this Route.
|
||||||
|
properties:
|
||||||
|
allow:
|
||||||
|
default: SameNamespace
|
||||||
|
description: 'Allow indicates which Gateways will be allowed to use this route. Possible values are: * All: Gateways in any namespace can use this route. * FromList: Only Gateways specified in GatewayRefs may use this route. * SameNamespace: Only Gateways in the same namespace may use this route.'
|
||||||
|
enum:
|
||||||
|
- All
|
||||||
|
- FromList
|
||||||
|
- SameNamespace
|
||||||
|
type: string
|
||||||
|
gatewayRefs:
|
||||||
|
description: GatewayRefs must be specified when Allow is set to "FromList". In that case, only Gateways referenced in this list will be allowed to use this route. This field is ignored for other values of "Allow".
|
||||||
|
items:
|
||||||
|
description: GatewayReference identifies a Gateway in a specified namespace.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
type: object
|
||||||
|
rules:
|
||||||
|
description: Rules are a list of TLS matchers and actions.
|
||||||
|
items:
|
||||||
|
description: TLSRouteRule is the configuration for a given rule.
|
||||||
|
properties:
|
||||||
|
forwardTo:
|
||||||
|
description: ForwardTo defines the backend(s) where matching requests should be sent.
|
||||||
|
items:
|
||||||
|
description: RouteForwardTo defines how a Route should forward a request.
|
||||||
|
properties:
|
||||||
|
backendRef:
|
||||||
|
description: "BackendRef is a reference to a backend to forward matched requests to. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
port:
|
||||||
|
description: "Port specifies the destination port number to use for the backend referenced by the ServiceName or BackendRef field. If unspecified, the destination port in the request is used when forwarding to a backendRef or serviceName. \n Support: Core"
|
||||||
|
format: int32
|
||||||
|
maximum: 65535
|
||||||
|
minimum: 1
|
||||||
|
type: integer
|
||||||
|
serviceName:
|
||||||
|
description: "ServiceName refers to the name of the Service to forward matched requests to. When specified, this takes the place of BackendRef. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n The protocol to use is defined using AppProtocol field (introduced in Kubernetes 1.18) in the Service resource. In the absence of the AppProtocol field a `networking.x-k8s.io/app-protocol` annotation on the BackendPolicy resource may be used to define the protocol. If the AppProtocol field is available, this annotation should not be used. The AppProtocol field, when populated, takes precedence over the annotation in the BackendPolicy resource. For custom backends, it is encouraged to add a semantically-equivalent field in the Custom Resource Definition. \n Support: Core"
|
||||||
|
maxLength: 253
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
default: 1
|
||||||
|
description: "Weight specifies the proportion of HTTP requests forwarded to the backend referenced by the ServiceName or BackendRef field. This is computed as weight/(sum of all weights in this ForwardTo list). For non-zero values, there may be some epsilon from the exact proportion defined here depending on the precision an implementation supports. Weight is not a percentage and the sum of weights does not need to equal 100. \n If only one backend is specified and it has a weight greater than 0, 100% of the traffic is forwarded to that backend. If weight is set to 0, no traffic should be forwarded for this entry. If unspecified, weight defaults to 1. \n Support: Extended"
|
||||||
|
format: int32
|
||||||
|
maximum: 1000000
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
matches:
|
||||||
|
description: Matches define conditions used for matching the rule against an incoming TLS handshake. Each match is independent, i.e. this rule will be matched if **any** one of the matches is satisfied. If unspecified, all requests from the associated gateway TLS listener will match.
|
||||||
|
items:
|
||||||
|
description: TLSRouteMatch defines the predicate used to match connections to a given action.
|
||||||
|
properties:
|
||||||
|
extensionRef:
|
||||||
|
description: "ExtensionRef is an optional, implementation-specific extension to the \"match\" behavior. For example, resource \"mytlsroutematcher\" in group \"networking.acme.io\". If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
snis:
|
||||||
|
description: "SNIs defines a set of SNI names that should match against the SNI attribute of TLS ClientHello message in TLS handshake. \n SNI can be \"precise\" which is a domain name without the terminating dot of a network host (e.g. \"foo.example.com\") or \"wildcard\", which is a domain name prefixed with a single wildcard label (e.g. `*.example.com`). The wildcard character `*` must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == `*`). \n Requests will be matched against the Host field in the following order: \n 1. If SNI is precise, the request matches this rule if the SNI in ClientHello is equal to one of the defined SNIs. 2. If SNI is a wildcard, then the request matches this rule if the SNI is to equal to the suffix (removing the first label) of the wildcard rule. 3. If SNIs is unspecified, all requests associated with the gateway TLS listener will match. This can be used to define a default backend for a TLS listener. \n Support: Core"
|
||||||
|
items:
|
||||||
|
description: Hostname is used to specify a hostname that should be matched.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
maxItems: 16
|
||||||
|
type: array
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- forwardTo
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- rules
|
||||||
|
type: object
|
||||||
|
status:
|
||||||
|
description: Status defines the current state of TLSRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
description: "Gateways is a list of Gateways that are associated with the route, and the status of the route with respect to each Gateway. When a Gateway selects this route, the controller that manages the Gateway must add an entry to this list when the controller first sees the route and should update the entry as appropriate when the route is modified. \n A maximum of 100 Gateways will be represented in this list. If this list is full, there may be additional Gateways using this Route that are not included in the list. An empty list means the route has not been admitted by any Gateway."
|
||||||
|
items:
|
||||||
|
description: RouteGatewayStatus describes the status of a route with respect to an associated Gateway.
|
||||||
|
properties:
|
||||||
|
conditions:
|
||||||
|
description: Conditions describes the status of the route with respect to the Gateway. The "Admitted" condition must always be specified by controllers to indicate whether the route has been admitted or rejected by the Gateway, and why. Note that the route's availability is also subject to the Gateway's own status conditions and listener status.
|
||||||
|
items:
|
||||||
|
description: "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }"
|
||||||
|
properties:
|
||||||
|
lastTransitionTime:
|
||||||
|
description: lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.
|
||||||
|
format: date-time
|
||||||
|
type: string
|
||||||
|
message:
|
||||||
|
description: message is a human readable message indicating details about the transition. This may be an empty string.
|
||||||
|
maxLength: 32768
|
||||||
|
type: string
|
||||||
|
observedGeneration:
|
||||||
|
description: observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.
|
||||||
|
format: int64
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
reason:
|
||||||
|
description: reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.
|
||||||
|
maxLength: 1024
|
||||||
|
minLength: 1
|
||||||
|
pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
description: status of the condition, one of True, False, Unknown.
|
||||||
|
enum:
|
||||||
|
- "True"
|
||||||
|
- "False"
|
||||||
|
- Unknown
|
||||||
|
type: string
|
||||||
|
type:
|
||||||
|
description: type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
|
||||||
|
maxLength: 316
|
||||||
|
pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- lastTransitionTime
|
||||||
|
- message
|
||||||
|
- reason
|
||||||
|
- status
|
||||||
|
- type
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
x-kubernetes-list-map-keys:
|
||||||
|
- type
|
||||||
|
x-kubernetes-list-type: map
|
||||||
|
gatewayRef:
|
||||||
|
description: GatewayRef is a reference to a Gateway object that is associated with the route.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- gatewayRef
|
||||||
|
type: object
|
||||||
|
maxItems: 100
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- gateways
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
subresources:
|
||||||
|
status: {}
|
||||||
|
status:
|
||||||
|
acceptedNames:
|
||||||
|
kind: ""
|
||||||
|
plural: ""
|
||||||
|
conditions: []
|
||||||
|
storedVersions: []
|
|
@ -34,10 +34,12 @@ The Kubernetes Gateway API, The Experimental Way.
|
||||||
You can find an excerpt of the supported Kubernetes Gateway API resources in the table below:
|
You can find an excerpt of the supported Kubernetes Gateway API resources in the table below:
|
||||||
|
|
||||||
| Kind | Purpose | Concept Behind |
|
| Kind | Purpose | Concept Behind |
|
||||||
|------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------|
|
|------------------------------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
|
||||||
| [GatewayClass](#kind-gatewayclass) | Defines a set of Gateways that share a common configuration and behaviour | [GatewayClass](https://gateway-api.sigs.k8s.io/api-types/gatewayclass) |
|
| [GatewayClass](#kind-gatewayclass) | Defines a set of Gateways that share a common configuration and behaviour | [GatewayClass](https://gateway-api.sigs.k8s.io/api-types/gatewayclass) |
|
||||||
| [Gateway](#kind-gateway) | Describes how traffic can be translated to Services within the cluster | [Gateway](https://gateway-api.sigs.k8s.io/api-types/gateway) |
|
| [Gateway](#kind-gateway) | Describes how traffic can be translated to Services within the cluster | [Gateway](https://gateway-api.sigs.k8s.io/api-types/gateway) |
|
||||||
| [HTTPRoute](#kind-httproute) | HTTP rules for mapping requests from a Gateway to Kubernetes Services | [Route](https://gateway-api.sigs.k8s.io/api-types/httproute) |
|
| [HTTPRoute](#kind-httproute) | HTTP rules for mapping requests from a Gateway to Kubernetes Services | [Route](https://gateway-api.sigs.k8s.io/api-types/httproute) |
|
||||||
|
| [TCPRoute](#kind-tcproute) | Allows mapping TCP requests from a Gateway to Kubernetes Services | [Route](https://gateway-api.sigs.k8s.io/concepts/api-overview/#httptcpfooroute) |
|
||||||
|
| [TLSRoute](#kind-tlsroute) | Allows mapping TLS requests from a Gateway to Kubernetes Services | [Route](https://gateway-api.sigs.k8s.io/concepts/api-overview/#httptcpfooroute) |
|
||||||
|
|
||||||
### Kind: `GatewayClass`
|
### Kind: `GatewayClass`
|
||||||
|
|
||||||
|
@ -70,43 +72,114 @@ More details on the Gateway [official documentation](https://gateway-api.sigs.k8
|
||||||
Register the `Gateway` [definition](../../reference/dynamic-configuration/kubernetes-gateway.md#definitions) in the
|
Register the `Gateway` [definition](../../reference/dynamic-configuration/kubernetes-gateway.md#definitions) in the
|
||||||
Kubernetes cluster before creating `Gateway` objects.
|
Kubernetes cluster before creating `Gateway` objects.
|
||||||
|
|
||||||
|
Depending on the Listener Protocol, different modes and Route types are supported.
|
||||||
|
|
||||||
|
| Listener Protocol | TLS Mode | Route Type Supported |
|
||||||
|
|-------------------|----------------|------------------------------|
|
||||||
|
| TCP | Not applicable | [TCPRoute](#kind-tcproute) |
|
||||||
|
| TLS | Passthrough | [TLSRoute](#kind-tlsroute) |
|
||||||
|
| TLS | Terminate | [TCPRoute](#kind-tcproute) |
|
||||||
|
| HTTP | Not applicable | [HTTPRoute](#kind-httproute) |
|
||||||
|
| HTTPS | Terminate | [HTTPRoute](#kind-httproute) |
|
||||||
|
|
||||||
!!! info "Declaring Gateway"
|
!!! info "Declaring Gateway"
|
||||||
|
|
||||||
```
|
```yaml tab="HTTP Listener"
|
||||||
kind: Gateway
|
kind: Gateway
|
||||||
apiVersion: networking.x-k8s.io/v1alpha1
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
metadata:
|
metadata:
|
||||||
name: my-gateway
|
name: my-http-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class # [1]
|
||||||
|
listeners: # [2]
|
||||||
|
- protocol: HTTP # [3]
|
||||||
|
port: 80 # [4]
|
||||||
|
routes: # [8]
|
||||||
|
kind: HTTPRoute # [9]
|
||||||
|
selector: # [10]
|
||||||
|
matchLabels: # [11]
|
||||||
|
app: foo
|
||||||
|
```
|
||||||
|
|
||||||
|
```yaml tab="HTTPS Listener"
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-https-gateway
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
gatewayClassName: my-gateway-class # [1]
|
gatewayClassName: my-gateway-class # [1]
|
||||||
listeners: # [2]
|
listeners: # [2]
|
||||||
- protocol: HTTPS # [3]
|
- protocol: HTTPS # [3]
|
||||||
port: 443 # [4]
|
port: 443 # [4]
|
||||||
tls: # [5]
|
tls: # [6]
|
||||||
certificateRef: # [6]
|
certificateRef: # [7]
|
||||||
group: "core"
|
group: "core"
|
||||||
kind: "Secret"
|
kind: "Secret"
|
||||||
name: "mysecret"
|
name: "mysecret"
|
||||||
routes: # [7]
|
routes: # [8]
|
||||||
kind: HTTPRoute # [8]
|
kind: HTTPRoute # [9]
|
||||||
selector: # [9]
|
selector: # [10]
|
||||||
matchLabels: # [10]
|
matchLabels: # [11]
|
||||||
app: foo
|
app: foo
|
||||||
```
|
```
|
||||||
|
|
||||||
|
```yaml tab="TCP Listener"
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tcp-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class # [1]
|
||||||
|
listeners: # [2]
|
||||||
|
- protocol: TCP # [3]
|
||||||
|
port: 8000 # [4]
|
||||||
|
routes: # [8]
|
||||||
|
kind: TCPRoute # [9]
|
||||||
|
selector: # [10]
|
||||||
|
matchLabels: # [11]
|
||||||
|
app: footcp
|
||||||
|
```
|
||||||
|
|
||||||
|
```yaml tab="TLS Listener"
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tls-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class # [1]
|
||||||
|
listeners: # [2]
|
||||||
|
- protocol: TLS # [3]
|
||||||
|
port: 443 # [4]
|
||||||
|
hostname: foo.com # [5]
|
||||||
|
tls: # [6]
|
||||||
|
certificateRef: # [7]
|
||||||
|
group: "core"
|
||||||
|
kind: "Secret"
|
||||||
|
name: "mysecret"
|
||||||
|
routes: # [8]
|
||||||
|
kind: TLSRoute # [9]
|
||||||
|
selector: # [10]
|
||||||
|
matchLabels: # [11]
|
||||||
|
app: footcp
|
||||||
|
```
|
||||||
|
|
||||||
| Ref | Attribute | Description |
|
| Ref | Attribute | Description |
|
||||||
|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------|
|
|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||||||
| [1] | `gatewayClassName` | GatewayClassName used for this Gateway. This is the name of a GatewayClass resource. |
|
| [1] | `gatewayClassName` | GatewayClassName used for this Gateway. This is the name of a GatewayClass resource. |
|
||||||
| [2] | `listeners` | Logical endpoints that are bound on this Gateway's addresses. At least one Listener MUST be specified. |
|
| [2] | `listeners` | Logical endpoints that are bound on this Gateway's addresses. At least one Listener MUST be specified. |
|
||||||
| [3] | `protocol` | The network protocol this listener expects to receive (only HTTP and HTTPS are implemented). |
|
| [3] | `protocol` | The network protocol this listener expects to receive (only HTTP and HTTPS are implemented). |
|
||||||
| [4] | `port` | The network port. |
|
| [4] | `port` | The network port. |
|
||||||
| [5] | `tls` | TLS configuration for the Listener. This field is required if the Protocol field is "HTTPS" or "TLS" and ignored otherwise. |
|
| [5] | `hostname` | Hostname specifies the virtual hostname to match for protocol types that define this concept. When unspecified, “”, or *, all hostnames are matched. |
|
||||||
| [6] | `certificateRef` | The reference to Kubernetes object that contains a TLS certificate and private key. |
|
| [6] | `tls` | TLS configuration for the Listener. This field is required if the Protocol field is "HTTPS" or "TLS" and ignored otherwise. |
|
||||||
| [7] | `routes` | A schema for associating routes with the Listener using selectors. |
|
| [7] | `certificateRef` | The reference to Kubernetes object that contains a TLS certificate and private key. |
|
||||||
| [8] | `kind` | The kind of the referent. |
|
| [8] | `routes` | A schema for associating routes with the Listener using selectors. |
|
||||||
| [9] | `selector` | Routes in namespaces selected by the selector may be used by this Gateway routes to associate with the Gateway. |
|
| [9] | `kind` | The kind of the referent. |
|
||||||
| [10] | `matchLabels` | A set of route labels used for selecting routes to associate with the Gateway. |
|
| [10] | `selector` | Routes in namespaces selected by the selector may be used by this Gateway routes to associate with the Gateway. |
|
||||||
|
| [11] | `matchLabels` | A set of route labels used for selecting routes to associate with the Gateway. |
|
||||||
|
|
||||||
### Kind: `HTTPRoute`
|
### Kind: `HTTPRoute`
|
||||||
|
|
||||||
|
@ -150,7 +223,7 @@ Kubernetes cluster before creating `HTTPRoute` objects.
|
||||||
```
|
```
|
||||||
|
|
||||||
| Ref | Attribute | Description |
|
| Ref | Attribute | Description |
|
||||||
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||||||
| [1] | `labels` | Labels to match with the `Gateway` labelselector. |
|
| [1] | `labels` | Labels to match with the `Gateway` labelselector. |
|
||||||
| [2] | `hostnames` | A set of hostname that should match against the HTTP Host header to select a HTTPRoute to process the request. |
|
| [2] | `hostnames` | A set of hostname that should match against the HTTP Host header to select a HTTPRoute to process the request. |
|
||||||
| [3] | `rules` | A list of HTTP matchers, filters and actions. |
|
| [3] | `rules` | A list of HTTP matchers, filters and actions. |
|
||||||
|
@ -169,3 +242,87 @@ Kubernetes cluster before creating `HTTPRoute` objects.
|
||||||
| [16] | `group` | Group is the group of the referent. Only `traefik.containo.us` value is supported. |
|
| [16] | `group` | Group is the group of the referent. Only `traefik.containo.us` value is supported. |
|
||||||
| [17] | `kind` | Kind is kind of the referent. Only `TraefikService` value is supported. |
|
| [17] | `kind` | Kind is kind of the referent. Only `TraefikService` value is supported. |
|
||||||
| [18] | `name` | Name is the name of the referent. |
|
| [18] | `name` | Name is the name of the referent. |
|
||||||
|
|
||||||
|
### Kind: `TCPRoute`
|
||||||
|
|
||||||
|
`TCPRoute` allows mapping TCP requests from a `Gateway` to Kubernetes Services
|
||||||
|
|
||||||
|
Register the `TCPRoute` [definition](../../reference/dynamic-configuration/kubernetes-gateway.md#definitions) in the
|
||||||
|
Kubernetes cluster before creating `TCPRoute` objects.
|
||||||
|
|
||||||
|
!!! info "Declaring TCPRoute"
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels: # [1]
|
||||||
|
app: tcp-app-1
|
||||||
|
spec:
|
||||||
|
rules: # [2]
|
||||||
|
- forwardTo: # [3]
|
||||||
|
- serviceName: whoamitcp # [4]
|
||||||
|
weight: 1 # [5]
|
||||||
|
port: 8080 # [6]
|
||||||
|
- backendRef: # [7]
|
||||||
|
group: traefik.containo.us # [8]
|
||||||
|
kind: TraefikService # [9]
|
||||||
|
name: api@internal # [10]
|
||||||
|
```
|
||||||
|
|
||||||
|
| Ref | Attribute | Description |
|
||||||
|
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||||||
|
| [1] | `labels` | Labels to match with the `Gateway` labelselector. |
|
||||||
|
| [2] | `rules` | Rules are a list of TCP matchers and actions. |
|
||||||
|
| [3] | `forwardTo` | The upstream target(s) where the request should be sent. |
|
||||||
|
| [4] | `serviceName` | The name of the referent service. |
|
||||||
|
| [5] | `weight` | The proportion of traffic forwarded to a targetRef, computed as weight/(sum of all weights in targetRefs). |
|
||||||
|
| [6] | `port` | The port of the referent service. |
|
||||||
|
| [7] | `backendRef` | The BackendRef is a reference to a backend (API object within a known namespace) to forward matched requests to. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. Only `TraefikService` is supported. |
|
||||||
|
| [8] | `group` | Group is the group of the referent. Only `traefik.containo.us` value is supported. |
|
||||||
|
| [9] | `kind` | Kind is kind of the referent. Only `TraefikService` value is supported. |
|
||||||
|
| [10] | `name` | Name is the name of the referent. |
|
||||||
|
|
||||||
|
### Kind: `TLSRoute`
|
||||||
|
|
||||||
|
`TLSRoute` allows mapping TLS requests from a `Gateway` to Kubernetes Services
|
||||||
|
|
||||||
|
Register the `TLSRoute` [definition](../../reference/dynamic-configuration/kubernetes-gateway.md#definitions) in the
|
||||||
|
Kubernetes cluster before creating `TLSRoute` objects.
|
||||||
|
|
||||||
|
!!! info "Declaring TCPRoute"
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels: # [1]
|
||||||
|
app: tls-app-1
|
||||||
|
spec:
|
||||||
|
rules: # [2]
|
||||||
|
- forwardTo: # [3]
|
||||||
|
- serviceName: whoamitcp # [4]
|
||||||
|
weight: 1 # [5]
|
||||||
|
port: 8080 # [6]
|
||||||
|
- backendRef: # [7]
|
||||||
|
group: traefik.containo.us # [8]
|
||||||
|
kind: TraefikService # [9]
|
||||||
|
name: api@internal # [10]
|
||||||
|
```
|
||||||
|
|
||||||
|
| Ref | Attribute | Description |
|
||||||
|
|------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||||||
|
| [1] | `labels` | Labels to match with the `Gateway` labelselector. |
|
||||||
|
| [2] | `rules` | Rules are a list of TCP matchers and actions. |
|
||||||
|
| [3] | `forwardTo` | The upstream target(s) where the request should be sent. |
|
||||||
|
| [4] | `serviceName` | The name of the referent service. |
|
||||||
|
| [5] | `weight` | The proportion of traffic forwarded to a targetRef, computed as weight/(sum of all weights in targetRefs). |
|
||||||
|
| [6] | `port` | The port of the referent service. |
|
||||||
|
| [7] | `backendRef` | The BackendRef is a reference to a backend (API object within a known namespace) to forward matched requests to. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. Only `TraefikService` is supported. |
|
||||||
|
| [8] | `group` | Group is the group of the referent. Only `traefik.containo.us` value is supported. |
|
||||||
|
| [9] | `kind` | Kind is kind of the referent. Only `TraefikService` value is supported. |
|
||||||
|
| [10] | `name` | Name is the name of the referent. |
|
||||||
|
|
|
@ -1104,3 +1104,519 @@ status:
|
||||||
plural: ""
|
plural: ""
|
||||||
conditions: []
|
conditions: []
|
||||||
storedVersions: []
|
storedVersions: []
|
||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
controller-gen.kubebuilder.io/version: v0.4.1
|
||||||
|
creationTimestamp: null
|
||||||
|
name: tcproutes.networking.x-k8s.io
|
||||||
|
spec:
|
||||||
|
group: networking.x-k8s.io
|
||||||
|
names:
|
||||||
|
kind: TCPRoute
|
||||||
|
listKind: TCPRouteList
|
||||||
|
plural: tcproutes
|
||||||
|
singular: tcproute
|
||||||
|
scope: Namespaced
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
description: TCPRoute is the Schema for the TCPRoute resource.
|
||||||
|
properties:
|
||||||
|
apiVersion:
|
||||||
|
description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
|
||||||
|
type: string
|
||||||
|
metadata:
|
||||||
|
type: object
|
||||||
|
spec:
|
||||||
|
description: Spec defines the desired state of TCPRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
default:
|
||||||
|
allow: SameNamespace
|
||||||
|
description: Gateways defines which Gateways can use this Route.
|
||||||
|
properties:
|
||||||
|
allow:
|
||||||
|
default: SameNamespace
|
||||||
|
description: 'Allow indicates which Gateways will be allowed to use this route. Possible values are: * All: Gateways in any namespace can use this route. * FromList: Only Gateways specified in GatewayRefs may use this route. * SameNamespace: Only Gateways in the same namespace may use this route.'
|
||||||
|
enum:
|
||||||
|
- All
|
||||||
|
- FromList
|
||||||
|
- SameNamespace
|
||||||
|
type: string
|
||||||
|
gatewayRefs:
|
||||||
|
description: GatewayRefs must be specified when Allow is set to "FromList". In that case, only Gateways referenced in this list will be allowed to use this route. This field is ignored for other values of "Allow".
|
||||||
|
items:
|
||||||
|
description: GatewayReference identifies a Gateway in a specified namespace.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
type: object
|
||||||
|
rules:
|
||||||
|
description: Rules are a list of TCP matchers and actions.
|
||||||
|
items:
|
||||||
|
description: TCPRouteRule is the configuration for a given rule.
|
||||||
|
properties:
|
||||||
|
forwardTo:
|
||||||
|
description: ForwardTo defines the backend(s) where matching requests should be sent.
|
||||||
|
items:
|
||||||
|
description: RouteForwardTo defines how a Route should forward a request.
|
||||||
|
properties:
|
||||||
|
backendRef:
|
||||||
|
description: "BackendRef is a reference to a backend to forward matched requests to. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
port:
|
||||||
|
description: "Port specifies the destination port number to use for the backend referenced by the ServiceName or BackendRef field. If unspecified, the destination port in the request is used when forwarding to a backendRef or serviceName. \n Support: Core"
|
||||||
|
format: int32
|
||||||
|
maximum: 65535
|
||||||
|
minimum: 1
|
||||||
|
type: integer
|
||||||
|
serviceName:
|
||||||
|
description: "ServiceName refers to the name of the Service to forward matched requests to. When specified, this takes the place of BackendRef. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n The protocol to use is defined using AppProtocol field (introduced in Kubernetes 1.18) in the Service resource. In the absence of the AppProtocol field a `networking.x-k8s.io/app-protocol` annotation on the BackendPolicy resource may be used to define the protocol. If the AppProtocol field is available, this annotation should not be used. The AppProtocol field, when populated, takes precedence over the annotation in the BackendPolicy resource. For custom backends, it is encouraged to add a semantically-equivalent field in the Custom Resource Definition. \n Support: Core"
|
||||||
|
maxLength: 253
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
default: 1
|
||||||
|
description: "Weight specifies the proportion of HTTP requests forwarded to the backend referenced by the ServiceName or BackendRef field. This is computed as weight/(sum of all weights in this ForwardTo list). For non-zero values, there may be some epsilon from the exact proportion defined here depending on the precision an implementation supports. Weight is not a percentage and the sum of weights does not need to equal 100. \n If only one backend is specified and it has a weight greater than 0, 100% of the traffic is forwarded to that backend. If weight is set to 0, no traffic should be forwarded for this entry. If unspecified, weight defaults to 1. \n Support: Extended"
|
||||||
|
format: int32
|
||||||
|
maximum: 1000000
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
matches:
|
||||||
|
description: Matches define conditions used for matching the rule against incoming TCP connections. Each match is independent, i.e. this rule will be matched if **any** one of the matches is satisfied. If unspecified, all requests from the associated gateway TCP listener will match.
|
||||||
|
items:
|
||||||
|
description: TCPRouteMatch defines the predicate used to match connections to a given action.
|
||||||
|
properties:
|
||||||
|
extensionRef:
|
||||||
|
description: "ExtensionRef is an optional, implementation-specific extension to the \"match\" behavior. For example, resource \"mytcproutematcher\" in group \"networking.acme.io\". If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- forwardTo
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- rules
|
||||||
|
type: object
|
||||||
|
status:
|
||||||
|
description: Status defines the current state of TCPRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
description: "Gateways is a list of Gateways that are associated with the route, and the status of the route with respect to each Gateway. When a Gateway selects this route, the controller that manages the Gateway must add an entry to this list when the controller first sees the route and should update the entry as appropriate when the route is modified. \n A maximum of 100 Gateways will be represented in this list. If this list is full, there may be additional Gateways using this Route that are not included in the list. An empty list means the route has not been admitted by any Gateway."
|
||||||
|
items:
|
||||||
|
description: RouteGatewayStatus describes the status of a route with respect to an associated Gateway.
|
||||||
|
properties:
|
||||||
|
conditions:
|
||||||
|
description: Conditions describes the status of the route with respect to the Gateway. The "Admitted" condition must always be specified by controllers to indicate whether the route has been admitted or rejected by the Gateway, and why. Note that the route's availability is also subject to the Gateway's own status conditions and listener status.
|
||||||
|
items:
|
||||||
|
description: "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }"
|
||||||
|
properties:
|
||||||
|
lastTransitionTime:
|
||||||
|
description: lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.
|
||||||
|
format: date-time
|
||||||
|
type: string
|
||||||
|
message:
|
||||||
|
description: message is a human readable message indicating details about the transition. This may be an empty string.
|
||||||
|
maxLength: 32768
|
||||||
|
type: string
|
||||||
|
observedGeneration:
|
||||||
|
description: observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.
|
||||||
|
format: int64
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
reason:
|
||||||
|
description: reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.
|
||||||
|
maxLength: 1024
|
||||||
|
minLength: 1
|
||||||
|
pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
description: status of the condition, one of True, False, Unknown.
|
||||||
|
enum:
|
||||||
|
- "True"
|
||||||
|
- "False"
|
||||||
|
- Unknown
|
||||||
|
type: string
|
||||||
|
type:
|
||||||
|
description: type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
|
||||||
|
maxLength: 316
|
||||||
|
pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- lastTransitionTime
|
||||||
|
- message
|
||||||
|
- reason
|
||||||
|
- status
|
||||||
|
- type
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
x-kubernetes-list-map-keys:
|
||||||
|
- type
|
||||||
|
x-kubernetes-list-type: map
|
||||||
|
gatewayRef:
|
||||||
|
description: GatewayRef is a reference to a Gateway object that is associated with the route.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- gatewayRef
|
||||||
|
type: object
|
||||||
|
maxItems: 100
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- gateways
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
subresources:
|
||||||
|
status: {}
|
||||||
|
status:
|
||||||
|
acceptedNames:
|
||||||
|
kind: ""
|
||||||
|
plural: ""
|
||||||
|
conditions: []
|
||||||
|
storedVersions: []
|
||||||
|
|
||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
controller-gen.kubebuilder.io/version: v0.4.1
|
||||||
|
creationTimestamp: null
|
||||||
|
name: tlsroutes.networking.x-k8s.io
|
||||||
|
spec:
|
||||||
|
group: networking.x-k8s.io
|
||||||
|
names:
|
||||||
|
kind: TLSRoute
|
||||||
|
listKind: TLSRouteList
|
||||||
|
plural: tlsroutes
|
||||||
|
singular: tlsroute
|
||||||
|
scope: Namespaced
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
description: "The TLSRoute resource is similar to TCPRoute, but can be configured to match against TLS-specific metadata. This allows more flexibility in matching streams for a given TLS listener. \n If you need to forward traffic to a single target for a TLS listener, you could choose to use a TCPRoute with a TLS listener."
|
||||||
|
properties:
|
||||||
|
apiVersion:
|
||||||
|
description: 'APIVersion defines the versioned schema of this representation of an object. Servers should convert recognized schemas to the latest internal value, and may reject unrecognized values. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources'
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: 'Kind is a string value representing the REST resource this object represents. Servers may infer this from the endpoint the client submits requests to. Cannot be updated. In CamelCase. More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds'
|
||||||
|
type: string
|
||||||
|
metadata:
|
||||||
|
type: object
|
||||||
|
spec:
|
||||||
|
description: Spec defines the desired state of TLSRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
default:
|
||||||
|
allow: SameNamespace
|
||||||
|
description: Gateways defines which Gateways can use this Route.
|
||||||
|
properties:
|
||||||
|
allow:
|
||||||
|
default: SameNamespace
|
||||||
|
description: 'Allow indicates which Gateways will be allowed to use this route. Possible values are: * All: Gateways in any namespace can use this route. * FromList: Only Gateways specified in GatewayRefs may use this route. * SameNamespace: Only Gateways in the same namespace may use this route.'
|
||||||
|
enum:
|
||||||
|
- All
|
||||||
|
- FromList
|
||||||
|
- SameNamespace
|
||||||
|
type: string
|
||||||
|
gatewayRefs:
|
||||||
|
description: GatewayRefs must be specified when Allow is set to "FromList". In that case, only Gateways referenced in this list will be allowed to use this route. This field is ignored for other values of "Allow".
|
||||||
|
items:
|
||||||
|
description: GatewayReference identifies a Gateway in a specified namespace.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
type: array
|
||||||
|
type: object
|
||||||
|
rules:
|
||||||
|
description: Rules are a list of TLS matchers and actions.
|
||||||
|
items:
|
||||||
|
description: TLSRouteRule is the configuration for a given rule.
|
||||||
|
properties:
|
||||||
|
forwardTo:
|
||||||
|
description: ForwardTo defines the backend(s) where matching requests should be sent.
|
||||||
|
items:
|
||||||
|
description: RouteForwardTo defines how a Route should forward a request.
|
||||||
|
properties:
|
||||||
|
backendRef:
|
||||||
|
description: "BackendRef is a reference to a backend to forward matched requests to. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
port:
|
||||||
|
description: "Port specifies the destination port number to use for the backend referenced by the ServiceName or BackendRef field. If unspecified, the destination port in the request is used when forwarding to a backendRef or serviceName. \n Support: Core"
|
||||||
|
format: int32
|
||||||
|
maximum: 65535
|
||||||
|
minimum: 1
|
||||||
|
type: integer
|
||||||
|
serviceName:
|
||||||
|
description: "ServiceName refers to the name of the Service to forward matched requests to. When specified, this takes the place of BackendRef. If both BackendRef and ServiceName are specified, ServiceName will be given precedence. \n If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n The protocol to use is defined using AppProtocol field (introduced in Kubernetes 1.18) in the Service resource. In the absence of the AppProtocol field a `networking.x-k8s.io/app-protocol` annotation on the BackendPolicy resource may be used to define the protocol. If the AppProtocol field is available, this annotation should not be used. The AppProtocol field, when populated, takes precedence over the annotation in the BackendPolicy resource. For custom backends, it is encouraged to add a semantically-equivalent field in the Custom Resource Definition. \n Support: Core"
|
||||||
|
maxLength: 253
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
default: 1
|
||||||
|
description: "Weight specifies the proportion of HTTP requests forwarded to the backend referenced by the ServiceName or BackendRef field. This is computed as weight/(sum of all weights in this ForwardTo list). For non-zero values, there may be some epsilon from the exact proportion defined here depending on the precision an implementation supports. Weight is not a percentage and the sum of weights does not need to equal 100. \n If only one backend is specified and it has a weight greater than 0, 100% of the traffic is forwarded to that backend. If weight is set to 0, no traffic should be forwarded for this entry. If unspecified, weight defaults to 1. \n Support: Extended"
|
||||||
|
format: int32
|
||||||
|
maximum: 1000000
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
matches:
|
||||||
|
description: Matches define conditions used for matching the rule against an incoming TLS handshake. Each match is independent, i.e. this rule will be matched if **any** one of the matches is satisfied. If unspecified, all requests from the associated gateway TLS listener will match.
|
||||||
|
items:
|
||||||
|
description: TLSRouteMatch defines the predicate used to match connections to a given action.
|
||||||
|
properties:
|
||||||
|
extensionRef:
|
||||||
|
description: "ExtensionRef is an optional, implementation-specific extension to the \"match\" behavior. For example, resource \"mytlsroutematcher\" in group \"networking.acme.io\". If the referent cannot be found, the rule is not included in the route. The controller should raise the \"ResolvedRefs\" condition on the Gateway with the \"DegradedRoutes\" reason. The gateway status for this route should be updated with a condition that describes the error more specifically. \n Support: Custom"
|
||||||
|
properties:
|
||||||
|
group:
|
||||||
|
description: Group is the group of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
kind:
|
||||||
|
description: Kind is kind of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- group
|
||||||
|
- kind
|
||||||
|
- name
|
||||||
|
type: object
|
||||||
|
snis:
|
||||||
|
description: "SNIs defines a set of SNI names that should match against the SNI attribute of TLS ClientHello message in TLS handshake. \n SNI can be \"precise\" which is a domain name without the terminating dot of a network host (e.g. \"foo.example.com\") or \"wildcard\", which is a domain name prefixed with a single wildcard label (e.g. `*.example.com`). The wildcard character `*` must appear by itself as the first DNS label and matches only a single label. You cannot have a wildcard label by itself (e.g. Host == `*`). \n Requests will be matched against the Host field in the following order: \n 1. If SNI is precise, the request matches this rule if the SNI in ClientHello is equal to one of the defined SNIs. 2. If SNI is a wildcard, then the request matches this rule if the SNI is to equal to the suffix (removing the first label) of the wildcard rule. 3. If SNIs is unspecified, all requests associated with the gateway TLS listener will match. This can be used to define a default backend for a TLS listener. \n Support: Core"
|
||||||
|
items:
|
||||||
|
description: Hostname is used to specify a hostname that should be matched.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
maxItems: 16
|
||||||
|
type: array
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- forwardTo
|
||||||
|
type: object
|
||||||
|
maxItems: 16
|
||||||
|
minItems: 1
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- rules
|
||||||
|
type: object
|
||||||
|
status:
|
||||||
|
description: Status defines the current state of TLSRoute.
|
||||||
|
properties:
|
||||||
|
gateways:
|
||||||
|
description: "Gateways is a list of Gateways that are associated with the route, and the status of the route with respect to each Gateway. When a Gateway selects this route, the controller that manages the Gateway must add an entry to this list when the controller first sees the route and should update the entry as appropriate when the route is modified. \n A maximum of 100 Gateways will be represented in this list. If this list is full, there may be additional Gateways using this Route that are not included in the list. An empty list means the route has not been admitted by any Gateway."
|
||||||
|
items:
|
||||||
|
description: RouteGatewayStatus describes the status of a route with respect to an associated Gateway.
|
||||||
|
properties:
|
||||||
|
conditions:
|
||||||
|
description: Conditions describes the status of the route with respect to the Gateway. The "Admitted" condition must always be specified by controllers to indicate whether the route has been admitted or rejected by the Gateway, and why. Note that the route's availability is also subject to the Gateway's own status conditions and listener status.
|
||||||
|
items:
|
||||||
|
description: "Condition contains details for one aspect of the current state of this API Resource. --- This struct is intended for direct use as an array at the field path .status.conditions. For example, type FooStatus struct{ // Represents the observations of a foo's current state. // Known .status.conditions.type are: \"Available\", \"Progressing\", and \"Degraded\" // +patchMergeKey=type // +patchStrategy=merge // +listType=map // +listMapKey=type Conditions []metav1.Condition `json:\"conditions,omitempty\" patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"` \n // other fields }"
|
||||||
|
properties:
|
||||||
|
lastTransitionTime:
|
||||||
|
description: lastTransitionTime is the last time the condition transitioned from one status to another. This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable.
|
||||||
|
format: date-time
|
||||||
|
type: string
|
||||||
|
message:
|
||||||
|
description: message is a human readable message indicating details about the transition. This may be an empty string.
|
||||||
|
maxLength: 32768
|
||||||
|
type: string
|
||||||
|
observedGeneration:
|
||||||
|
description: observedGeneration represents the .metadata.generation that the condition was set based upon. For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date with respect to the current state of the instance.
|
||||||
|
format: int64
|
||||||
|
minimum: 0
|
||||||
|
type: integer
|
||||||
|
reason:
|
||||||
|
description: reason contains a programmatic identifier indicating the reason for the condition's last transition. Producers of specific condition types may define expected values and meanings for this field, and whether the values are considered a guaranteed API. The value should be a CamelCase string. This field may not be empty.
|
||||||
|
maxLength: 1024
|
||||||
|
minLength: 1
|
||||||
|
pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$
|
||||||
|
type: string
|
||||||
|
status:
|
||||||
|
description: status of the condition, one of True, False, Unknown.
|
||||||
|
enum:
|
||||||
|
- "True"
|
||||||
|
- "False"
|
||||||
|
- Unknown
|
||||||
|
type: string
|
||||||
|
type:
|
||||||
|
description: type of condition in CamelCase or in foo.example.com/CamelCase. --- Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be useful (see .node.status.conditions), the ability to deconflict is important. The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt)
|
||||||
|
maxLength: 316
|
||||||
|
pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- lastTransitionTime
|
||||||
|
- message
|
||||||
|
- reason
|
||||||
|
- status
|
||||||
|
- type
|
||||||
|
type: object
|
||||||
|
maxItems: 8
|
||||||
|
type: array
|
||||||
|
x-kubernetes-list-map-keys:
|
||||||
|
- type
|
||||||
|
x-kubernetes-list-type: map
|
||||||
|
gatewayRef:
|
||||||
|
description: GatewayRef is a reference to a Gateway object that is associated with the route.
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: Name is the name of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
namespace:
|
||||||
|
description: Namespace is the namespace of the referent.
|
||||||
|
maxLength: 253
|
||||||
|
minLength: 1
|
||||||
|
type: string
|
||||||
|
required:
|
||||||
|
- name
|
||||||
|
- namespace
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- gatewayRef
|
||||||
|
type: object
|
||||||
|
maxItems: 100
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- gateways
|
||||||
|
type: object
|
||||||
|
type: object
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
subresources:
|
||||||
|
status: {}
|
||||||
|
status:
|
||||||
|
acceptedNames:
|
||||||
|
kind: ""
|
||||||
|
plural: ""
|
||||||
|
conditions: []
|
||||||
|
storedVersions: []
|
||||||
|
|
|
@ -20,6 +20,95 @@ spec:
|
||||||
routes:
|
routes:
|
||||||
kind: HTTPRoute
|
kind: HTTPRoute
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tcp-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 8193
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app-1
|
||||||
|
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCk1JSUNJakNDQVl1Z0F3SUJBZ0lRS1F6S1hWV0duODRNNzk2QmhGUzV0VEFOQmdrcWhraUc5dzBCQVFzRkFEQVMKTVJBd0RnWURWUVFLRXdkQlkyMWxJRU52TUNBWERUY3dNREV3TVRBd01EQXdNRm9ZRHpJd09EUXdNVEk1TVRZdwpNREF3V2pBU01SQXdEZ1lEVlFRS0V3ZEJZMjFsSUVOdk1JR2ZNQTBHQ1NxR1NJYjNEUUVCQVFVQUE0R05BRENCCmlRS0JnUURsMHNndm5HSnJOMEt1NXVQanBVZjNwTkY2MTkyL0xSb1FjMmFCeENORkdtZW5XekhsZXpoS3Rnam4KZk0velRxeGU1Y3M5QzBvKzlpdFNrRTBzNEp0S0lob1R6NGEvbklCUmxRZ2hsWkRTQ2ZFVjdXdWxLZGVqbWE3Swp3MittUDVLYy9Qa0ozRkxPSCt0blJRSVZPakZmeDBhMllDS2VxTFJWRmhGOWlMSFBWd0lEQVFBQm8zY3dkVEFPCkJnTlZIUThCQWY4RUJBTUNBcVF3RXdZRFZSMGxCQXd3Q2dZSUt3WUJCUVVIQXdFd0R3WURWUjBUQVFIL0JBVXcKQXdFQi96QWRCZ05WSFE0RUZnUVVyZERBNGFIMHc2WjJHc2dxa3FHMHRqNlFZL2t3SGdZRFZSMFJCQmN3RllJVApkR3h6TG1admJ5NWxlR0Z0Y0d4bExtTnZiVEFOQmdrcWhraUc5dzBCQVFzRkFBT0JnUUIvVFBHcElMUGg0Nlp4CnVXZFM4WDFNWEc0ODVQSlNKYVhxZUNsTW9EVEQxdlVwa0Jzd1hEUUVESFRMQkU0SGROaEJaaUlpOFFLQjZCS1IKZEVqU0xFbmlhK0ExUkwyRjdIa05MbU1ycFVjT3lzdzBiOFg1LzkydkpGYStScXgxdjJwQ0FIUHRGUE9ZM240NQoza3lGZy96ZXUwd2w0NW80MUtNL0ZJT1ljWFA3dVE9PQotLS0tLUVORCBDRVJUSUZJQ0FURS0tLS0tCg==
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUNlQUlCQURBTkJna3Foa2lHOXcwQkFRRUZBQVNDQW1Jd2dnSmVBZ0VBQW9HQkFPWFN5QytjWW1zM1FxN20KNCtPbFIvZWswWHJYM2I4dEdoQnpab0hFSTBVYVo2ZGJNZVY3T0VxMkNPZDh6L05PckY3bHl6MExTajcySzFLUQpUU3pnbTBvaUdoUFBocitjZ0ZHVkNDR1ZrTklKOFJYdGE2VXAxNk9acnNyRGI2WS9rcHo4K1FuY1VzNGY2MmRGCkFoVTZNVi9IUnJaZ0lwNm90RlVXRVgySXNjOVhBZ01CQUFFQ2dZRUF4MllMRSt2dUpESHM1RTBsZWhTa0RVUHUKRUZRTWE5dFkydDhWR0EreHZqbjdwdU5qdGtRamdnYlFVUEFraUdoQSs1RUt0ZXIrdndQY2NLVU1vSnc3ZmdBTQphMWxZVlJ1M1F6V1hSamdLL2xHbU5SN050bkVZaDBxL0VGcVRDZys5Nkp6UnR6b3FJSGdwN09IVWFVaUJUVURnCmFxUTdvcmc4Z1hiUmMxT0UwNWtDUVFEbXQ3TDRTNDk1Yk1CajFBL3kzamM5aThPeEZ1ZUt6Q1l3NWFZaC8xOGgKZTBYRkhRYmpSKzRxNDM1MmJsMkduMVg5Z0hKUDFUQllPY3V0UUM4Qmt0M2pBa0VBL3dIL2JFejd0RCtaWFVjZgpnb21XZzVEU2xhUmRtb0xrSTdLZllvcDl4VlNPUElTSnU4SEFhdnBhWVhiM1NuN05KL25EcUdZM1BVeFpsdzBZCmJNaEMvUUpBZTI3UUt4S1J3YzZ5NXpXdkNxcGtOMk1zNFBOMkVNWERzT2xNQm1oUGh1UWlvYUF6N1Npd2ZQV1UKMU51YTRja2hBaXpUKzIzOUhWWmVaMlF0UWRSSExRSkJBTE40aUhlRVJyRzVBUXJ3LzNBenZVYWpLbEkrOTlIQwp4U1dLbFRvWkZpTkhPMFBFVTl0Y3BUdWxMdTdoZDNGcWhLRFoyNll0S2p0dC9LK2VlODR6czFFQ1FRQ3oyNWlEClpCY2ZrR0FURlhjdWVzeXgvUlcyL2c4QzhtYkN6RW5oSCtYbWVBak44UFRDREF2VDNLVXltRm5MRVB6amVVYU0KRGRuSlZqc3JaNW8xK1c5WgotLS0tLUVORCBQUklWQVRFIEtFWS0tLS0tCg==
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tls-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners:
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9001
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app-1
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9002
|
||||||
|
tls:
|
||||||
|
mode: Terminate
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app-1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-https-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners:
|
||||||
|
- protocol: HTTPS
|
||||||
|
port: 8443
|
||||||
|
tls:
|
||||||
|
mode: Terminate
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: HTTPRoute
|
kind: HTTPRoute
|
||||||
apiVersion: networking.x-k8s.io/v1alpha1
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
@ -40,3 +129,36 @@ spec:
|
||||||
- serviceName: whoami
|
- serviceName: whoami
|
||||||
port: 80
|
port: 80
|
||||||
weight: 1
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app-1
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 8080
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app-1
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 8080
|
||||||
|
weight: 1
|
||||||
|
matches:
|
||||||
|
- snis:
|
||||||
|
- foo.bar
|
||||||
|
|
|
@ -12,11 +12,17 @@
|
||||||
kubernetesGateway = true
|
kubernetesGateway = true
|
||||||
|
|
||||||
[entryPoints]
|
[entryPoints]
|
||||||
|
[entryPoints.footlspassthrough]
|
||||||
|
address = ":9001"
|
||||||
|
[entryPoints.footlsterminate]
|
||||||
|
address = ":9002"
|
||||||
[entryPoints.footcp]
|
[entryPoints.footcp]
|
||||||
address = ":8193"
|
address = ":8193"
|
||||||
[entryPoints.fooudp]
|
[entryPoints.fooudp]
|
||||||
address = ":8190/udp"
|
address = ":8190/udp"
|
||||||
[entryPoints.web]
|
[entryPoints.web]
|
||||||
address = ":8180"
|
address = ":8180"
|
||||||
|
[entryPoints.websecure]
|
||||||
|
address = ":8443"
|
||||||
|
|
||||||
[providers.kubernetesGateway]
|
[providers.kubernetesGateway]
|
||||||
|
|
129
integration/testdata/rawdata-gateway.json
vendored
129
integration/testdata/rawdata-gateway.json
vendored
|
@ -38,6 +38,18 @@
|
||||||
"using": [
|
"using": [
|
||||||
"web"
|
"web"
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
"default-http-app-1-my-https-gateway-websecure-1c0cf64bde37d9d0df06@kubernetesgateway": {
|
||||||
|
"entryPoints": [
|
||||||
|
"websecure"
|
||||||
|
],
|
||||||
|
"service": "default-http-app-1-my-https-gateway-websecure-1c0cf64bde37d9d0df06-wrr",
|
||||||
|
"rule": "Host(`foo.com`) \u0026\u0026 Path(`/bar`)",
|
||||||
|
"tls": {},
|
||||||
|
"status": "enabled",
|
||||||
|
"using": [
|
||||||
|
"websecure"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"middlewares": {
|
"middlewares": {
|
||||||
|
@ -92,11 +104,25 @@
|
||||||
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06@kubernetesgateway"
|
"default-http-app-1-my-gateway-web-1c0cf64bde37d9d0df06@kubernetesgateway"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"default-http-app-1-my-https-gateway-websecure-1c0cf64bde37d9d0df06-wrr@kubernetesgateway": {
|
||||||
|
"weighted": {
|
||||||
|
"services": [
|
||||||
|
{
|
||||||
|
"name": "default-whoami-80",
|
||||||
|
"weight": 1
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"status": "enabled",
|
||||||
|
"usedBy": [
|
||||||
|
"default-http-app-1-my-https-gateway-websecure-1c0cf64bde37d9d0df06@kubernetesgateway"
|
||||||
|
]
|
||||||
|
},
|
||||||
"default-whoami-80@kubernetesgateway": {
|
"default-whoami-80@kubernetesgateway": {
|
||||||
"loadBalancer": {
|
"loadBalancer": {
|
||||||
"servers": [
|
"servers": [
|
||||||
{
|
{
|
||||||
"url": "http://10.42.0.3:80"
|
"url": "http://10.42.0.6:80"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"url": "http://10.42.0.7:80"
|
"url": "http://10.42.0.7:80"
|
||||||
|
@ -106,12 +132,111 @@
|
||||||
},
|
},
|
||||||
"status": "enabled",
|
"status": "enabled",
|
||||||
"serverStatus": {
|
"serverStatus": {
|
||||||
"http://10.42.0.3:80": "UP",
|
"http://10.42.0.6:80": "UP",
|
||||||
"http://10.42.0.7:80": "UP"
|
"http://10.42.0.7:80": "UP"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"noop@internal": {
|
"noop@internal": {
|
||||||
"status": "enabled"
|
"status": "enabled"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"tcpRouters": {
|
||||||
|
"default-tcp-app-1-my-tcp-gateway-footcp-e3b0c44298fc1c149afb@kubernetesgateway": {
|
||||||
|
"entryPoints": [
|
||||||
|
"footcp"
|
||||||
|
],
|
||||||
|
"service": "default-tcp-app-1-my-tcp-gateway-footcp-e3b0c44298fc1c149afb-wrr",
|
||||||
|
"rule": "HostSNI(`*`)",
|
||||||
|
"status": "enabled",
|
||||||
|
"using": [
|
||||||
|
"footcp"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"default-tcp-app-1-my-tls-gateway-footlsterminate-e3b0c44298fc1c149afb@kubernetesgateway": {
|
||||||
|
"entryPoints": [
|
||||||
|
"footlsterminate"
|
||||||
|
],
|
||||||
|
"service": "default-tcp-app-1-my-tls-gateway-footlsterminate-e3b0c44298fc1c149afb-wrr",
|
||||||
|
"rule": "HostSNI(`*`)",
|
||||||
|
"tls": {
|
||||||
|
"passthrough": false
|
||||||
|
},
|
||||||
|
"status": "enabled",
|
||||||
|
"using": [
|
||||||
|
"footlsterminate"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"default-tls-app-1-my-tls-gateway-footlspassthrough-2279fe75c5156dc5eb26@kubernetesgateway": {
|
||||||
|
"entryPoints": [
|
||||||
|
"footlspassthrough"
|
||||||
|
],
|
||||||
|
"service": "default-tls-app-1-my-tls-gateway-footlspassthrough-2279fe75c5156dc5eb26-wrr",
|
||||||
|
"rule": "HostSNI(`foo.bar`)",
|
||||||
|
"tls": {
|
||||||
|
"passthrough": true
|
||||||
|
},
|
||||||
|
"status": "enabled",
|
||||||
|
"using": [
|
||||||
|
"footlspassthrough"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"tcpServices": {
|
||||||
|
"default-tcp-app-1-my-tcp-gateway-footcp-e3b0c44298fc1c149afb-wrr@kubernetesgateway": {
|
||||||
|
"weighted": {
|
||||||
|
"services": [
|
||||||
|
{
|
||||||
|
"name": "default-whoamitcp-8080",
|
||||||
|
"weight": 1
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"status": "enabled",
|
||||||
|
"usedBy": [
|
||||||
|
"default-tcp-app-1-my-tcp-gateway-footcp-e3b0c44298fc1c149afb@kubernetesgateway"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"default-tcp-app-1-my-tls-gateway-footlsterminate-e3b0c44298fc1c149afb-wrr@kubernetesgateway": {
|
||||||
|
"weighted": {
|
||||||
|
"services": [
|
||||||
|
{
|
||||||
|
"name": "default-whoamitcp-8080",
|
||||||
|
"weight": 1
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"status": "enabled",
|
||||||
|
"usedBy": [
|
||||||
|
"default-tcp-app-1-my-tls-gateway-footlsterminate-e3b0c44298fc1c149afb@kubernetesgateway"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"default-tls-app-1-my-tls-gateway-footlspassthrough-2279fe75c5156dc5eb26-wrr@kubernetesgateway": {
|
||||||
|
"weighted": {
|
||||||
|
"services": [
|
||||||
|
{
|
||||||
|
"name": "default-whoamitcp-8080",
|
||||||
|
"weight": 1
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"status": "enabled",
|
||||||
|
"usedBy": [
|
||||||
|
"default-tls-app-1-my-tls-gateway-footlspassthrough-2279fe75c5156dc5eb26@kubernetesgateway"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"default-whoamitcp-8080@kubernetesgateway": {
|
||||||
|
"loadBalancer": {
|
||||||
|
"terminationDelay": 100,
|
||||||
|
"servers": [
|
||||||
|
{
|
||||||
|
"address": "10.42.0.2:8080"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"address": "10.42.0.4:8080"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"status": "enabled"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -56,6 +56,8 @@ type Client interface {
|
||||||
UpdateGatewayClassStatus(gatewayClass *v1alpha1.GatewayClass, condition metav1.Condition) error
|
UpdateGatewayClassStatus(gatewayClass *v1alpha1.GatewayClass, condition metav1.Condition) error
|
||||||
GetGateways() []*v1alpha1.Gateway
|
GetGateways() []*v1alpha1.Gateway
|
||||||
GetHTTPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.HTTPRoute, error)
|
GetHTTPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.HTTPRoute, error)
|
||||||
|
GetTCPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.TCPRoute, error)
|
||||||
|
GetTLSRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.TLSRoute, error)
|
||||||
|
|
||||||
GetService(namespace, name string) (*corev1.Service, bool, error)
|
GetService(namespace, name string) (*corev1.Service, bool, error)
|
||||||
GetSecret(namespace, name string) (*corev1.Secret, bool, error)
|
GetSecret(namespace, name string) (*corev1.Secret, bool, error)
|
||||||
|
@ -176,6 +178,8 @@ func (c *clientWrapper) WatchAll(namespaces []string, stopCh <-chan struct{}) (<
|
||||||
factoryGateway := externalversions.NewSharedInformerFactoryWithOptions(c.csGateway, resyncPeriod, externalversions.WithNamespace(ns))
|
factoryGateway := externalversions.NewSharedInformerFactoryWithOptions(c.csGateway, resyncPeriod, externalversions.WithNamespace(ns))
|
||||||
factoryGateway.Networking().V1alpha1().Gateways().Informer().AddEventHandler(eventHandler)
|
factoryGateway.Networking().V1alpha1().Gateways().Informer().AddEventHandler(eventHandler)
|
||||||
factoryGateway.Networking().V1alpha1().HTTPRoutes().Informer().AddEventHandler(eventHandler)
|
factoryGateway.Networking().V1alpha1().HTTPRoutes().Informer().AddEventHandler(eventHandler)
|
||||||
|
factoryGateway.Networking().V1alpha1().TCPRoutes().Informer().AddEventHandler(eventHandler)
|
||||||
|
factoryGateway.Networking().V1alpha1().TLSRoutes().Informer().AddEventHandler(eventHandler)
|
||||||
|
|
||||||
factoryKube := informers.NewSharedInformerFactoryWithOptions(c.csKube, resyncPeriod, informers.WithNamespace(ns))
|
factoryKube := informers.NewSharedInformerFactoryWithOptions(c.csKube, resyncPeriod, informers.WithNamespace(ns))
|
||||||
factoryKube.Core().V1().Services().Informer().AddEventHandler(eventHandler)
|
factoryKube.Core().V1().Services().Informer().AddEventHandler(eventHandler)
|
||||||
|
@ -228,7 +232,7 @@ func (c *clientWrapper) WatchAll(namespaces []string, stopCh <-chan struct{}) (<
|
||||||
|
|
||||||
func (c *clientWrapper) GetHTTPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.HTTPRoute, error) {
|
func (c *clientWrapper) GetHTTPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.HTTPRoute, error) {
|
||||||
if !c.isWatchedNamespace(namespace) {
|
if !c.isWatchedNamespace(namespace) {
|
||||||
return nil, fmt.Errorf("failed to get HTTPRoute %s with labels selector %s: namespace is not within watched namespaces", namespace, selector)
|
return nil, fmt.Errorf("failed to get HTTPRoutes %s with labels selector %s: namespace is not within watched namespaces", namespace, selector)
|
||||||
}
|
}
|
||||||
httpRoutes, err := c.factoriesGateway[c.lookupNamespace(namespace)].Networking().V1alpha1().HTTPRoutes().Lister().HTTPRoutes(namespace).List(selector)
|
httpRoutes, err := c.factoriesGateway[c.lookupNamespace(namespace)].Networking().V1alpha1().HTTPRoutes().Lister().HTTPRoutes(namespace).List(selector)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -236,12 +240,46 @@ func (c *clientWrapper) GetHTTPRoutes(namespace string, selector labels.Selector
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(httpRoutes) == 0 {
|
if len(httpRoutes) == 0 {
|
||||||
log.WithoutContext().Debugf("No HTTPRoute found in %q namespace with labels selector %s", namespace, selector)
|
log.WithoutContext().Debugf("No HTTPRoutes found in %q namespace with labels selector %s", namespace, selector)
|
||||||
}
|
}
|
||||||
|
|
||||||
return httpRoutes, nil
|
return httpRoutes, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c *clientWrapper) GetTCPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.TCPRoute, error) {
|
||||||
|
if !c.isWatchedNamespace(namespace) {
|
||||||
|
return nil, fmt.Errorf("failed to get TCPRoutes %s with labels selector %s: namespace is not within watched namespaces", namespace, selector)
|
||||||
|
}
|
||||||
|
|
||||||
|
tcpRoutes, err := c.factoriesGateway[c.lookupNamespace(namespace)].Networking().V1alpha1().TCPRoutes().Lister().TCPRoutes(namespace).List(selector)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(tcpRoutes) == 0 {
|
||||||
|
log.WithoutContext().Debugf("No TCPRoutes found in %q namespace with labels selector %s", namespace, selector)
|
||||||
|
}
|
||||||
|
|
||||||
|
return tcpRoutes, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *clientWrapper) GetTLSRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.TLSRoute, error) {
|
||||||
|
if !c.isWatchedNamespace(namespace) {
|
||||||
|
return nil, fmt.Errorf("failed to get TLSRoutes %s with labels selector %s: namespace is not within watched namespaces", namespace, selector)
|
||||||
|
}
|
||||||
|
|
||||||
|
tlsRoutes, err := c.factoriesGateway[c.lookupNamespace(namespace)].Networking().V1alpha1().TLSRoutes().Lister().TLSRoutes(namespace).List(selector)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(tlsRoutes) == 0 {
|
||||||
|
log.WithoutContext().Debugf("No TLSRoutes found in %q namespace with labels selector %s", namespace, selector)
|
||||||
|
}
|
||||||
|
|
||||||
|
return tlsRoutes, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (c *clientWrapper) GetGateways() []*v1alpha1.Gateway {
|
func (c *clientWrapper) GetGateways() []*v1alpha1.Gateway {
|
||||||
var result []*v1alpha1.Gateway
|
var result []*v1alpha1.Gateway
|
||||||
|
|
||||||
|
|
|
@ -35,6 +35,8 @@ type clientMock struct {
|
||||||
gatewayClasses []*v1alpha1.GatewayClass
|
gatewayClasses []*v1alpha1.GatewayClass
|
||||||
gateways []*v1alpha1.Gateway
|
gateways []*v1alpha1.Gateway
|
||||||
httpRoutes []*v1alpha1.HTTPRoute
|
httpRoutes []*v1alpha1.HTTPRoute
|
||||||
|
tcpRoutes []*v1alpha1.TCPRoute
|
||||||
|
tlsRoutes []*v1alpha1.TLSRoute
|
||||||
|
|
||||||
watchChan chan interface{}
|
watchChan chan interface{}
|
||||||
}
|
}
|
||||||
|
@ -63,6 +65,10 @@ func newClientMock(paths ...string) clientMock {
|
||||||
c.gateways = append(c.gateways, o)
|
c.gateways = append(c.gateways, o)
|
||||||
case *v1alpha1.HTTPRoute:
|
case *v1alpha1.HTTPRoute:
|
||||||
c.httpRoutes = append(c.httpRoutes, o)
|
c.httpRoutes = append(c.httpRoutes, o)
|
||||||
|
case *v1alpha1.TCPRoute:
|
||||||
|
c.tcpRoutes = append(c.tcpRoutes, o)
|
||||||
|
case *v1alpha1.TLSRoute:
|
||||||
|
c.tlsRoutes = append(c.tlsRoutes, o)
|
||||||
default:
|
default:
|
||||||
panic(fmt.Sprintf("Unknown runtime object %+v %T", o, o))
|
panic(fmt.Sprintf("Unknown runtime object %+v %T", o, o))
|
||||||
}
|
}
|
||||||
|
@ -126,7 +132,7 @@ func (c clientMock) GetGateways() []*v1alpha1.Gateway {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c clientMock) GetHTTPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.HTTPRoute, error) {
|
func (c clientMock) GetHTTPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.HTTPRoute, error) {
|
||||||
httpRoutes := make([]*v1alpha1.HTTPRoute, len(c.httpRoutes))
|
var httpRoutes []*v1alpha1.HTTPRoute
|
||||||
|
|
||||||
for _, httpRoute := range c.httpRoutes {
|
for _, httpRoute := range c.httpRoutes {
|
||||||
if httpRoute.Namespace == namespace && selector.Matches(labels.Set(httpRoute.Labels)) {
|
if httpRoute.Namespace == namespace && selector.Matches(labels.Set(httpRoute.Labels)) {
|
||||||
|
@ -136,6 +142,28 @@ func (c clientMock) GetHTTPRoutes(namespace string, selector labels.Selector) ([
|
||||||
return httpRoutes, nil
|
return httpRoutes, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c clientMock) GetTCPRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.TCPRoute, error) {
|
||||||
|
var tcpRoutes []*v1alpha1.TCPRoute
|
||||||
|
|
||||||
|
for _, tcpRoute := range c.tcpRoutes {
|
||||||
|
if tcpRoute.Namespace == namespace && selector.Matches(labels.Set(tcpRoute.Labels)) {
|
||||||
|
tcpRoutes = append(tcpRoutes, tcpRoute)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return tcpRoutes, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c clientMock) GetTLSRoutes(namespace string, selector labels.Selector) ([]*v1alpha1.TLSRoute, error) {
|
||||||
|
var tlsRoutes []*v1alpha1.TLSRoute
|
||||||
|
|
||||||
|
for _, tlsRoute := range c.tlsRoutes {
|
||||||
|
if tlsRoute.Namespace == namespace && selector.Matches(labels.Set(tlsRoute.Labels)) {
|
||||||
|
tlsRoutes = append(tlsRoutes, tlsRoute)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return tlsRoutes, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (c clientMock) GetService(namespace, name string) (*corev1.Service, bool, error) {
|
func (c clientMock) GetService(namespace, name string) (*corev1.Service, bool, error) {
|
||||||
if c.apiServiceError != nil {
|
if c.apiServiceError != nil {
|
||||||
return nil, false, c.apiServiceError
|
return nil, false, c.apiServiceError
|
||||||
|
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -0,0 +1,47 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 80
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
hostnames:
|
||||||
|
- "foo.com"
|
||||||
|
rules:
|
||||||
|
- matches:
|
||||||
|
- path:
|
||||||
|
type: ImplementationSpecific
|
||||||
|
value: /bar
|
||||||
|
forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -14,9 +14,9 @@ metadata:
|
||||||
namespace: default
|
namespace: default
|
||||||
spec:
|
spec:
|
||||||
gatewayClassName: my-gateway-class
|
gatewayClassName: my-gateway-class
|
||||||
listeners:
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
- protocol: HTTP
|
- protocol: HTTP
|
||||||
port: 80
|
port: 443
|
||||||
routes:
|
routes:
|
||||||
kind: HTTPRoute
|
kind: HTTPRoute
|
||||||
namespaces:
|
namespaces:
|
||||||
|
@ -35,7 +35,7 @@ metadata:
|
||||||
app: foo
|
app: foo
|
||||||
spec:
|
spec:
|
||||||
hostnames:
|
hostnames:
|
||||||
- "whoami"
|
- "foo.com"
|
||||||
rules:
|
rules:
|
||||||
- matches:
|
- matches:
|
||||||
- path:
|
- path:
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -38,6 +38,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -0,0 +1,64 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTPS
|
||||||
|
port: 443
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
hostnames:
|
||||||
|
- "foo.com"
|
||||||
|
rules:
|
||||||
|
- matches:
|
||||||
|
- path:
|
||||||
|
type: Exact
|
||||||
|
value: /bar
|
||||||
|
forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -0,0 +1,47 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 443
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
hostnames:
|
||||||
|
- "foo.com"
|
||||||
|
rules:
|
||||||
|
- matches:
|
||||||
|
- path:
|
||||||
|
type: Exact
|
||||||
|
value: /bar
|
||||||
|
forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -0,0 +1,64 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 443
|
||||||
|
tls:
|
||||||
|
mode: Terminate
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
hostnames:
|
||||||
|
- "foo.com"
|
||||||
|
rules:
|
||||||
|
- matches:
|
||||||
|
- path:
|
||||||
|
type: Exact
|
||||||
|
value: /bar
|
||||||
|
forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -38,6 +38,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
||||||
|
@ -56,6 +57,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -38,6 +38,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
- protocol: HTTP
|
- protocol: HTTP
|
||||||
port: 80
|
port: 80
|
||||||
|
@ -46,6 +47,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -22,6 +22,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -14,6 +14,7 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
||||||
|
|
||||||
---
|
---
|
|
@ -22,4 +22,5 @@ spec:
|
||||||
namespaces:
|
namespaces:
|
||||||
from: Same
|
from: Same
|
||||||
selector:
|
selector:
|
||||||
|
matchLabels:
|
||||||
app: foo
|
app: foo
|
131
pkg/provider/kubernetes/gateway/fixtures/mixed/simple.yml
Normal file
131
pkg/provider/kubernetes/gateway/fixtures/mixed/simple.yml
Normal file
|
@ -0,0 +1,131 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 9080
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: http-app
|
||||||
|
- protocol: HTTPS
|
||||||
|
port: 9443
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: http-app
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
- protocol: TLS
|
||||||
|
port: 10000
|
||||||
|
hostname: tls.foo.example.com
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
- protocol: TLS
|
||||||
|
port: 11000
|
||||||
|
hostname: pass.tls.foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: http-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,41 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners:
|
||||||
|
- protocol: UNKNOWN
|
||||||
|
port: 9080
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: http-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: http-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -0,0 +1,41 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners:
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 9080
|
||||||
|
routes:
|
||||||
|
kind: UnknownRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: http-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: http-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -0,0 +1,41 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners:
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9080
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: http-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: http-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -0,0 +1,139 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 9080
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: http-app-1
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 9080
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: http-app-2
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9000
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9000
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: http-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-2
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: http-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,75 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-mixed-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 80
|
||||||
|
routes:
|
||||||
|
kind: HTTPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-tls-app-1
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-tls-app-1
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9443
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-http-app-1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: label-tls-app-1
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: HTTPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: http-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: label-http-app-1
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- matches:
|
||||||
|
- path:
|
||||||
|
type: Exact
|
||||||
|
value: /bar
|
||||||
|
forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -107,7 +107,6 @@ spec:
|
||||||
- name: websecure2
|
- name: websecure2
|
||||||
port: 8443
|
port: 8443
|
||||||
targetPort: websecure2
|
targetPort: websecure2
|
||||||
scheme: https
|
|
||||||
selector:
|
selector:
|
||||||
app: containous
|
app: containous
|
||||||
task: whoami3
|
task: whoami3
|
||||||
|
@ -164,3 +163,39 @@ spec:
|
||||||
- name: https
|
- name: https
|
||||||
protocol: TCP
|
protocol: TCP
|
||||||
port: 443
|
port: 443
|
||||||
|
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Endpoints
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: whoamitcp
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
subsets:
|
||||||
|
- addresses:
|
||||||
|
- ip: 10.10.0.9
|
||||||
|
- ip: 10.10.0.10
|
||||||
|
ports:
|
||||||
|
- name: tcp-1
|
||||||
|
protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
- name: tcp-2
|
||||||
|
protocol: TCP
|
||||||
|
port: 10000
|
||||||
|
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: whoamitcp
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
spec:
|
||||||
|
ports:
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
name: tcp-1
|
||||||
|
- protocol: TCP
|
||||||
|
port: 10000
|
||||||
|
name: tcp-2
|
||||||
|
|
|
@ -0,0 +1,41 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: unkown.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 8080
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: TCP-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
40
pkg/provider/kubernetes/gateway/fixtures/tcproute/simple.yml
Normal file
40
pkg/provider/kubernetes/gateway/fixtures/tcproute/simple.yml
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tcp-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: whoamitcp
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: whoamitcp
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,47 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- weight: 1
|
||||||
|
backendRef:
|
||||||
|
group: traefik.containo.us
|
||||||
|
kind: TraefikService
|
||||||
|
name: service@file
|
||||||
|
port: 9000
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,62 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tcp-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-tcp-app-1
|
||||||
|
- protocol: TCP
|
||||||
|
port: 10000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-tcp-app-2
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: label-tcp-app-1
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-2
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: label-tcp-app-2
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 10000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,44 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tcp-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9000
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-tcp-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: label-tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 10000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,42 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 9000
|
||||||
|
hostname: foo.example.com
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,59 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTPS
|
||||||
|
port: 9000
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Terminate # Default mode
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,59 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9000
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Terminate # Default mode
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,41 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 8080
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: TCP-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
weight: 1
|
||||||
|
port: 9000
|
|
@ -0,0 +1,33 @@
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 8080
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: TCP-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoami
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -0,0 +1,26 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 8080
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
|
@ -0,0 +1,43 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 8080
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: unkown.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
port: 8080
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 80
|
||||||
|
weight: 1
|
|
@ -0,0 +1,57 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tls-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
hostname: foo.example.com
|
||||||
|
port: 9000
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: whoamitcp
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: whoamitcp
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,57 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tls-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
hostname: foo.example.com
|
||||||
|
port: 9000
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: whoamitls
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: whoamitls
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,54 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tls-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
hostname: foo.example.com
|
||||||
|
port: 9000
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: whoamitcp
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: whoamitcp
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,63 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9000
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tcp-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tcp-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- weight: 1
|
||||||
|
backendRef:
|
||||||
|
group: traefik.containo.us
|
||||||
|
kind: TraefikService
|
||||||
|
name: service@file
|
||||||
|
port: 9000
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,48 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
matches:
|
||||||
|
- snis:
|
||||||
|
- foo.bar
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
matches:
|
||||||
|
- snis:
|
||||||
|
- foo.bar
|
||||||
|
- "*"
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
matches:
|
||||||
|
- snis:
|
||||||
|
- foo.bar
|
||||||
|
- fiz.baz
|
||||||
|
|
|
@ -0,0 +1,82 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-tls-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
hostname: foo.example.com
|
||||||
|
port: 9000
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-tcp-app-1
|
||||||
|
- protocol: TLS
|
||||||
|
port: 10000
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: label-tls-app-1
|
||||||
|
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: label-tcp-app-1
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: label-tls-app-1
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 10000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,44 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,60 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
# certificateRef is ignored with mode "Passthrough"
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,42 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTP
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,59 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: HTTPS
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
tls:
|
||||||
|
mode: Terminate # Default mode
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,42 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TCP
|
||||||
|
port: 9001
|
||||||
|
hostname: foo.example.com
|
||||||
|
routes:
|
||||||
|
kind: TLSRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: tls-app
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TLSRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tls-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: tls-app
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 9000
|
||||||
|
weight: 1
|
|
@ -0,0 +1,57 @@
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: supersecret
|
||||||
|
namespace: default
|
||||||
|
|
||||||
|
data:
|
||||||
|
tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0=
|
||||||
|
tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0=
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 8080
|
||||||
|
tls:
|
||||||
|
certificateRef:
|
||||||
|
kind: Secret
|
||||||
|
name: supersecret
|
||||||
|
group: core
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
weight: 1
|
||||||
|
port: 9001
|
|
@ -0,0 +1,33 @@
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 8080
|
||||||
|
routes:
|
||||||
|
kind: TCPRoute
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: TCPRoute
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: tcp-app-1
|
||||||
|
namespace: default
|
||||||
|
labels:
|
||||||
|
app: foo
|
||||||
|
spec:
|
||||||
|
rules:
|
||||||
|
- forwardTo:
|
||||||
|
- serviceName: whoamitcp
|
||||||
|
port: 8080
|
||||||
|
weight: 1
|
|
@ -0,0 +1,28 @@
|
||||||
|
---
|
||||||
|
kind: GatewayClass
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway-class
|
||||||
|
spec:
|
||||||
|
controller: traefik.io/gateway-controller
|
||||||
|
|
||||||
|
---
|
||||||
|
kind: Gateway
|
||||||
|
apiVersion: networking.x-k8s.io/v1alpha1
|
||||||
|
metadata:
|
||||||
|
name: my-gateway
|
||||||
|
namespace: default
|
||||||
|
spec:
|
||||||
|
gatewayClassName: my-gateway-class
|
||||||
|
listeners: # Use GatewayClass defaults for listener definition.
|
||||||
|
- protocol: TLS
|
||||||
|
port: 8080
|
||||||
|
tls:
|
||||||
|
mode: Passthrough
|
||||||
|
routes:
|
||||||
|
kind: TLSRoutes
|
||||||
|
namespaces:
|
||||||
|
from: Same
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: foo
|
|
@ -32,6 +32,9 @@ const (
|
||||||
providerName = "kubernetesgateway"
|
providerName = "kubernetesgateway"
|
||||||
traefikServiceKind = "TraefikService"
|
traefikServiceKind = "TraefikService"
|
||||||
traefikServiceGroupName = "traefik.containo.us"
|
traefikServiceGroupName = "traefik.containo.us"
|
||||||
|
routeHTTPKind = "HTTPRoute"
|
||||||
|
routeTCPKind = "TCPRoute"
|
||||||
|
routeTLSKind = "TLSRoute"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Provider holds configurations of the provider.
|
// Provider holds configurations of the provider.
|
||||||
|
@ -222,7 +225,7 @@ func (p *Provider) loadConfigurationFromGateway(ctx context.Context, client Clie
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
cfg, err := p.createGatewayConf(client, gateway)
|
cfg, err := p.createGatewayConf(ctxLog, client, gateway)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logger.Error(err)
|
logger.Error(err)
|
||||||
continue
|
continue
|
||||||
|
@ -262,7 +265,7 @@ func (p *Provider) loadConfigurationFromGateway(ctx context.Context, client Clie
|
||||||
return conf
|
return conf
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Provider) createGatewayConf(client Client, gateway *v1alpha1.Gateway) (*dynamic.Configuration, error) {
|
func (p *Provider) createGatewayConf(ctx context.Context, client Client, gateway *v1alpha1.Gateway) (*dynamic.Configuration, error) {
|
||||||
conf := &dynamic.Configuration{
|
conf := &dynamic.Configuration{
|
||||||
UDP: &dynamic.UDPConfiguration{
|
UDP: &dynamic.UDPConfiguration{
|
||||||
Routers: map[string]*dynamic.UDPRouter{},
|
Routers: map[string]*dynamic.UDPRouter{},
|
||||||
|
@ -285,7 +288,7 @@ func (p *Provider) createGatewayConf(client Client, gateway *v1alpha1.Gateway) (
|
||||||
// GatewayReasonListenersNotValid is used when one or more
|
// GatewayReasonListenersNotValid is used when one or more
|
||||||
// Listeners have an invalid or unsupported configuration
|
// Listeners have an invalid or unsupported configuration
|
||||||
// and cannot be configured on the Gateway.
|
// and cannot be configured on the Gateway.
|
||||||
listenerStatuses := p.fillGatewayConf(client, gateway, conf, tlsConfigs)
|
listenerStatuses := p.fillGatewayConf(ctx, client, gateway, conf, tlsConfigs)
|
||||||
|
|
||||||
gatewayStatus, errG := p.makeGatewayStatus(listenerStatuses)
|
gatewayStatus, errG := p.makeGatewayStatus(listenerStatuses)
|
||||||
|
|
||||||
|
@ -305,8 +308,10 @@ func (p *Provider) createGatewayConf(client Client, gateway *v1alpha1.Gateway) (
|
||||||
return conf, nil
|
return conf, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, conf *dynamic.Configuration, tlsConfigs map[string]*tls.CertAndStores) []v1alpha1.ListenerStatus {
|
func (p *Provider) fillGatewayConf(ctx context.Context, client Client, gateway *v1alpha1.Gateway, conf *dynamic.Configuration, tlsConfigs map[string]*tls.CertAndStores) []v1alpha1.ListenerStatus {
|
||||||
listenerStatuses := make([]v1alpha1.ListenerStatus, len(gateway.Spec.Listeners))
|
listenerStatuses := make([]v1alpha1.ListenerStatus, len(gateway.Spec.Listeners))
|
||||||
|
logger := log.FromContext(ctx)
|
||||||
|
allocatedPort := map[v1alpha1.PortNumber]v1alpha1.ProtocolType{}
|
||||||
|
|
||||||
for i, listener := range gateway.Spec.Listeners {
|
for i, listener := range gateway.Spec.Listeners {
|
||||||
listenerStatuses[i] = v1alpha1.ListenerStatus{
|
listenerStatuses[i] = v1alpha1.ListenerStatus{
|
||||||
|
@ -315,7 +320,8 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
}
|
}
|
||||||
|
|
||||||
// Supported Protocol
|
// Supported Protocol
|
||||||
if listener.Protocol != v1alpha1.HTTPProtocolType && listener.Protocol != v1alpha1.HTTPSProtocolType {
|
if listener.Protocol != v1alpha1.HTTPProtocolType && listener.Protocol != v1alpha1.HTTPSProtocolType &&
|
||||||
|
listener.Protocol != v1alpha1.TCPProtocolType && listener.Protocol != v1alpha1.TLSProtocolType {
|
||||||
// update "Detached" status true with "UnsupportedProtocol" reason
|
// update "Detached" status true with "UnsupportedProtocol" reason
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
||||||
Type: string(v1alpha1.ListenerConditionDetached),
|
Type: string(v1alpha1.ListenerConditionDetached),
|
||||||
|
@ -328,6 +334,50 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Supported Route types
|
||||||
|
if listener.Routes.Kind != routeHTTPKind && listener.Routes.Kind != routeTCPKind && listener.Routes.Kind != routeTLSKind {
|
||||||
|
// update "ResolvedRefs" status true with "InvalidRoutesRef" reason
|
||||||
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonInvalidRoutesRef),
|
||||||
|
Message: fmt.Sprintf("Unsupported Route Kind %q", listener.Routes.Kind),
|
||||||
|
})
|
||||||
|
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// Protocol compliant with route type
|
||||||
|
if listener.Protocol == v1alpha1.HTTPProtocolType && listener.Routes.Kind != routeHTTPKind ||
|
||||||
|
listener.Protocol == v1alpha1.HTTPSProtocolType && listener.Routes.Kind != routeHTTPKind ||
|
||||||
|
listener.Protocol == v1alpha1.TCPProtocolType && listener.Routes.Kind != routeTCPKind ||
|
||||||
|
listener.Protocol == v1alpha1.TLSProtocolType && listener.Routes.Kind != routeTLSKind && listener.Routes.Kind != routeTCPKind {
|
||||||
|
// update "Detached" status true with "UnsupportedProtocol" reason
|
||||||
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionDetached),
|
||||||
|
Status: metav1.ConditionTrue,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonUnsupportedProtocol),
|
||||||
|
Message: fmt.Sprintf("listener protocol %q not supported with route kind %q", listener.Protocol, listener.Routes.Kind),
|
||||||
|
})
|
||||||
|
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, ok := allocatedPort[listener.Port]; ok {
|
||||||
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionDetached),
|
||||||
|
Status: metav1.ConditionTrue,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonPortUnavailable),
|
||||||
|
Message: fmt.Sprintf("port %d unavailable", listener.Port),
|
||||||
|
})
|
||||||
|
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
allocatedPort[listener.Port] = listener.Protocol
|
||||||
ep, err := p.entryPointName(listener.Port, listener.Protocol)
|
ep, err := p.entryPointName(listener.Port, listener.Protocol)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// update "Detached" status with "PortUnavailable" reason
|
// update "Detached" status with "PortUnavailable" reason
|
||||||
|
@ -342,8 +392,9 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if listener.Protocol == v1alpha1.HTTPSProtocolType {
|
// TLS
|
||||||
if listener.TLS == nil {
|
if listener.Protocol == v1alpha1.HTTPSProtocolType || listener.Protocol == v1alpha1.TLSProtocolType {
|
||||||
|
if listener.TLS == nil || (listener.TLS.CertificateRef == nil && listener.TLS.Mode != v1alpha1.TLSModePassthrough) {
|
||||||
// update "Detached" status with "UnsupportedProtocol" reason
|
// update "Detached" status with "UnsupportedProtocol" reason
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
||||||
Type: string(v1alpha1.ListenerConditionDetached),
|
Type: string(v1alpha1.ListenerConditionDetached),
|
||||||
|
@ -356,6 +407,34 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if listener.TLS.Mode == v1alpha1.TLSModePassthrough && listener.TLS.CertificateRef != nil {
|
||||||
|
// https://gateway-api.sigs.k8s.io/guides/tls/
|
||||||
|
logger.Warnf("In case of Passthrough TLS mode, no TLS settings take effect as the TLS session from the client is NOT terminated at the Gateway")
|
||||||
|
}
|
||||||
|
|
||||||
|
isTLSPassthrough := listener.TLS.Mode == v1alpha1.TLSModePassthrough
|
||||||
|
|
||||||
|
// Allowed configurations:
|
||||||
|
// Protocol TLS -> Passthrough -> TLSRoute
|
||||||
|
// Protocol TLS -> Terminate -> TCPRoute
|
||||||
|
// Protocol HTTPS -> Terminate -> HTTPRoute
|
||||||
|
if !(listener.Protocol == v1alpha1.TLSProtocolType && isTLSPassthrough && listener.Routes.Kind == routeTLSKind ||
|
||||||
|
listener.Protocol == v1alpha1.TLSProtocolType && !isTLSPassthrough && listener.Routes.Kind == routeTCPKind ||
|
||||||
|
listener.Protocol == v1alpha1.HTTPSProtocolType && !isTLSPassthrough && listener.Routes.Kind == routeHTTPKind) {
|
||||||
|
// update "ConditionDetached" status true with "ReasonUnsupportedProtocol" reason
|
||||||
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionDetached),
|
||||||
|
Status: metav1.ConditionTrue,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonUnsupportedProtocol),
|
||||||
|
Message: fmt.Sprintf("Unsupported route kind %q with %q",
|
||||||
|
listener.Routes.Kind, listener.TLS.Mode),
|
||||||
|
})
|
||||||
|
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if !isTLSPassthrough {
|
||||||
if listener.TLS.CertificateRef.Kind != "Secret" || listener.TLS.CertificateRef.Group != "core" {
|
if listener.TLS.CertificateRef.Kind != "Secret" || listener.TLS.CertificateRef.Group != "core" {
|
||||||
// update "ResolvedRefs" status true with "InvalidCertificateRef" reason
|
// update "ResolvedRefs" status true with "InvalidCertificateRef" reason
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
||||||
|
@ -388,44 +467,46 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
tlsConfigs[configKey] = tlsConf
|
tlsConfigs[configKey] = tlsConf
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Supported Route types
|
|
||||||
if listener.Routes.Kind != "HTTPRoute" {
|
|
||||||
// update "ResolvedRefs" status true with "InvalidRoutesRef" reason
|
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
|
||||||
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
|
||||||
Status: metav1.ConditionFalse,
|
|
||||||
LastTransitionTime: metav1.Now(),
|
|
||||||
Reason: string(v1alpha1.ListenerReasonInvalidRoutesRef),
|
|
||||||
Message: fmt.Sprintf("Unsupported Route Kind %q", listener.Routes.Kind),
|
|
||||||
})
|
|
||||||
|
|
||||||
continue
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch listener.Routes.Kind {
|
||||||
|
case routeHTTPKind:
|
||||||
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, gatewayHTTPRouteToHTTPConf(ctx, ep, listener, gateway, client, conf)...)
|
||||||
|
case routeTCPKind:
|
||||||
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, gatewayTCPRouteToTCPConf(ctx, ep, listener, gateway, client, conf)...)
|
||||||
|
case routeTLSKind:
|
||||||
|
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, gatewayTLSRouteToTCPConf(ctx, ep, listener, gateway, client, conf)...)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return listenerStatuses
|
||||||
|
}
|
||||||
|
|
||||||
|
func gatewayHTTPRouteToHTTPConf(ctx context.Context, ep string, listener v1alpha1.Listener, gateway *v1alpha1.Gateway, client Client, conf *dynamic.Configuration) []metav1.Condition {
|
||||||
// TODO: support RouteNamespaces
|
// TODO: support RouteNamespaces
|
||||||
httpRoutes, err := client.GetHTTPRoutes(gateway.Namespace, labels.SelectorFromSet(listener.Routes.Selector.MatchLabels))
|
selector := labels.SelectorFromSet(listener.Routes.Selector.MatchLabels)
|
||||||
|
httpRoutes, err := client.GetHTTPRoutes(gateway.Namespace, selector)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// update "ResolvedRefs" status true with "InvalidRoutesRef" reason
|
// update "ResolvedRefs" status true with "InvalidRoutesRef" reason
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
return []metav1.Condition{{
|
||||||
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
Status: metav1.ConditionFalse,
|
Status: metav1.ConditionFalse,
|
||||||
LastTransitionTime: metav1.Now(),
|
LastTransitionTime: metav1.Now(),
|
||||||
Reason: string(v1alpha1.ListenerReasonInvalidRoutesRef),
|
Reason: string(v1alpha1.ListenerReasonInvalidRoutesRef),
|
||||||
Message: fmt.Sprintf("Cannot fetch HTTPRoutes for namespace %q and matchLabels %v", gateway.Namespace, listener.Routes.Selector.MatchLabels),
|
Message: fmt.Sprintf("Cannot fetch %ss for namespace %q and matchLabels %v", listener.Routes.Kind, gateway.Namespace, listener.Routes.Selector.MatchLabels),
|
||||||
})
|
}}
|
||||||
continue
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if len(httpRoutes) == 0 {
|
||||||
|
log.FromContext(ctx).Debugf("No HTTPRoutes found for selector %q", selector)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var conditions []metav1.Condition
|
||||||
for _, httpRoute := range httpRoutes {
|
for _, httpRoute := range httpRoutes {
|
||||||
// Should never happen
|
|
||||||
if httpRoute == nil {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
hostRule, err := hostRule(httpRoute.Spec)
|
hostRule, err := hostRule(httpRoute.Spec)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
conditions = append(conditions, metav1.Condition{
|
||||||
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
Status: metav1.ConditionFalse,
|
Status: metav1.ConditionFalse,
|
||||||
LastTransitionTime: metav1.Now(),
|
LastTransitionTime: metav1.Now(),
|
||||||
|
@ -439,14 +520,13 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
rule, err := extractRule(routeRule, hostRule)
|
rule, err := extractRule(routeRule, hostRule)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
conditions = append(conditions, metav1.Condition{
|
||||||
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
Status: metav1.ConditionFalse,
|
Status: metav1.ConditionFalse,
|
||||||
LastTransitionTime: metav1.Now(),
|
LastTransitionTime: metav1.Now(),
|
||||||
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
Message: fmt.Sprintf("Skipping HTTPRoute %s: cannot generate rule: %v", httpRoute.Name, err),
|
Message: fmt.Sprintf("Skipping %s %s: cannot generate rule: %v", listener.Routes.Kind, httpRoute.Name, err),
|
||||||
})
|
})
|
||||||
continue
|
|
||||||
}
|
}
|
||||||
|
|
||||||
router := dynamic.Router{
|
router := dynamic.Router{
|
||||||
|
@ -464,19 +544,22 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
routerKey, err := makeRouterKey(router.Rule, makeID(httpRoute.Namespace, routerName))
|
routerKey, err := makeRouterKey(router.Rule, makeID(httpRoute.Namespace, routerName))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
conditions = append(conditions, metav1.Condition{
|
||||||
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
Status: metav1.ConditionFalse,
|
Status: metav1.ConditionFalse,
|
||||||
LastTransitionTime: metav1.Now(),
|
LastTransitionTime: metav1.Now(),
|
||||||
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
Message: fmt.Sprintf("Skipping HTTPRoute %s: cannot make router's key with rule %s: %v", httpRoute.Name, router.Rule, err),
|
Message: fmt.Sprintf("Skipping %s %s: cannot make router's key with rule %s: %v", listener.Routes.Kind, httpRoute.Name, router.Rule, err),
|
||||||
})
|
})
|
||||||
|
|
||||||
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if routeRule.ForwardTo != nil {
|
if routeRule.ForwardTo == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
// Traefik internal service can be used only if there is only one ForwardTo service reference.
|
// Traefik internal service can be used only if there is only one ForwardTo service reference.
|
||||||
if len(routeRule.ForwardTo) == 1 && isInternalService(routeRule.ForwardTo[0]) {
|
if len(routeRule.ForwardTo) == 1 && isInternalService(routeRule.ForwardTo[0]) {
|
||||||
router.Service = routeRule.ForwardTo[0].BackendRef.Name
|
router.Service = routeRule.ForwardTo[0].BackendRef.Name
|
||||||
|
@ -484,12 +567,12 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
wrrService, subServices, err := loadServices(client, gateway.Namespace, routeRule.ForwardTo)
|
wrrService, subServices, err := loadServices(client, gateway.Namespace, routeRule.ForwardTo)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
listenerStatuses[i].Conditions = append(listenerStatuses[i].Conditions, metav1.Condition{
|
conditions = append(conditions, metav1.Condition{
|
||||||
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
Status: metav1.ConditionFalse,
|
Status: metav1.ConditionFalse,
|
||||||
LastTransitionTime: metav1.Now(),
|
LastTransitionTime: metav1.Now(),
|
||||||
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
Message: fmt.Sprintf("Cannot load service from HTTPRoute %s/%s : %v", gateway.Namespace, httpRoute.Name, err),
|
Message: fmt.Sprintf("Cannot load service from %s %s/%s : %v", listener.Routes.Kind, gateway.Namespace, httpRoute.Name, err),
|
||||||
})
|
})
|
||||||
|
|
||||||
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
||||||
|
@ -505,18 +588,216 @@ func (p *Provider) fillGatewayConf(client Client, gateway *v1alpha1.Gateway, con
|
||||||
|
|
||||||
router.Service = serviceName
|
router.Service = serviceName
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if router.Service != "" {
|
|
||||||
routerKey = provider.Normalize(routerKey)
|
routerKey = provider.Normalize(routerKey)
|
||||||
|
|
||||||
conf.HTTP.Routers[routerKey] = &router
|
conf.HTTP.Routers[routerKey] = &router
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return conditions
|
||||||
|
}
|
||||||
|
|
||||||
|
func gatewayTCPRouteToTCPConf(ctx context.Context, ep string, listener v1alpha1.Listener, gateway *v1alpha1.Gateway, client Client, conf *dynamic.Configuration) []metav1.Condition {
|
||||||
|
// TODO: support RouteNamespaces
|
||||||
|
selector := labels.SelectorFromSet(listener.Routes.Selector.MatchLabels)
|
||||||
|
tcpRoutes, err := client.GetTCPRoutes(gateway.Namespace, selector)
|
||||||
|
if err != nil {
|
||||||
|
// update "ResolvedRefs" status true with "InvalidRoutesRef" reason
|
||||||
|
return []metav1.Condition{{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonInvalidRoutesRef),
|
||||||
|
Message: fmt.Sprintf("Cannot fetch %ss for namespace %q and matchLabels %v", listener.Routes.Kind, gateway.Namespace, listener.Routes.Selector.MatchLabels),
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(tcpRoutes) == 0 {
|
||||||
|
log.FromContext(ctx).Debugf("No TCPRoutes found for selector %q", selector)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var conditions []metav1.Condition
|
||||||
|
for _, tcpRoute := range tcpRoutes {
|
||||||
|
if len(tcpRoute.Spec.Rules) > 1 {
|
||||||
|
conditions = append(conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
|
Message: fmt.Sprintf("Skipping %s %s: multiple rules are not supported", listener.Routes.Kind, tcpRoute.Name),
|
||||||
|
})
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, routeRule := range tcpRoute.Spec.Rules {
|
||||||
|
router := dynamic.TCPRouter{
|
||||||
|
Rule: "HostSNI(`*`)", // Gateway listener hostname not available in TCP
|
||||||
|
EntryPoints: []string{ep},
|
||||||
|
}
|
||||||
|
|
||||||
|
if listener.TLS != nil {
|
||||||
|
// TODO support let's encrypt
|
||||||
|
router.TLS = &dynamic.RouterTCPTLSConfig{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adding the gateway name and the entryPoint name prevents overlapping of routers build from the same routes.
|
||||||
|
routerName := tcpRoute.Name + "-" + gateway.Name + "-" + ep
|
||||||
|
routerKey, err := makeRouterKey("", makeID(tcpRoute.Namespace, routerName))
|
||||||
|
if err != nil {
|
||||||
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
|
conditions = append(conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
|
Message: fmt.Sprintf("Skipping %s %s: cannot make router's key with rule %s: %v", listener.Routes.Kind, tcpRoute.Name, router.Rule, err),
|
||||||
|
})
|
||||||
|
|
||||||
|
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// Should not happen due to validation
|
||||||
|
// https://github.com/kubernetes-sigs/gateway-api/blob/af68a622f072811767d246ef5897135d93af0704/apis/v1alpha1/tcproute_types.go#L76
|
||||||
|
if routeRule.ForwardTo == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
wrrService, subServices, err := loadTCPServices(client, gateway.Namespace, routeRule.ForwardTo)
|
||||||
|
if err != nil {
|
||||||
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
|
conditions = append(conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
|
Message: fmt.Sprintf("Cannot load service from %s %s/%s : %v", listener.Routes.Kind, gateway.Namespace, tcpRoute.Name, err),
|
||||||
|
})
|
||||||
|
|
||||||
|
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
for svcName, svc := range subServices {
|
||||||
|
conf.TCP.Services[svcName] = svc
|
||||||
|
}
|
||||||
|
|
||||||
|
serviceName := provider.Normalize(routerKey + "-wrr")
|
||||||
|
conf.TCP.Services[serviceName] = wrrService
|
||||||
|
|
||||||
|
router.Service = serviceName
|
||||||
|
|
||||||
|
routerKey = provider.Normalize(routerKey)
|
||||||
|
conf.TCP.Routers[routerKey] = &router
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return listenerStatuses
|
return conditions
|
||||||
|
}
|
||||||
|
|
||||||
|
func gatewayTLSRouteToTCPConf(ctx context.Context, ep string, listener v1alpha1.Listener, gateway *v1alpha1.Gateway, client Client, conf *dynamic.Configuration) []metav1.Condition {
|
||||||
|
// TODO: support RouteNamespaces
|
||||||
|
selector := labels.SelectorFromSet(listener.Routes.Selector.MatchLabels)
|
||||||
|
tlsRoutes, err := client.GetTLSRoutes(gateway.Namespace, selector)
|
||||||
|
if err != nil {
|
||||||
|
// update "ResolvedRefs" status true with "InvalidRoutesRef" reason
|
||||||
|
return []metav1.Condition{{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonInvalidRoutesRef),
|
||||||
|
Message: fmt.Sprintf("Cannot fetch %ss for namespace %q and matchLabels %v", listener.Routes.Kind, gateway.Namespace, listener.Routes.Selector.MatchLabels),
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(tlsRoutes) == 0 {
|
||||||
|
log.FromContext(ctx).Debugf("No TLSRoutes found for selector %q", selector)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var conditions []metav1.Condition
|
||||||
|
for _, tlsRoute := range tlsRoutes {
|
||||||
|
for _, routeRule := range tlsRoute.Spec.Rules {
|
||||||
|
rule, err := hostSNIRule(routeRule)
|
||||||
|
if err != nil {
|
||||||
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
|
conditions = append(conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
|
Message: fmt.Sprintf("Skipping %s %s: cannot make route's SNI match: %v", listener.Routes.Kind, tlsRoute.Name, err),
|
||||||
|
})
|
||||||
|
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
router := dynamic.TCPRouter{
|
||||||
|
Rule: rule,
|
||||||
|
EntryPoints: []string{ep},
|
||||||
|
}
|
||||||
|
|
||||||
|
if listener.TLS != nil {
|
||||||
|
// TODO support let's encrypt
|
||||||
|
router.TLS = &dynamic.RouterTCPTLSConfig{
|
||||||
|
Passthrough: listener.TLS.Mode == v1alpha1.TLSModePassthrough,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adding the gateway name and the entryPoint name prevents overlapping of routers build from the same routes.
|
||||||
|
routerName := tlsRoute.Name + "-" + gateway.Name + "-" + ep
|
||||||
|
routerKey, err := makeRouterKey(rule, makeID(tlsRoute.Namespace, routerName))
|
||||||
|
if err != nil {
|
||||||
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
|
conditions = append(conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
|
Message: fmt.Sprintf("Skipping %s %s: cannot make router's key with rule %s: %v", listener.Routes.Kind, tlsRoute.Name, router.Rule, err),
|
||||||
|
})
|
||||||
|
|
||||||
|
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// Should not happen due to validation
|
||||||
|
// https://github.com/kubernetes-sigs/gateway-api/blob/af68a622f072811767d246ef5897135d93af0704/apis/v1alpha1/tlsroute_types.go#L79
|
||||||
|
if routeRule.ForwardTo == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
wrrService, subServices, err := loadTCPServices(client, gateway.Namespace, routeRule.ForwardTo)
|
||||||
|
if err != nil {
|
||||||
|
// update "ResolvedRefs" status true with "DroppedRoutes" reason
|
||||||
|
conditions = append(conditions, metav1.Condition{
|
||||||
|
Type: string(v1alpha1.ListenerConditionResolvedRefs),
|
||||||
|
Status: metav1.ConditionFalse,
|
||||||
|
LastTransitionTime: metav1.Now(),
|
||||||
|
Reason: string(v1alpha1.ListenerReasonDegradedRoutes),
|
||||||
|
Message: fmt.Sprintf("Cannot load service from %s %s/%s : %v", listener.Routes.Kind, gateway.Namespace, tlsRoute.Name, err),
|
||||||
|
})
|
||||||
|
|
||||||
|
// TODO update the RouteStatus condition / deduplicate conditions on listener
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
for svcName, svc := range subServices {
|
||||||
|
conf.TCP.Services[svcName] = svc
|
||||||
|
}
|
||||||
|
|
||||||
|
serviceName := provider.Normalize(routerKey + "-wrr")
|
||||||
|
conf.TCP.Services[serviceName] = wrrService
|
||||||
|
|
||||||
|
router.Service = serviceName
|
||||||
|
|
||||||
|
routerKey = provider.Normalize(routerKey)
|
||||||
|
conf.TCP.Routers[routerKey] = &router
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return conditions
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Provider) makeGatewayStatus(listenerStatuses []v1alpha1.ListenerStatus) (v1alpha1.GatewayStatus, error) {
|
func (p *Provider) makeGatewayStatus(listenerStatuses []v1alpha1.ListenerStatus) (v1alpha1.GatewayStatus, error) {
|
||||||
|
@ -601,7 +882,7 @@ func hostRule(httpRouteSpec v1alpha1.HTTPRouteSpec) (string, error) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://gateway-api.sigs.k8s.io/spec/#networking.x-k8s.io/v1alpha1.Hostname
|
// https://gateway-api.sigs.k8s.io/references/spec/#networking.x-k8s.io/v1alpha1.Hostname
|
||||||
if !strings.HasPrefix(host, "*.") || wildcard > 1 {
|
if !strings.HasPrefix(host, "*.") || wildcard > 1 {
|
||||||
return "", fmt.Errorf("invalid rule: %q", host)
|
return "", fmt.Errorf("invalid rule: %q", host)
|
||||||
}
|
}
|
||||||
|
@ -627,6 +908,38 @@ func hostRule(httpRouteSpec v1alpha1.HTTPRouteSpec) (string, error) {
|
||||||
return hostRegexp, nil
|
return hostRegexp, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func hostSNIRule(rule v1alpha1.TLSRouteRule) (string, error) {
|
||||||
|
uniqHostnames := map[string]struct{}{}
|
||||||
|
var hostnames []string
|
||||||
|
for _, match := range rule.Matches {
|
||||||
|
for _, hostname := range match.SNIs {
|
||||||
|
if len(hostname) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
h := string(hostname)
|
||||||
|
|
||||||
|
// first naive validation, should be improved
|
||||||
|
wildcardNb := strings.Count(h, "*")
|
||||||
|
if wildcardNb != 0 && !strings.HasPrefix(h, "*.") || wildcardNb > 1 {
|
||||||
|
return "", fmt.Errorf("invalid hostname: %q", h)
|
||||||
|
}
|
||||||
|
|
||||||
|
hostname := "`" + h + "`"
|
||||||
|
if _, ok := uniqHostnames[hostname]; !ok {
|
||||||
|
hostnames = append(hostnames, hostname)
|
||||||
|
uniqHostnames[hostname] = struct{}{}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(hostnames) == 0 {
|
||||||
|
return "HostSNI(`*`)", nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return "HostSNI(" + strings.Join(hostnames, ",") + ")", nil
|
||||||
|
}
|
||||||
|
|
||||||
func extractRule(routeRule v1alpha1.HTTPRouteRule, hostRule string) (string, error) {
|
func extractRule(routeRule v1alpha1.HTTPRouteRule, hostRule string) (string, error) {
|
||||||
var rule string
|
var rule string
|
||||||
var matchesRules []string
|
var matchesRules []string
|
||||||
|
@ -700,6 +1013,7 @@ func (p *Provider) entryPointName(port v1alpha1.PortNumber, protocol v1alpha1.Pr
|
||||||
for name, entryPoint := range p.EntryPoints {
|
for name, entryPoint := range p.EntryPoints {
|
||||||
if strings.HasSuffix(entryPoint.Address, ":"+portStr) {
|
if strings.HasSuffix(entryPoint.Address, ":"+portStr) {
|
||||||
// if the protocol is HTTP the entryPoint must have no TLS conf
|
// if the protocol is HTTP the entryPoint must have no TLS conf
|
||||||
|
// Not relevant for v1alpha1.TLSProtocolType && v1alpha1.TCPProtocolType
|
||||||
if protocol == v1alpha1.HTTPProtocolType && entryPoint.HasHTTPTLSConf {
|
if protocol == v1alpha1.HTTPProtocolType && entryPoint.HasHTTPTLSConf {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
@ -860,13 +1174,11 @@ func loadServices(client Client, namespace string, targets []v1alpha1.HTTPRouteF
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
var portName string
|
|
||||||
var portSpec corev1.ServicePort
|
var portSpec corev1.ServicePort
|
||||||
var match bool
|
var match bool
|
||||||
|
|
||||||
for _, p := range service.Spec.Ports {
|
for _, p := range service.Spec.Ports {
|
||||||
if forwardTo.Port == nil || p.Port == int32(*forwardTo.Port) {
|
if forwardTo.Port == nil || p.Port == int32(*forwardTo.Port) {
|
||||||
portName = p.Name
|
|
||||||
portSpec = p
|
portSpec = p
|
||||||
match = true
|
match = true
|
||||||
break
|
break
|
||||||
|
@ -894,7 +1206,7 @@ func loadServices(client Client, namespace string, targets []v1alpha1.HTTPRouteF
|
||||||
var portStr string
|
var portStr string
|
||||||
for _, subset := range endpoints.Subsets {
|
for _, subset := range endpoints.Subsets {
|
||||||
for _, p := range subset.Ports {
|
for _, p := range subset.Ports {
|
||||||
if portName == p.Name {
|
if portSpec.Name == p.Name {
|
||||||
port = p.Port
|
port = p.Port
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
@ -904,7 +1216,7 @@ func loadServices(client Client, namespace string, targets []v1alpha1.HTTPRouteF
|
||||||
return nil, nil, errors.New("cannot define a port")
|
return nil, nil, errors.New("cannot define a port")
|
||||||
}
|
}
|
||||||
|
|
||||||
protocol := getProtocol(portSpec, portName)
|
protocol := getProtocol(portSpec)
|
||||||
|
|
||||||
portStr = strconv.FormatInt(int64(port), 10)
|
portStr = strconv.FormatInt(int64(port), 10)
|
||||||
for _, addr := range subset.Addresses {
|
for _, addr := range subset.Addresses {
|
||||||
|
@ -927,9 +1239,127 @@ func loadServices(client Client, namespace string, targets []v1alpha1.HTTPRouteF
|
||||||
return wrrSvc, services, nil
|
return wrrSvc, services, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func getProtocol(portSpec corev1.ServicePort, portName string) string {
|
// loadTCPServices is generating a WRR service, even when there is only one target.
|
||||||
|
func loadTCPServices(client Client, namespace string, targets []v1alpha1.RouteForwardTo) (*dynamic.TCPService, map[string]*dynamic.TCPService, error) {
|
||||||
|
services := map[string]*dynamic.TCPService{}
|
||||||
|
|
||||||
|
wrrSvc := &dynamic.TCPService{
|
||||||
|
Weighted: &dynamic.TCPWeightedRoundRobin{
|
||||||
|
Services: []dynamic.TCPWRRService{},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, forwardTo := range targets {
|
||||||
|
weight := int(forwardTo.Weight)
|
||||||
|
|
||||||
|
if forwardTo.ServiceName == nil && forwardTo.BackendRef != nil {
|
||||||
|
if !(forwardTo.BackendRef.Group == traefikServiceGroupName && forwardTo.BackendRef.Kind == traefikServiceKind) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if strings.HasSuffix(forwardTo.BackendRef.Name, "@internal") {
|
||||||
|
return nil, nil, fmt.Errorf("traefik internal service %s is not allowed in a TCP service", forwardTo.BackendRef.Name)
|
||||||
|
}
|
||||||
|
|
||||||
|
wrrSvc.Weighted.Services = append(wrrSvc.Weighted.Services, dynamic.TCPWRRService{Name: forwardTo.BackendRef.Name, Weight: &weight})
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if forwardTo.ServiceName == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
svc := dynamic.TCPService{
|
||||||
|
LoadBalancer: &dynamic.TCPServersLoadBalancer{},
|
||||||
|
}
|
||||||
|
|
||||||
|
service, exists, err := client.GetService(namespace, *forwardTo.ServiceName)
|
||||||
|
if err != nil {
|
||||||
|
return nil, nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if !exists {
|
||||||
|
return nil, nil, errors.New("service not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(service.Spec.Ports) > 1 && forwardTo.Port == nil {
|
||||||
|
// If the port is unspecified and the backend is a Service
|
||||||
|
// object consisting of multiple port definitions, the route
|
||||||
|
// must be dropped from the Gateway. The controller should
|
||||||
|
// raise the "ResolvedRefs" condition on the Gateway with the
|
||||||
|
// "DroppedRoutes" reason. The gateway status for this route
|
||||||
|
// should be updated with a condition that describes the error
|
||||||
|
// more specifically.
|
||||||
|
log.WithoutContext().Errorf("A multiple ports Kubernetes Service cannot be used if unspecified forwardTo.Port")
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
var portSpec corev1.ServicePort
|
||||||
|
var match bool
|
||||||
|
|
||||||
|
for _, p := range service.Spec.Ports {
|
||||||
|
if forwardTo.Port == nil || p.Port == int32(*forwardTo.Port) {
|
||||||
|
portSpec = p
|
||||||
|
match = true
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !match {
|
||||||
|
return nil, nil, errors.New("service port not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
endpoints, endpointsExists, endpointsErr := client.GetEndpoints(namespace, *forwardTo.ServiceName)
|
||||||
|
if endpointsErr != nil {
|
||||||
|
return nil, nil, endpointsErr
|
||||||
|
}
|
||||||
|
|
||||||
|
if !endpointsExists {
|
||||||
|
return nil, nil, errors.New("endpoints not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(endpoints.Subsets) == 0 {
|
||||||
|
return nil, nil, errors.New("subset not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
var port int32
|
||||||
|
var portStr string
|
||||||
|
for _, subset := range endpoints.Subsets {
|
||||||
|
for _, p := range subset.Ports {
|
||||||
|
if portSpec.Name == p.Name {
|
||||||
|
port = p.Port
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if port == 0 {
|
||||||
|
return nil, nil, errors.New("cannot define a port")
|
||||||
|
}
|
||||||
|
|
||||||
|
portStr = strconv.FormatInt(int64(port), 10)
|
||||||
|
for _, addr := range subset.Addresses {
|
||||||
|
svc.LoadBalancer.Servers = append(svc.LoadBalancer.Servers, dynamic.TCPServer{
|
||||||
|
Address: net.JoinHostPort(addr.IP, portStr),
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
serviceName := provider.Normalize(makeID(service.Namespace, service.Name) + "-" + portStr)
|
||||||
|
services[serviceName] = &svc
|
||||||
|
|
||||||
|
wrrSvc.Weighted.Services = append(wrrSvc.Weighted.Services, dynamic.TCPWRRService{Name: serviceName, Weight: &weight})
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(wrrSvc.Weighted.Services) == 0 {
|
||||||
|
return nil, nil, errors.New("no service has been created")
|
||||||
|
}
|
||||||
|
|
||||||
|
return wrrSvc, services, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func getProtocol(portSpec corev1.ServicePort) string {
|
||||||
protocol := "http"
|
protocol := "http"
|
||||||
if portSpec.Port == 443 || strings.HasPrefix(portName, "https") {
|
if portSpec.Port == 443 || strings.HasPrefix(portSpec.Name, "https") {
|
||||||
protocol = "https"
|
protocol = "https"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -12,7 +12,7 @@ import (
|
||||||
|
|
||||||
// MustParseYaml parses a YAML to objects.
|
// MustParseYaml parses a YAML to objects.
|
||||||
func MustParseYaml(content []byte) []runtime.Object {
|
func MustParseYaml(content []byte) []runtime.Object {
|
||||||
acceptedK8sTypes := regexp.MustCompile(`^(Deployment|Endpoints|Service|Ingress|IngressRoute|IngressRouteTCP|IngressRouteUDP|Middleware|Secret|TLSOption|TLSStore|TraefikService|IngressClass|ServersTransport|GatewayClass|Gateway|HTTPRoute)$`)
|
acceptedK8sTypes := regexp.MustCompile(`^(Deployment|Endpoints|Service|Ingress|IngressRoute|IngressRouteTCP|IngressRouteUDP|Middleware|Secret|TLSOption|TLSStore|TraefikService|IngressClass|ServersTransport|GatewayClass|Gateway|HTTPRoute|TCPRoute|TLSRoute)$`)
|
||||||
|
|
||||||
files := strings.Split(string(content), "---")
|
files := strings.Split(string(content), "---")
|
||||||
retVal := make([]runtime.Object, 0, len(files))
|
retVal := make([]runtime.Object, 0, len(files))
|
||||||
|
|
Loading…
Reference in a new issue