diff --git a/docs/adr/0023-allow-snippets-annotations.md b/docs/adr/0023-allow-snippets-annotations.md index b5f771c4715..86b160addae 100644 --- a/docs/adr/0023-allow-snippets-annotations.md +++ b/docs/adr/0023-allow-snippets-annotations.md @@ -1,6 +1,6 @@ -# Only allow Ingress Configuration Snippet Annotations after Proper Risk Acceptance +# [Superseded by [ADR-0056](0056-allow-snippets-annotations-after-risk-acceptance.md)] Only allow Ingress Configuration Snippet Annotations after Proper Risk Acceptance -- Status: accepted +- Status: Superseded by [ADR-0056](0056-allow-snippets-annotations-after-risk-acceptance.md) - Deciders: architecture meeting - Date: 2022-08-11 diff --git a/docs/adr/0056-allow-snippets-annotations-after-risk-acceptance.md b/docs/adr/0056-allow-snippets-annotations-after-risk-acceptance.md new file mode 100644 index 00000000000..0b66ce4b816 --- /dev/null +++ b/docs/adr/0056-allow-snippets-annotations-after-risk-acceptance.md @@ -0,0 +1,69 @@ +# Only allow Ingress Snippet Annotations after Proper Risk Acceptance + +- Status: Accepted +- Deciders: Product Team +- Date: 2024-11-07 + +## Context and Problem Statement + +We previously decided to allow [configuration snippet annotations](https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/annotations/#configuration-snippet) for Ingress NGINX, but only after formal risk acceptance from the Application Developer. However, we had not yet decided on handling specific use cases, such as whether [server snippets](https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/annotations/#server-snippet) should have stricter controls due to their higher risk profile. + +The difference is that config snippets allows to configure for whole location blocks and are validated by the Ingress Controller, while server snippets allows to configure for whole server block and are not validated by the Ingress Controller, they are passed directly to NGINX, which increases the vulnerability exposure area. + +[Snippet Annotations](https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/annotations/) are a powerful tool to allow injecting custom configurations, including both configuration and server snippets, into the Ingress NGINX Controller. For example, it allows things such as header renaming, custom authentication, or other advanced use cases etc. + +However, with great power comes great responsibility. Snippet annotations may break the Ingress Controller and cause downtime for all applications hosted in the Workload Cluster. Also, it opens up [CVE-2021-25742](https://github.com/kubernetes/ingress-nginx/issues/7837), and possibly other CVEs, which means that Application Developers can exfiltrate all Secrets in the Workload Cluster. + +How shall we best serve Application Developers without compromising platform stability and security? + +## Decision Drivers + +- We want to best serve Application Developers. +- We want to ensure platform stability and security. + +## Considered Options + +- Allow `the use of "snippet annotations" with Ingress` by default. +- Disallow `the use of "snippet annotations" with Ingress` by default. +- Never allow `the use of "snippet annotations" with Ingress`. +- Allow `the use of "snippet annotations" with Ingress`, but only after Application Developer accepted the downtime and security risks. + +## Decision Outcome + +Chosen option: Allow `the use of "snippet annotations" with Ingress`, but only after Application Developer accepted the downtime and security risks. + +### Positive Consequences + +- Several use-cases commonly requested by Application Developers can be satisfied. + +### Negative Consequences + +- Platform security is at a small risk if this feature is misused by Application Developers. +- Platform stability is at a small risk if this feature is misused by Application Developers. + +## Recommendation to Platform Administrators + +If you enable this feature, then make sure Application Developers understand and accept the added stability and security risks. A message as follows could be used: + +```text +Hello! + +After talking with the team, we have decided that it is okay to enable the snippet annotations provided that: + +(a) There is no alternative method to achieve the required customization; +(b) The Application Developers fully understands and accepts the security risks involved; +(c) The Application Developers takes responsibility for any downtime caused by misconfiguration; and +(d) The Application Developers takes responsibility for updating the annotation as required. + +For (a), please confirm you have evaluated and ruled out other options. + +For (b), confirm you understand and accept potential vulnerabilities, such as CVEs like https://github.com/kubernetes/ingress-nginx/issues/7837. + +For (c), please confirm that you understand that this snippet annotations is quite powerful, meaning that misconfiguration can lead to downtime for all your Ingress resources. Obviously, if Nginx goes down due to any custom configuration, then we cannot take responsibility for that. + +For (d), please confirm that you are okay to take responsibility for making sure that the custom configuration is supported in newer versions of Nginx, as we sometimes upgrade Nginx. Both our release notes and calendar invites for the maintenance windows mention if we are upgrading Nginx. + +To sum up, if you can confirm (a)-(d) then we can proceed with enabling snippet annotations for your use case. + +Regards, +``` diff --git a/docs/adr/index.md b/docs/adr/index.md index 880893d0210..0538946e889 100644 --- a/docs/adr/index.md +++ b/docs/adr/index.md @@ -99,7 +99,7 @@ This log lists the architectural decisions for Welkin. - [ADR-0020](0020-filter-by-cluster-label-then-data-source.md) - Filter by cluster label then data source - [ADR-0021](0021-tls-for-additional-services.md) - Default to TLS for performance-insensitive additional services - [ADR-0022](0022-use-dedicated-nodes-for-additional-services.md) - Use Dedicated Nodes for Additional Services -- [ADR-0023](0023-allow-snippets-annotations.md) - Only allow Ingress Configuration Snippet Annotations after Proper Risk Acceptance +- [ADR-0023](0023-allow-snippets-annotations.md) - [Superseded by [ADR-0056](0056-allow-snippets-annotations-after-risk-acceptance.md)] Only allow Ingress Configuration Snippet Annotations after Proper Risk Acceptance - [ADR-0024](0024-allow-Harbor-robot-account.md) - Allow a Harbor robot account that can create other robot accounts with full privileges - [ADR-0025](0025-local-storage.md) - Use local-volume-provisioner for Managed Services that requires high-speed disks - [ADR-0026](0026-hnc.md) - Use `environment-name` as the default root of Hierarchical Namespace Controller (HNC) @@ -132,6 +132,7 @@ This log lists the architectural decisions for Welkin. - [ADR-0053](0053-do-not-expose-platform-observability-services-to-end-users.md) - Do not expose platform observability services to end-users - [ADR-0054](0054-allow-write-access-to-endpoints-and-endpointslices-after-risk-acceptance.md) - Allow Application Developer write access to Endpoints and EndpointSlices after Proper Risk Acceptance - [ADR-0055](0055-welkin-to-consist-of-both-public-and-private-open-source.md) - Welkin to consist of both public and private open source +- [ADR-0056](0056-allow-snippets-annotations-after-risk-acceptance.md) - Only allow Ingress Snippet Annotations after Proper Risk Acceptance