From 4af6e22f7f9752f61e44038e86dfffca98928d0b Mon Sep 17 00:00:00 2001 From: Aleksei Sizov Date: Mon, 14 Oct 2024 10:38:54 -0500 Subject: [PATCH] Add credential propagation docs --- docs/credential/main.md | 57 ++++++++++++++++++++++++++++++++++++++++- 1 file changed, 56 insertions(+), 1 deletion(-) diff --git a/docs/credential/main.md b/docs/credential/main.md index 8fac23b..ade2fc2 100644 --- a/docs/credential/main.md +++ b/docs/credential/main.md @@ -11,7 +11,7 @@ The following is the process of passing credentials to the system: 2. `Credential` object is created referencing `ClusterIdentity` from step **1**. 3. The `Credential` object is then referenced in the `ManagedCluster`. -By design steps 1 and 2 should be executed by the platform lead engender who has +By design steps 1 and 2 should be executed by the platform lead engineer who has access to the credentials. Thus credentials could be used by platform engineers without a need to have access to actual credentials or underlying resources, like `ClusterIndentity`. @@ -47,3 +47,58 @@ which was created in the `hmc-system` namespace. The `.spec.description` field can be used to provide arbitrary description of the object, so user could make a decision which credentials to use if several are present. + +## Cloud provider credentials propagation + +Some components in the managed cluster require cloud provider credentials to be +passed for proper functioning. As an example cloud controller manager (CCM) +requires provider credentials to create load balancers and provide other +functionality. + +This poses a challenge of credentials delivery. Currently `cloud-init` is used +to pass all necessary credentials. This approach has several problems: + +- Credentials stored unencrypted in the instance metadata. +- Rotation of the credentials is impossible without complete instance + redeployment. +- Possible leaks, since credentials are copied to several `Secret` objects + related to bootstrap data. + +To solve these problems in Project 2A we're using special controller which +aggregates all necessary data from CAPI provider resources (like +`ClusterIdentity`) and creates `Secrets` directly on the managed cluster. + +This eliminates the need to pass anything credentials-related to `cloud-init` +and makes it possible to rotate credentials automatically without the need for +instance redeployment. + +Also this automation makes it possible to separate roles and responsibilities +where only platform lead has access to credentials and platform engineer can +only use them without seeing concrete values and even any access to underlying +infrastructure platform. + +The process is fully automated and credentials will be propagated automatically +within `ManagedCluster` reconcile process, user only needs to provide correct +[Credential object](#credential-object). + +### Provider specific notes + +Since this feature highly depends on the provider some notes and clarifications +are needed. + +>? NOTE: **Research notes** +> More detailed research notes could be found [here](https://github.com/Mirantis/hmc/issues/293) + +#### AWS + +Since AWS uses roles, which are assigned to instances, no additional credentials +will be created. + +#### Azure + +Currently Cluster API provider Azure (CAPZ) creates `azure.json` Secrets in the +same namespace with `Cluster` object. By design they should be referenced in the +`cloud-init` yaml later during bootstrap process. + +In Project 2A these Secrets aren't used and will not be added to the +`cloud-init`, but platform engineer can access them unrestricted.