fix markdown formatting and update status conditions

Signed-off-by: Sanskar Jaiswal <jaiswalsanskar078@gmail.com>
pull/3081/head
Sanskar Jaiswal 2 years ago
parent a17210f387
commit f3da59e5af

@ -5,15 +5,17 @@
**Creation Date:** 2022-09-08 **Creation Date:** 2022-09-08
## Summary ## Summary
Flux should have a consistent way of disabling insecure HTTP connections. Flux should have a consistent way of disabling insecure HTTP connections.
At the controller level, a flag should be present which would disable all outgoing HTTP connections. At the controller level, a flag should be present which would disable all outgoing HTTP connections.
At the object level, a field should be provided which would enable the use of non-TLS endpoints. At the object level, a field should be provided which would enable the use of non-TLS endpoints.
If the use of a non-TLS endpoint is not supported, it should be made clear to users through the use of If the use of a non-TLS endpoint is not supported, reconciliation will fail and the object will be marked
logs and status conditions. as stalled, signalling that human intervention is required.
## Motivation ## Motivation
Today the use of non-TLS based connections is inconsistent across Flux controllers. Today the use of non-TLS based connections is inconsistent across Flux controllers.
Controllers that deal only with `http` and `https` schemes have no way to block use of the `http` scheme at controller-level. Controllers that deal only with `http` and `https` schemes have no way to block use of the `http` scheme at controller-level.
@ -21,17 +23,20 @@ Some Flux objects provide a `.spec.insecure` field to enable the use of non-TLS
users when the option is not supported (e.g. Azure/GCP Buckets). users when the option is not supported (e.g. Azure/GCP Buckets).
### Goals ### Goals
* Provide a flag across relevant Flux controllers which disables all outgoing HTTP connections. * Provide a flag across relevant Flux controllers which disables all outgoing HTTP connections.
* Add a field which enables the use of non-TLS endpoints to appropriate Flux objects. * Add a field which enables the use of non-TLS endpoints to appropriate Flux objects.
* Provide a way for users to be made aware that their use of non-TLS endpoints is not supported if that is the case. * Provide a way for users to be made aware that their use of non-TLS endpoints is not supported if that is the case.
### Non-Goals ### Non-Goals
* Break Flux's current behavior of allowing HTTP connections. * Break Flux's current behavior of allowing HTTP connections.
* Change in behavior of communication between Flux components. * Change in behavior of communication between Flux components.
## Proposal ## Proposal
### Controllers ### Controllers
Flux users should be able to enforce that controllers are using HTTPS connections only. Flux users should be able to enforce that controllers are using HTTPS connections only.
This shall be enabled by adding a new boolean flag `--insecure-allow-http` to the following controllers: This shall be enabled by adding a new boolean flag `--insecure-allow-http` to the following controllers:
* source-controller * source-controller
@ -60,27 +65,24 @@ spec:
- --insecure-allow-http=false - --insecure-allow-http=false
``` ```
> Note: The flag shall not be added to the following controllers: **Note:** The flag shall not be added to the following controllers:
> * kustomize-controller: This flag is excluded from this controller, as the upstream `kubenetes-sigs/kustomize` project * kustomize-controller: This flag is excluded from this controller, as the upstream `kubenetes-sigs/kustomize` project
> does not support disabling HTTP connections while fetching resources from remote bases. We can revisit this if the does not support disabling HTTP connections while fetching resources from remote bases. We can revisit this if the
> upstream project adds support for this at a later point in time. upstream project adds support for this at a later point in time.
> * helm-controller: This flag does not serve a purpose in this controller, as the controller does not make any HTTP calls. * helm-controller: This flag does not serve a purpose in this controller, as the controller does not make any HTTP calls.
> Furthermore although both controllers can also do remote applies, serving `kube-apiserver` over plain Furthermore although both controllers can also do remote applies, serving `kube-apiserver` over plain
> HTTP is disabled by default. While technically this can be enabled, the option for this configuration was also disabled HTTP is disabled by default. While technically this can be enabled, the option for this configuration was also disabled
> quite a while back (ref: https://github.com/kubernetes/kubernetes/pull/65830/). quite a while back (ref: https://github.com/kubernetes/kubernetes/pull/65830/).
Both kustomize-controller and helm-controller currently have a flag `--insecure-kubeconfig-tls` which makes the controller skip
TLS verification when connecting to a Kubernetes cluster with an HTTPS connection. This flag shall be renamed to
`--insecure-skip-tls-verify` to align it with the Flux CLI which offers this command for the same purpose.
### Objects ### Objects
Some Flux objects, like `GitRepository`, provide a field for specifying a URL, and the URL would contain the scheme. Some Flux objects, like `GitRepository`, provide a field for specifying a URL, and the URL would contain the scheme.
In such cases, the scheme can be used for inferring the transport type of the connection and consequently, In such cases, the scheme can be used for inferring the transport type of the connection and consequently,
whether to use HTTP or HTTPS connections for that object. whether to use HTTP or HTTPS connections for that object.
But there are a few objects that don't allow such behavior, for example: But there are a few objects that don't allow such behavior, for example:
* `ImageRepository`: It provides a field, `.spec.image`, which is used for specifying the URL of the image present on * `ImageRepository`: It provides a field, `.spec.image`, which is used for specifying the address of the image present on
a container registry. But any URL containing a scheme is considered invalid and HTTPS is the default transport used. a container registry. But any address containing a scheme is considered invalid and HTTPS is the default transport used.
This prevents users from using images present on insecure registries. This prevents users from using images present on insecure registries.
* OCI `HelmRepository`: When using an OCI registry as a Helm repository, the `.spec.url` is expected to begin with `oci://`. * OCI `HelmRepository`: When using an OCI registry as a Helm repository, the `.spec.url` is expected to begin with `oci://`.
Since the scheme part of the URL is used to specify the type of `HelmRepository`, there is no way for users to specify Since the scheme part of the URL is used to specify the type of `HelmRepository`, there is no way for users to specify
@ -90,6 +92,7 @@ For such objects, we shall introduce a new boolean field `.spec.insecure`, which
need their object to point to an HTTP endpoint, can set this to `true`. need their object to point to an HTTP endpoint, can set this to `true`.
### CLI ### CLI
The Flux CLI offers several commands for creating Flux specific resources. Some of these commands may involve specifying The Flux CLI offers several commands for creating Flux specific resources. Some of these commands may involve specifying
an endpoint such as creating an `OCIRepository`: an endpoint such as creating an `OCIRepository`:
@ -107,6 +110,7 @@ for the required commands, which will be used for specifying the value of `.spec
> when using an HTTPS connection. > when using an HTTPS connection.
### Precedence & Validity ### Precedence & Validity
Objects with `.spec.insecure` as `true ` will only be allowed if HTTP connections are allowed at the controller level. Objects with `.spec.insecure` as `true ` will only be allowed if HTTP connections are allowed at the controller level.
Similarly, an object can have `.spec.insecure` as `true` only if the Saas/Cloud provider allows HTTP connections. Similarly, an object can have `.spec.insecure` as `true` only if the Saas/Cloud provider allows HTTP connections.
For example, using a `Bucket` with its `.spec.provider` set to `azure` would be invalid since Azure doesn't allow For example, using a `Bucket` with its `.spec.provider` set to `azure` would be invalid since Azure doesn't allow
@ -115,6 +119,7 @@ HTTP connections.
### User Stories ### User Stories
#### Story 1 #### Story 1
> As a cluster admin of a multi-tenant cluster, I want to ensure all controllers access endpoints using only HTTPS > As a cluster admin of a multi-tenant cluster, I want to ensure all controllers access endpoints using only HTTPS
> regardless of tenants' object definitions. > regardless of tenants' object definitions.
@ -134,8 +139,8 @@ patches:
target: target:
kind: Deployment kind: Deployment
name: "(source-controller|notification-controller|image-reflector-controller|image-automation-controller)" name: "(source-controller|notification-controller|image-reflector-controller|image-automation-controller)"
# Since this above flag is not available in kustomize-controller for reasons explained in a previous section, # Since the above flag is not available in kustomize-controller for reasons explained in a previous section,
# we disable the Kustomize remote build by disallowing use of remote bases. This ensures that kustomize-controller # we disable Kustomize remote builds by disallowing use of remote bases. This ensures that kustomize-controller
# won't initiate any plain HTTP connections. # won't initiate any plain HTTP connections.
- patch: | - patch: |
- op: add - op: add
@ -147,6 +152,7 @@ patches:
``` ```
#### Story 2 #### Story 2
> As an application developer, I'm trying to debug a new image pushed to my local registry which > As an application developer, I'm trying to debug a new image pushed to my local registry which
> is not served over HTTPS. > is not served over HTTPS.
@ -164,14 +170,16 @@ spec:
``` ```
### Alternatives ### Alternatives
Instead of adding a flag, we can instruct users to make use of Kyverno policies to enforce that Instead of adding a flag, we can instruct users to make use of Kyverno policies to enforce that
all objects have `.spec.insecure` as `false` and any URLs present in the definition don't have `http` all objects have `.spec.insecure` as `false` and any URLs present in the definition don't have `http`
as the scheme. This is less attractive, as this would ask users to install another software and prevent as the scheme. This is less attractive, as this would ask users to install another software and prevent
Flux multi-tenancy from being standalone. Flux multi-tenancy from being standalone.
## Design Details ## Design Details
If a controller is started with `--insecure-allow-http=false`, any URL in a Flux object which has `http` If a controller is started with `--insecure-allow-http=false`, any URL in a Flux object which has `http`
as the scheme will result in an error and the following condition will be added to the object's as the scheme will result in an unsuccessful reconciliation and the following condition will be added to the object's
`.status.conditions`: `.status.conditions`:
```yaml ```yaml
@ -180,13 +188,13 @@ status:
- lastTransitionTime: "2022-09-06T09:14:21Z" - lastTransitionTime: "2022-09-06T09:14:21Z"
message: "Use of insecure HTTP connections isn't allowed for this controller" message: "Use of insecure HTTP connections isn't allowed for this controller"
observedGeneration: 1 observedGeneration: 1
reason: URLInvalid reason: InsecureConnectionsDisallowed
status: "True" status: "True"
type: FetchFailedCondition type: Stalled
``` ```
Similarly, if an object has `.spec.insecure` as `true` but the Cloud provider doesn't allow HTTP connections, Similarly, if an object has `.spec.insecure` as `true` but the Cloud provider doesn't allow HTTP connections,
the reconciler will error out and add the condition below to the object's `.status.conditions`: the reconciliation will fail and the following condition will be added to the object's `.status.conditions`:
```yaml ```yaml
status: status:
@ -194,9 +202,9 @@ status:
- lastTransitionTime: "2022-09-06T09:14:21Z" - lastTransitionTime: "2022-09-06T09:14:21Z"
message: "Use of insecure HTTP connections isn't allowed for Azure Storage" message: "Use of insecure HTTP connections isn't allowed for Azure Storage"
observedGeneration: 1 observedGeneration: 1
reason: InsecureConnectionsDisallowed reason: UnsupportedConnectionType
status: "True" status: "True"
type: FetchFailedCondition type: Stalled
``` ```
If an object has `.spec.insecure` as `true`, the registry client or bucket client shall be created with the use If an object has `.spec.insecure` as `true`, the registry client or bucket client shall be created with the use

Loading…
Cancel
Save