- 
                Notifications
    You must be signed in to change notification settings 
- Fork 9
          feat: Support certificateAuthorityCertSecretRef on TwingateResource CRD
          #807
        
          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
base: main
Are you sure you want to change the base?
Conversation
| example_cluster_ip_gateway_service_body, "default" | ||
| ) | ||
|  | ||
| def test_kubernetes_resource_type_annotation_with_invalid_secret_type( | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
These tests are moved to test_utils_k8s
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pull Request Overview
This PR adds support for referencing Kubernetes Secret objects in the TwingateResource CRD to manage certificate authority certificates, providing an alternative to inline certificate strings.
- Add certificateAuthorityCertSecretReffield toTwingateResourceCRD schema with validation
- Update resource creation handlers to use secret references instead of inline certificates
- Extract certificate handling utilities to shared utils_k8smodule for better code organization
Reviewed Changes
Copilot reviewed 11 out of 11 changed files in this pull request and generated 2 comments.
Show a summary per file
| File | Description | 
|---|---|
| deploy/twingate-operator/crds/twingate.com.twingateresources.yaml | Updates CRD schema to support certificateAuthorityCertSecretRefwith oneOf validation | 
| app/crds.py | Adds secret reference support to ResourceProxyclass with certificate retrieval logic | 
| app/utils_k8s.py | Extracts and consolidates Kubernetes secret handling utilities | 
| app/handlers/handlers_services.py | Updates service handler to use secret references instead of inline certificates | 
| tests_integration/test_resource_flows.py | Adds comprehensive integration test for Kubernetes resource flows with secret references | 
| tests_integration/test_crds_resource.py | Adds validation tests for new CRD schema constraints | 
| app/tests/test_*.py | Updates unit tests to use extracted utilities and test new functionality | 
| tests_integration/utils.py | Adds utility function for log message validation | 
| app/conftest.py | Moves shared test fixture to common location | 
Tip: Customize your code reviews with copilot-instructions.md. Create the file or learn how to get started.
693f5d5    to
    fe84bfc      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix & merge!
        
          
                app/utils_k8s.py
              
                Outdated
          
        
      | f"Kubernetes Secret object: {tls_secret_name} type is invalid." | ||
| ) | ||
|  | ||
| if not (ca_cert := tls_secret.data.get("ca.crt")): | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This ca.crt is a convention in Gateway. I think it's good enough for now. Later we might want to make it customizable like ACMEIssuer.privateKeySecretRef in cert-manager.
PrivateKey is the name of a Kubernetes Secret resource that will be used to store the automatically generated ACME account private key. Optionally, a key may be specified to select a specific entry within the named Secret resource. If key is not specified, a default of tls.key will be used.
a850ad4    to
    9ea0ddb      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fix & merge!
        
          
                app/utils_k8s.py
              
                Outdated
          
        
      | raise | ||
|  | ||
|  | ||
| def k8s_get_secret(namespace: str, name: str) -> kubernetes.client.V1Secret | None: | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Other methods in this module also get the kapi: kubernetes.client.CoreV1Api | None = None kwarg and only instanciate a new CoreV1API if not given one.
Lets keep the same behavior here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, agree! I also updated the naming to k8s_read_namespaced_secret to  match other methods in this module
        
          
                app/utils_k8s.py
              
                Outdated
          
        
      | raise | ||
|  | ||
|  | ||
| def get_ca_cert(secret: kubernetes.client.V1Secret) -> str: | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wonder if this should be here because its not purely a "k8s utility" thats general - its very specific to the CA secret of ResourceProxy - maybe it should be there?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Moved the method to ResourceProxy
| "certificateAuthorityCert": base64.b64encode( | ||
| ResourceProxy.read_certificate_authority_cert_from_secret( | ||
| secret | ||
| ).encode() | ||
| ).decode(), | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is conversion is temporary, it'll be removed in this PR
| Pull Request Test Coverage Report for Build 18672859610Details
 
 
 💛 - Coveralls | 
75ba988    to
    e31b36e      
    Compare
  
    
Changes
certificateAuthorityCertSecretRefonTwingateResourceCRD. This enables Kubernetes Resource CRD to reference K8s secret object to update/reconcile the certificate authority cert value on Twingate via Public API.k8s_get_secrettoutils_k8sget_ca_certtoResourceProxy