Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

TransportServer with TLS support #3637

Closed
visokoo opened this issue Nov 4, 2024 · 13 comments
Closed

TransportServer with TLS support #3637

visokoo opened this issue Nov 4, 2024 · 13 comments

Comments

@visokoo
Copy link

visokoo commented Nov 4, 2024

Setup Details

CIS Version : 2.17.1
Build: f5networks/k8s-bigip-ctlr:2.17.1
BIGIP Version:
BIG-IP 15.1.10.2 Build 0.44.2 Engineering Hotfix
AS3 Version: 3.44.0
Agent Mode: AS3
Orchestration: K8S
Orchestration Version: 1.27.15+rke2r1
Pool Mode: Nodeport
Additional Setup details:

Description

Hi there, we have a use case where we're trying to deploy a non-http service (nats) that runs on port 4222 but we'd like to enable TLS with it. Looking at the documentation, it looks like we should be deploying a TransportServer to achieve what we want, however, looking at the CRDs, it doesn't look like we're able to specify a TLSProfile like we can with a VirtualServer CRD. However, on the F5 UI itself, the option to select a TLSProfile is available and can be selected. We've tested manually selecting this on the F5 UI and have confirmed that TLS works, though we're also getting some IO timeout issues as well.

Steps To Reproduce

  1. Deploy any service that's listening on a port that's not 80 or 443
  2. Deploy a TLSProfile and a TransportServer

Expected Result

Ability to attach a TLSProfile like you would be able to with a VirtualServer

Actual Result

No option is available to do this.

If this is not the correct way to do it, would someone kindly advise a way forward for us?

@visokoo visokoo added bug untriaged no JIRA created labels Nov 4, 2024
@visokoo
Copy link
Author

visokoo commented Nov 4, 2024

Also, we're using the f5-ipam controller with InfoBlox configured for DNS. When configuring the host field for the TransportServer, it doesn't seem to be updating anything in InfoBlox either. Adding the DNS entry manually works but is there no functionality for TransportServers?

@vidyasagar-m
Copy link
Contributor

@visokoo Could you provide more information on the tls profile. Do you want to attach the existing BIGIP ClientSSL and ServerSSL Profiles or you want to use Kubernetes secrets to provide the TLS information.

@trinaths
Copy link
Contributor

Created [CONTCNTR-4970] for internal tracking.

@trinaths trinaths added JIRA and removed untriaged no JIRA created labels Nov 15, 2024
@vidyasagar-m
Copy link
Contributor

@visokoo Could you verify the Transport Server TLS functionality with this UBI9 image quay.io/mvsr222/k8s-bigip-ctlr:transportServerTLS.

Examples:
TLS BIGIP Reference:

apiVersion: cis.f5.com/v1
  kind: TransportServer
  metadata:
    annotations:
      kubectl.kubernetes.io/last-applied-configuration: |
        {"apiVersion":"cis.f5.com/v1","kind":"TransportServer","metadata":{"annotations":{},"creationTimestamp":"2024-11-18T14:52:31Z","generation":2,"labels":{"f5cr":"true"},"name":"svc1-tcp-transport-server","namespace":"default","resourceVersion":"38870856","uid":"03c71fc6-7129-45d6-9b7a-3fecb0213038"},"spec":{"bigipRouteDomain":0,"mode":"standard","pool":{"monitor":{"interval":20,"timeout":10,"type":"tcp"},"name":"latte.pool-coffee.-ts","service":"pytest-svc-1","servicePort":443},"snat":"auto","tls":{"clientSSLs":["foo-secret","qa.foo-secret","stage.foo-secret"],"reference":"secret","serverSSLs":["foo-back-secret","qa.foo-back-secret","stage.foo-back-secret"]},"virtualServerAddress":"10.8.0.72","virtualServerName":"svc1-tcp-ts.coffee","virtualServerPort":443},"status":{"lastUpdated":"2024-11-18T15:00:37Z","status":"OK","vsAddress":"10.8.0.72"}}
    creationTimestamp: "2024-11-19T05:26:00Z"
    generation: 1
    labels:
      f5cr: "true"
    name: svc1-tcp-transport-server
    namespace: default
    resourceVersion: "39104398"
    uid: 2c795eb0-7d29-4ad5-b08d-4f914a7c4d16
  spec:
    bigipRouteDomain: 0
    mode: standard
    pool:
      monitor:
        interval: 20
        timeout: 10
        type: tcp
      name: latte.pool-coffee.-ts
      service: pytest-svc-1
      servicePort: 443
    snat: auto
    tls:
      clientSSLs:
      - /Common/clientssl
      reference: bigip
      serverSSLs:
      - /Common/serverssl
    virtualServerAddress: 10.8.0.72
    virtualServerName: svc1-tcp-ts.coffee
    virtualServerPort: 443

TLS Secret Reference:

apiVersion: cis.f5.com/v1
  kind: TransportServer
  metadata:
    annotations:
    labels:
      f5cr: "true"
    name: svc1-tcp-transport-server
    namespace: default
  spec:
    bigipRouteDomain: 0
    mode: standard
    pool:
      monitor:
        interval: 20
        timeout: 10
        type: tcp
      name: latte.pool-coffee.-ts
      service: pytest-svc-1
      servicePort: 443
    snat: auto
    tls:
      clientSSLs:
      - foo-secret
      - qa.foo-secret
      - stage.foo-secret
      reference: secret
      serverSSLs:
      - foo-back-secret
      - qa.foo-back-secret
      - stage.foo-back-secret
    virtualServerAddress: 10.8.0.72
    virtualServerName: svc1-tcp-ts.coffee
    virtualServerPort: 443

vidyasagar-m added a commit to vidyasagar-m/k8s-bigip-ctlr that referenced this issue Nov 19, 2024
vidyasagar-m added a commit that referenced this issue Nov 19, 2024
* rebasing from the source

* update resource config

* fix uts
@visokoo
Copy link
Author

visokoo commented Nov 22, 2024

Hey @vidyasagar-m,

Apologies for the delay in my response, I just got back from PTO.

I'd like to be able to specify the TLSProfile like how we do in VirtualServers currently.

apiVersion: cis.f5.com/v1
kind: VirtualServer
metadata:
  labels:
    f5cr: 'true'
  name: https-virtual-server
  namespace: ingress-nginx
spec:
  host: '*.dev.<redacted>.<redacted>.<redacted>.com'
  httpTraffic: allow
  ipamLabel: vips
  pools:
    - monitor:
        interval: 10
        send: /
        timeout: 31
        type: http
      path: /
      service: rke2-ingress-nginx-controller
      servicePort: 80
  tlsProfileName: edge-dev
  virtualServerAddress: 10.160.151.4
  virtualServerHTTPPort: 80
  virtualServerHTTPSPort: 443

tlsProfileName would refer to a created TLSProfile resource that's created beforehand.

I know you created the image already, but is it possible to update it to reference it like how we do with VirtualServers for consistency?

@vidyasagar-m
Copy link
Contributor

@vklohiya
Copy link
Contributor

vklohiya commented Dec 2, 2024

@visokoo , tlsProfile is supported with the VS CR only as it allows us to support the multiple domains using single Virtual server ip, along with various terminations like edge, passthrough and re-encrypt. Combining the TLSProfile with the Transport Server will also impact the overall performance of CIS.

@vklohiya
Copy link
Contributor

vklohiya commented Dec 2, 2024

Also, we're using the f5-ipam controller with InfoBlox configured for DNS. When configuring the host field for the TransportServer, it doesn't seem to be updating anything in InfoBlox either. Adding the DNS entry manually works but is there no functionality for TransportServers?

CIS does not create any DNS entry on the Infoblox server. It only requests the IP Address from the Infoblox and release the Ip address once the resource is deleted.

@visokoo
Copy link
Author

visokoo commented Dec 6, 2024

@vklohiya,

Pardon my delay and thank you for the explanation in regards to tlsProfile. I've tested this image and it will work for my use case. Do we know when this will be released to 2.19?

@trinaths
Copy link
Contributor

trinaths commented Dec 7, 2024

@visokoo We are working on validating 2.19.

2.19 ETA ~ End of December'24.

@visokoo
Copy link
Author

visokoo commented Jan 7, 2025

Any update on this @trinaths @vklohiya?

@trinaths
Copy link
Contributor

trinaths commented Jan 8, 2025

@visokoo CIS 2.19 is due this week. This issue is fixed in 2.19.

vklohiya pushed a commit to vklohiya/k8s-bigip-ctlr that referenced this issue Jan 8, 2025
* rebasing from the source

* update resource config

* fix uts
@trinaths
Copy link
Contributor

RFE supported in 2.19

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants