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

Implement mutual TLS authentication support for Ingress #3532

Merged
merged 6 commits into from
Jan 26, 2024

Conversation

shraddhabang
Copy link
Collaborator

@shraddhabang shraddhabang commented Jan 17, 2024

Issue

#3499

Description

Support for (mTLS) Mutual Transport Layer Security on Ingress through AWS LB Controller

This PR adds the support for mutual TLS authentication support for Ingress. Its delivers mTLS feature by integrating the Trust Stores into listener management. The customer will be able to set the mTLS mode and will be able to provide the existing Trust Store Name/ARN (they have created through CLI/Console) through new annotations for Ingress.

New Ingress Annotation

alb.ingress.kubernetes.io/mutual-authentication
Type: string
Default Value: '[{"port": 443, "mode": "off"}]'
# port: listen port
# mode: "off" (deafult) | "passthrough" | "verify"
# trustStore: "arn:aws:elasticloadbalancing:trustStoreArn" or "my-trust-store"// required when the mode is "verify"
# ignoreClientCertificateExpiry : true | false (default)
Example
# Listen port configuration
alb.ingress.kubernetes.io/listen-ports: '[{"HTTPS": 80}, {"HTTPS": 443}, {"HTTPS": 8080}, {"HTTPS": 8443}]'


# mTLS configuration
alb.ingress.kubernetes.io/mutual-authentication: '[{"port": 80, "mode": "passthrough"}, 
                                    {"port": 443, "mode": "verify", "trustStore": "arn:aws:elasticloadbalancing:trustStoreArn", "ignoreClientCertificateExpiry" : true}]'

We will identify the HTTPS listener based on its port and set the specified the mTLS configuration. So in the above example, we specified four HTTPS listeners with ports 80, 443, 8080, 8443. As per the annotation, the listener HTTPS:80 will be set to "passthrough” mode, the listener HTTPS:443 will be set to “verify” mode and will be associated with the provided trust-store-arn “arn:aws:elasticloadbalancing:trustStoreArn”. The remaining listeners HTTPS:8080 and HTTPS:8443 will be set to default mTLS mode i.e “off”.

New load balancer attributes for enabling connection logs for Ingresses and IngressGroup

We are also adding the support for connection logs support similar to what we support for access logs today for ALB.

Example on Ingress annotation
alb.ingress.kubernetes.io/load-balancer-attributes: connection_logs.s3.enabled=true,connection_logs.s3.bucket=my-connection-log-bucket,access_logs.s3.prefix=my-app
Example on IngressClassParams specification
apiVersion: elbv2.k8s.aws/v1beta1
kind: IngressClassParams
metadata:
    name: awesome-class
spec:
  loadBalancerAttributes:
  - key: connection_logs.s3.enabled
    value: "true"
  - key: connection_logs.s3.bucket
    value: "my-connection-logs"  
  - key: connection_logs.s3.prefix
    value: "myapp"

More : https://docs.aws.amazon.com/elasticloadbalancing/latest/application/mutual-authentication.html

Checklist

  • Added tests that cover your change (if possible) - Added some unit tests
  • Added/modified documentation as required (such as the README.md, or the docs directory) - Will raise separate PR for this
  • Manually tested
    • Verified the config set on ingress annotation for mTLS is reflected on the associated ALB for all the modes while creating and modifying listener
    • Verified the trustStore name is accepted through ingress annotation and controller was able to fetch the associated trust-store-arn and create and modify the listener properly
    • Verified that the ingress class param is accepted and given precedence over ingress annotation
    • Manually tested input validations
    • Verified the new connection logs attribute is being updated through ingress annotation
  • Made sure the title of the PR is a good description that can go into the release notes

BONUS POINTS checklist: complete for good vibes and maybe prizes?! 🤯

  • Backfilled missing tests for code in same general area 🎉
  • Refactored something and made the world a better place 🌟

@k8s-ci-robot k8s-ci-robot added the cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. label Jan 17, 2024
@k8s-ci-robot
Copy link
Contributor

Hi @shraddhabang. Thanks for your PR.

I'm waiting for a kubernetes-sigs member to verify that this patch is reasonable to test. If it is, they should reply with /ok-to-test on its own line. Until that is done, I will not automatically test new commits in this PR, but the usual testing commands by org members will still work. Regular contributors should join the org to skip this step.

Once the patch is verified, the new status will be reflected by the ok-to-test label.

I understand the commands that are listed here.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

@k8s-ci-robot k8s-ci-robot added needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. labels Jan 17, 2024
@oliviassss
Copy link
Collaborator

/ok-to-test

@k8s-ci-robot k8s-ci-robot added ok-to-test Indicates a non-member PR verified by an org member that is safe to test. and removed needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. labels Jan 17, 2024
@shraddhabang
Copy link
Collaborator Author

/retest

@codecov-commenter
Copy link

codecov-commenter commented Jan 18, 2024

Codecov Report

Attention: 118 lines in your changes are missing coverage. Please review.

Comparison is base (0b82ebb) 55.75% compared to head (a10b7de) 55.11%.

❗ Current head a10b7de differs from pull request most recent head 5db0cc7. Consider uploading reports for the commit 5db0cc7 to get more accurate results

Files Patch % Lines
pkg/ingress/model_build_listener.go 15.38% 97 Missing and 2 partials ⚠️
pkg/deploy/elbv2/listener_manager.go 7.69% 11 Missing and 1 partial ⚠️
pkg/ingress/model_builder.go 65.00% 5 Missing and 2 partials ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #3532      +/-   ##
==========================================
- Coverage   55.75%   55.11%   -0.64%     
==========================================
  Files         149      149              
  Lines        8843     8979     +136     
==========================================
+ Hits         4930     4949      +19     
- Misses       3579     3691     +112     
- Partials      334      339       +5     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

go.mod Outdated Show resolved Hide resolved
if exists := t.annotationParser.ParseStringAnnotation(annotations.IngressSuffixMutualAuthentication, &rawMtlsConfigString, ing.Ing.Annotations); !exists {
if !fromIngressClassParams {
return map[int64]*elbv2model.MutualAuthenticationAttributes{443: {
Mode: string(elbv2model.MutualAuthenticationOffMode),
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What if the users do not have port 443 in the listeners (like they have port 8080), and neither do they specify the mtls setting?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

also need to call out the default mtls in the ingress annotation and ingress class param doc.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will be ignored then while building the Listener SDK request since we only map the port and their respective setting in mTLS.

@torredil
Copy link
Member

/retest

@shraddhabang
Copy link
Collaborator Author

/retest

1 similar comment
@shraddhabang
Copy link
Collaborator Author

/retest

@@ -107,6 +109,10 @@ type IngressClassParamsSpec struct {
// +optional
SSLPolicy string `json:"sslPolicy,omitEmpty"`

// MutualAuthentication specifies the mutual TLS authentication config for all Ingresses that belong to IngressClass with this IngressClassParams.
// +optional
MutualAuthentication *MutualAuthentication `json:"mutualAuthentication,omitempty"`
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

type MutualAuthentication struct {
Mode ...
TrustStoreArn...
}
type IngressClassParamsSpec struct {
....

// MutualAuthentication specifies the mutual TLS authentication config for all Ingresses that belong to IngressClass with this IngressClassParams.
// +optional
MutualAuthentication *MutualAuthentication `json:"mutualAuthentication,omitempty"`

}

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As discussed, removed the support for IngressClassParam from this release. We will add a documentation update which will specify that warning to use mTLS config on IngressGroups. Thanks for the review.
We will add the IngressClassParam support for mTLS in follow up patch release.

@oliviassss oliviassss added the tide/merge-method-squash Denotes a PR that should be squashed by tide when it merges. label Jan 24, 2024
Copy link
Collaborator

@M00nF1sh M00nF1sh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm
/approve

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Jan 26, 2024
@k8s-ci-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: M00nF1sh, shraddhabang

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@k8s-ci-robot k8s-ci-robot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Jan 26, 2024
@k8s-ci-robot k8s-ci-robot merged commit d0c13bf into kubernetes-sigs:main Jan 26, 2024
9 checks passed
johngmyers pushed a commit to johngmyers/aws-load-balancer-controller that referenced this pull request Feb 6, 2024
…igs#3532)

* Implement mutual TLS authentication support for Ingress

* Addressing comments and adding policy updates

* Adding dependency for maps

* removing ingressClassParam support
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. lgtm "Looks good to me", indicates that a PR is ready to be merged. ok-to-test Indicates a non-member PR verified by an org member that is safe to test. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. tide/merge-method-squash Denotes a PR that should be squashed by tide when it merges.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants