Updated diagrams and architecture text
Signed-off-by: Margo Crawford <margaretc@vmware.com>
This commit is contained in:
parent
4dbd8c9cae
commit
0b12b30cb1
@ -19,7 +19,7 @@ credential from an identity source (e.g., Pinniped Supervisor, proprietary IDP),
|
|||||||
authenticates the user via that credential, and returns another credential which is
|
authenticates the user via that credential, and returns another credential which is
|
||||||
understood by the host Kubernetes cluster.
|
understood by the host Kubernetes cluster.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/b78c4/b78c4727a311740a344a0ad56ff8f9ac87200e9a" alt="Pinniped Architecture Sketch"
|
data:image/s3,"s3://crabby-images/4fc18/4fc18faa093c59b212d3815aa85f6cf7da9cad1c" alt="Pinniped Architecture Sketch"
|
||||||
|
|
||||||
Pinniped supports various IDP types and implements different integration strategies
|
Pinniped supports various IDP types and implements different integration strategies
|
||||||
for various Kubernetes distributions to make authentication possible.
|
for various Kubernetes distributions to make authentication possible.
|
||||||
@ -111,16 +111,21 @@ cluster-specific credential via a
|
|||||||
Users may use the Pinniped CLI as the credential plugin, or they may use any proprietary CLI
|
Users may use the Pinniped CLI as the credential plugin, or they may use any proprietary CLI
|
||||||
built with the [Pinniped Go client library](https://github.com/vmware-tanzu/pinniped/tree/main/generated).
|
built with the [Pinniped Go client library](https://github.com/vmware-tanzu/pinniped/tree/main/generated).
|
||||||
|
|
||||||
## Example Cluster Authentication Sequence Diagrams
|
|
||||||
|
|
||||||
### Concierge With Webhook
|
## Pinniped Deployment Strategies
|
||||||
|
Pinniped can be configured to authenticate users in a variety of scenarios.
|
||||||
|
Depending on the use case, administrators can deploy the Supervisor, the Concierge,
|
||||||
|
both, or neither.
|
||||||
|
|
||||||
This diagram demonstrates using `kubectl get pods` with a [Kubernetes client-go credential plugin](https://kubernetes.io/docs/reference/access-authn-authz/authentication/#client-go-credential-plugins)
|
### Full Integration-- Concierge, Supervisor, and CLI
|
||||||
that obtains an external credential to be sent to a webhook authenticator via the Pinniped Concierge.
|
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/1afe1/1afe1e51b2f52b54bb269ae89c92540be6732378" alt="concierge-with-webhook-sequence-diagram"
|
Users can authenticate with the help of the Supervisor, which will issue tokens that
|
||||||
|
can be exchanged at the Concierge for a credential that is understood by the host Kubernetes
|
||||||
|
cluster.
|
||||||
|
The Supervisor enables users to log in to their external identity provider
|
||||||
|
once per day and access each cluster in a domain with a distinct scoped-down token.
|
||||||
|
|
||||||
### Concierge with Supervisor
|
data:image/s3,"s3://crabby-images/4fc18/4fc18faa093c59b212d3815aa85f6cf7da9cad1c" alt="concierge-with-supervisor-architecture-diagram"
|
||||||
|
|
||||||
This diagram demonstrates using `kubectl get pods` with the Pinniped CLI
|
This diagram demonstrates using `kubectl get pods` with the Pinniped CLI
|
||||||
functioning as a [Kubernetes client-go credential plugin](https://kubernetes.io/docs/reference/access-authn-authz/authentication/#client-go-credential-plugins)
|
functioning as a [Kubernetes client-go credential plugin](https://kubernetes.io/docs/reference/access-authn-authz/authentication/#client-go-credential-plugins)
|
||||||
@ -128,3 +133,31 @@ that obtains a federation ID token from the Pinniped Supervisor to be sent to a
|
|||||||
JWT authenticator via the Pinniped Concierge.
|
JWT authenticator via the Pinniped Concierge.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/df860/df8607da3e092c30f8719040f549889433980088" alt="concierge-with-supervisor-sequence-diagram"
|
data:image/s3,"s3://crabby-images/df860/df8607da3e092c30f8719040f549889433980088" alt="concierge-with-supervisor-sequence-diagram"
|
||||||
|
|
||||||
|
### Dynamic Cluster Authentication-- Concierge and CLI
|
||||||
|
|
||||||
|
Users can authenticate directly with their OIDC compliant external identity provider to get credentials which
|
||||||
|
can be exchanged at the Concierge for a credential that is understood by the host Kubernetes
|
||||||
|
cluster.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/b4eb2/b4eb2e0a8f522201efd309da24ef0ea795b0a78c" alt="concierge-with-webhook-architecture-diagram"
|
||||||
|
|
||||||
|
This diagram demonstrates using `kubectl get pods` with a [Kubernetes client-go credential plugin](https://kubernetes.io/docs/reference/access-authn-authz/authentication/#client-go-credential-plugins)
|
||||||
|
that obtains an external credential to be sent to a webhook authenticator via the Pinniped Concierge.
|
||||||
|
|
||||||
|
data:image/s3,"s3://crabby-images/1afe1/1afe1e51b2f52b54bb269ae89c92540be6732378" alt="concierge-with-webhook-sequence-diagram"
|
||||||
|
|
||||||
|
### Static Cluster Integration-- Supervisor and CLI
|
||||||
|
|
||||||
|
Users can authenticate with the help of the Supervisor, which will issue tokens that
|
||||||
|
can be given directly to a Kubernetes API Server that has been configured with
|
||||||
|
[OIDC Authentication.](https://kubernetes.io/docs/reference/access-authn-authz/authentication/#openid-connect-tokens)
|
||||||
|
The Supervisor enables users to log in to their external identity provider
|
||||||
|
once per day and access each cluster in a domain with a distinct scoped-down token.
|
||||||
|
|
||||||
|
### Minimal-- CLI only
|
||||||
|
|
||||||
|
Users can authenticate directly with their OIDC compliant external identity provider to get credentials
|
||||||
|
that can be given directly to a Kubernetes API Server that has been configured with
|
||||||
|
[OIDC Authentication.](https://kubernetes.io/docs/reference/access-authn-authz/authentication/#openid-connect-tokens)
|
||||||
|
|
||||||
|
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 96 KiB |
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 66 KiB |
Loading…
Reference in New Issue
Block a user