--- apiVersion: v1 kind: Secret metadata: name: supersecret namespace: default data: tls.crt: LS0tLS1CRUdJTiBDRVJUSUZJQ0FURS0tLS0tCi0tLS0tRU5EIENFUlRJRklDQVRFLS0tLS0= tls.key: LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCi0tLS0tRU5EIFBSSVZBVEUgS0VZLS0tLS0= --- kind: GatewayClass apiVersion: gateway.networking.k8s.io/v1 metadata: name: my-gateway-class namespace: default spec: controllerName: traefik.io/gateway-controller --- kind: Gateway apiVersion: gateway.networking.k8s.io/v1 metadata: name: my-tls-gateway namespace: default spec: gatewayClassName: my-gateway-class listeners: # Use GatewayClass defaults for listener definition. - name: tls protocol: TLS hostname: foo.example.com port: 9000 tls: mode: Passthrough allowedRoutes: kinds: - kind: TLSRoute group: gateway.networking.k8s.io namespaces: from: Same --- kind: TLSRoute apiVersion: gateway.networking.k8s.io/v1alpha2 metadata: name: tls-app-1 namespace: default spec: parentRefs: - name: my-tls-gateway kind: Gateway group: gateway.networking.k8s.io rules: - backendRefs: - name: whoamitcp port: 9000 weight: 1 kind: Service group: ""