Skip to content

Commit

Permalink
Fix markup and alignment in User Management (SSO) and add HTTPS and T…
Browse files Browse the repository at this point in the history
…LS requirements (#3345)

* chore: Fix markup and alignment in the User Management > SSO section

* docs: Add notes that require HTTPS and TLS for SSO providers

* docs: Convert admonitions to bullets in prerequisites
  • Loading branch information
yuliiiah authored Jul 12, 2024
1 parent c84211b commit 74d442b
Show file tree
Hide file tree
Showing 6 changed files with 300 additions and 510 deletions.
212 changes: 74 additions & 138 deletions docs/docs-content/user-management/saml-sso/palette-sso-with-adfs.md

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,8 @@ Use the following steps to enable OIDC SSO in Palette with Microsoft Entra ID.

- Palette or Palette VerteX version 4.0.X or greater.

- For Microsoft Entra ID to work correctly with Palette, you must enable HTTPS and configure TLS.

- A [Microsoft Entra ID](https://entra.microsoft.com/#home) subscription. You will need an account with one of the
following roles: Global Administrator, Cloud Application Administrator, or Application Administrator. Alternatively,
you may be the owner of the service principal.
Expand Down Expand Up @@ -118,7 +120,7 @@ Use the following steps to enable OIDC SSO in Palette with Microsoft Entra ID.
| **Directory (tenant) ID** | The Directory ID is the unique identifier for your Azure AD tenant. |
| **Secret Value** | The Secret Value is the value of the client secret you created in the previous steps. |

<details>
<details>

<summary>Additional Redirect URLs</summary>

Expand All @@ -130,7 +132,7 @@ Use the following steps to enable OIDC SSO in Palette with Microsoft Entra ID.
| `http://localhost:8000` | UsUseing kubectl with the kube-login plugin from a workstation |
| `https://<fqdn_of_k8s_dashboard>/oauth/callback` | Use OIDC to authenticate and log in to the Kubernetes Dashboard |

</details>
</details>

#### Configure Microsoft Entra ID with Users and Groups

Expand Down Expand Up @@ -276,6 +278,8 @@ Use the following steps to enable OIDC in Kubernetes clusters with Microsoft Ent

- Palette or Palette VerteX version 4.0.X or greater.

- For Microsoft Entra ID to work correctly with Palette, you must enable HTTPS and configure TLS.

- OIDC configured in Palette with Microsoft Entra ID. Refer to the
[Enable OIDC SSO in Palette](#enable-oidc-sso-in-palette) section for detailed guidance on how to configure OIDC in
Palette.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,26 +21,28 @@ up Keycloak as an OIDC provider for Palette.

## Prerequisites

1. Access to Palette as a Tenant Admin.
- Access to Palette as a Tenant Admin.

2. The Keycloak service must be exposed on an external IP address, preferably with a domain name. Refer to the
[Configuring Keycloak for production](https://www.keycloak.org/server/configuration-production) guide for more
information.
- For Keycloak to work correctly with Palette, you must enable HTTPS and configure TLS.

3. Deploy a Kubernetes cluster with load balancer resources available. You will also need a set of open IP addresses for
the Keycloak service.
- The Keycloak service must be exposed on an external IP address, preferably with a domain name. Refer to the
[Configuring Keycloak for production](https://www.keycloak.org/server/configuration-production) guide for more
information.

:::tip
- Deploy a Kubernetes cluster with load balancer resources available. You will also need a set of open IP addresses for
the Keycloak service.

You can deploy a Kubernetes cluster in a public cloud with load balancer resources using Palette. You can also deploy to
an on-prem or edge environment and use the MetalLB pack to expose a load balancer service. Check out the
[Deploy a Cluster](../../clusters/public-cloud/deploy-k8s-cluster.md) guide for more information.
:::tip

:::
You can deploy a Kubernetes cluster in a public cloud with load balancer resources using Palette. You can also deploy
to an on-prem or edge environment and use the MetalLB pack to expose a load balancer service. Check out the
[Deploy a Cluster](../../clusters/public-cloud/deploy-k8s-cluster.md) guide for more information.

4. Kubectl installed and configured to access your Kubernetes cluster.
:::

## Setup
- Kubectl installed and configured to access your Kubernetes cluster.

## Enable SSO with Keycloak

1. Ensure you can access your Kubernetes cluster using the kubectl CLI. Refer to the
[Access Cluster with CLI](../../clusters/cluster-management/palette-webctl.md) for guidance on how to access your
Expand All @@ -63,38 +65,38 @@ an on-prem or edge environment and use the MetalLB pack to expose a load balance
3. The installation process takes a couple of minutes. After installation completes, use the following command to
retrieve the external IP address of the Keycloak service.

```bash
kubectl describe service keycloak | grep "LoadBalancer Ingress" | awk '{print $3}' && \
IP=$(kubectl describe service keycloak | grep "LoadBalancer Ingress" | awk '{print $3}')
```
```bash
kubectl describe service keycloak | grep "LoadBalancer Ingress" | awk '{print $3}' && \
IP=$(kubectl describe service keycloak | grep "LoadBalancer Ingress" | awk '{print $3}')
```

```shell hideClipboard
aacf4014d5cd34825803567201217410-1398304919.us-east-1.elb.amazonaws.com
```
```shell hideClipboard
aacf4014d5cd34825803567201217410-1398304919.us-east-1.elb.amazonaws.com
```

4. Next, download the Ingress YAML definition provided by Keycloak to create an Ingress resource in your cluster. The
command below also automatically replaces the `KEYCLOAK_HOST` placeholder with the external IP address of the
Keycloak service.

```bash
wget --quiet --output-document - https://raw.githubusercontent.com/keycloak/keycloak-quickstarts/latest/kubernetes/keycloak-ingress.yaml | sed "s/KEYCLOAK_HOST/$IP/" | kubectl create -f -
```
```bash
wget --quiet --output-document - https://raw.githubusercontent.com/keycloak/keycloak-quickstarts/latest/kubernetes/keycloak-ingress.yaml | sed "s/KEYCLOAK_HOST/$IP/" | kubectl create -f -
```

```shell hideClipboard
ingress.networking.k8s.io/keycloak created
```
```shell hideClipboard
ingress.networking.k8s.io/keycloak created
```

:::info
:::info

If `wget` and `sed` are not available, download the file and manually edit the file to replace `KEYCLOAK_HOST` with the
external IP address of the Keycloak service.
If `wget` and `sed` are not available, download the file and manually edit the file to replace `KEYCLOAK_HOST` with
the external IP address of the Keycloak service.

:::
:::

After the ingress resource is created, the following services will be available in your cluster. You can review the
exposed services in the cluster details page.
After the ingress resource is created, the following services will be available in your cluster. You can review the
exposed services in the cluster details page.

![View of the cluster details page](/keycloak/user-management_saml-sso_keycloak-01-keycloak-service.webp "Keycloak Service")
![View of the cluster details page](/keycloak/user-management_saml-sso_keycloak-01-keycloak-service.webp "Keycloak Service")

5. Create a DNS CNAME record for the URL exposed by load balancer. For example, the CNAME
`keycloak.dmitry.sa.spectrodemos.com` points to the following URL exposed by the load balancer
Expand All @@ -105,72 +107,72 @@ exposed services in the cluster details page.
`http://keycloak.dmitry.sa.spectrodemos.com:8080/admin`. Use the default credentials `admin:admin` to log into the
admin console.

:::warning
:::warning

We recommend that you change the default credentials after logging in to the admin console.
We recommend that you change the default credentials after logging in to the admin console.

:::
:::

![Keycloak Admin console](/keycloak//user-management_palette-rback_keycloak_login.webp)
![Keycloak Admin console](/keycloak//user-management_palette-rback_keycloak_login.webp)

7. Next, log in to [Palette](https://console.spectrocloud.com), and navigate to the left **Main Menu** and select
**Tenant Settings**. Next, select **SSO** from the **Tenant Menu** to access the SSO configuration page. Click on
the **OIDC** tab to configure OIDC for Palette. Copy the values in the **Callback URL** and **Logout URL** fields.
You will need these values to configure Keycloak.
7. Next, log in to [Palette](https://console.spectrocloud.com), and navigate to the left **Main Menu** and select
**Tenant Settings**. Next, select **SSO** from the **Tenant Menu** to access the SSO configuration page. Click on the
**OIDC** tab to configure OIDC for Palette. Copy the values in the **Callback URL** and **Logout URL** fields. You
will need these values to configure Keycloak.

![The callback URL](/keycloak/user-management_saml-sso_keycloak-02-callback-url.webp "Callback URL")
![The callback URL](/keycloak/user-management_saml-sso_keycloak-02-callback-url.webp "Callback URL")

8. Switch back to the Keycloak admin console and create a client for Palette. Navigate to the left **Main Menu** and
select **Clients**. Click on the **Create** button to create a new client.

![The Client create screen](/keycloak/user-management_saml-sso_keycloak-03-create-client.webp "Create Client")
![The Client create screen](/keycloak/user-management_saml-sso_keycloak-03-create-client.webp "Create Client")

9. Select **Client Type** value "OpenID Connect" and fill in the fields **Client ID** and **Name** with the value
`palette`. Click on **Next**.

![Fill out the user name](/keycloak/user-management_saml-sso_keycloak-04-palette-username.webp "Palette username")
![Fill out the user name](/keycloak/user-management_saml-sso_keycloak-04-palette-username.webp "Palette username")

10. Select **Client authentication** for increased security and check the **Standard Flow** box and the **Direct Access
Grants** box. Click on **Next**.

![Client Authentication creation screen number two](/keycloak/user-management_saml-sso_keycloak-05-client-authentication.webp "Client Authentication")
![Client Authentication creation screen number two](/keycloak/user-management_saml-sso_keycloak-05-client-authentication.webp "Client Authentication")

11. Fill out the following fields with the instructions provided in the table.

| **Field** | **Description** |
| ----------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **Root URL** | Your Palette URL. For Palette SaaS, this value is prefixed with your tenant name. For example, `https://docs-test.console.spectrocloud.com`. For self-hosted Palette, or VerteX, this value is the URL of your Palette deployment. |
| **Valid Redirect URIs** | The callback URL you copied from the Palette SSO configuration page. |
| **Valid post logout redirect URIs** | The logout URL you copied from the Palette SSO configuration page. |
| **Field** | **Description** |
| ----------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **Root URL** | Your Palette URL. For Palette SaaS, this value is prefixed with your tenant name. For example, `https://docs-test.console.spectrocloud.com`. For self-hosted Palette, or VerteX, this value is the URL of your Palette deployment. |
| **Valid Redirect URIs** | The callback URL you copied from the Palette SSO configuration page. |
| **Valid post logout redirect URIs** | The logout URL you copied from the Palette SSO configuration page. |

12. Click on **Save** to save the client configuration.

![alt_text](/keycloak/user-management_saml-sso_keycloak-06-keycloak-callback.webp "Keycloak callback")
![alt_text](/keycloak/user-management_saml-sso_keycloak-06-keycloak-callback.webp "Keycloak callback")

13. In the following screen, select the **Credentials** tab to retrieve client secret.

![alt_text](/keycloak/user-management_saml-sso_keycloak-07-keycloak-credentials.webp "Keycloak Credentials")
![alt_text](/keycloak/user-management_saml-sso_keycloak-07-keycloak-credentials.webp "Keycloak Credentials")

14. Switch back to Palette and paste client secret in the **Client Secret** field. Fill out the following fields with
the instructions provided in the table below.

| **Field** | **Description** |
| ----------------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
| **Issuer URL** | Your Keycloak URL with `/realms/master` appended to the end. For example, `http://keycloak.dmitry.sa.spectrodemos.com:8080/realms/master`. |
| **Client ID** | The client ID you created in the previous steps. In this guide, the name `palette` was used. |
| **Client Secret** | The client secret you retrieved in the previous step. |
| **Field** | **Description** |
| ----------------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
| **Issuer URL** | Your Keycloak URL with `/realms/master` appended to the end. For example, `http://keycloak.dmitry.sa.spectrodemos.com:8080/realms/master`. |
| **Client ID** | The client ID you created in the previous steps. In this guide, the name `palette` was used. |
| **Client Secret** | The client secret you retrieved in the previous step. |

![alt_text](/keycloak/user-management_saml-sso_keycloak-08-palette-callback.webp "Palette Callback")
![alt_text](/keycloak/user-management_saml-sso_keycloak-08-palette-callback.webp "Palette Callback")

16. Scroll down to the bottom of the page, and click on **Enable**. If all values are correct, you will receive green
15. Scroll down to the bottom of the page, and click on **Enable**. If all values are correct, you will receive green
message stating "OIDC configured successfully" at the top right corner.

![alt_text](/keycloak/user-management_saml-sso_keycloak-09-palette-oidc-enabled.webp "Palette OIDC Enabled")
![alt_text](/keycloak/user-management_saml-sso_keycloak-09-palette-oidc-enabled.webp "Palette OIDC Enabled")

17. Navigate back to the Keycloak admin console. In the left **Main Menu**, select **Users**. Fill in first name, second
16. Navigate back to the Keycloak admin console. In the left **Main Menu**, select **Users**. Fill in first name, second
name, and the email address of the admin user.

![alt_text](/keycloak/user-management_saml-sso_keycloak-10-keycloak-admin.webp "Keycloak Admin")
![alt_text](/keycloak/user-management_saml-sso_keycloak-10-keycloak-admin.webp "Keycloak Admin")

You have now configured SSO for Palette with Keycloak. You can now log in to Palette using the admin user you created in
Keycloak. Use the validation steps below to validate the SSO configuration. Check out the
Expand All @@ -185,9 +187,9 @@ Use the following steps to validate the SSO configuration.
2. Sign in to Palette using the admin user you created in Keycloak. You will be redirected to the Keycloak login page.
Enter the credentials for the admin user you created in Keycloak.

![alt_text](/keycloak/user-management_saml-sso_keycloak-11-palette-sso.webp "Palette SSO")
![alt_text](/keycloak/user-management_saml-sso_keycloak-11-palette-sso.webp "Palette SSO")

![Keycloak Admin console](/keycloak//user-management_palette-rback_keycloak_login.webp)
![Keycloak Admin console](/keycloak//user-management_palette-rback_keycloak_login.webp)

3. Upon successful authentication, you will be redirected to Palette. You will be logged in to Palette as the admin user
you created in Keycloak.
Expand All @@ -197,29 +199,29 @@ Use the following steps to validate the SSO configuration.
1. Log in to Palette as a Tenant Admin. Navigate to the left **Main Menu** and select **Users & Teams**. Click on the
**Teams** tab to access the Teams page. Click on the **Create Team** button to create a new team.

![alt_text](/keycloak/user-management_saml-sso_keycloak-14-palette-groups.webp "Palette groups")
![alt_text](/keycloak/user-management_saml-sso_keycloak-14-palette-groups.webp "Palette groups")

2. Provide a team name, such as `admins` but leave the **Members** field empty. Click on **Confirm** to create the team.

3. Next, select the **admins** row to access the team settings page. Click on **New Project Role** and add the **Project
Admin** role to the **Default** project. Click on **Confirm** to save the changes.

![alt_text](/keycloak/user-management_saml-sso_keycloak-15-palette-project.webp "Palette Project")
![alt_text](/keycloak/user-management_saml-sso_keycloak-15-palette-project.webp "Palette Project")

4. From the left **Main Menu**, select **Tenant Settings**. Next, click on **SSO** to access the SSO configuration page.
Click on the **OIDC** tab to access the OIDC configuration page. Scroll down to the **SSO Admins** section and select
the **admins** team from the **Default Team** drop-down Menu. Click on **Save**.

![alt_text](/keycloak/user-management_saml-sso_keycloak-16-palette-sso-admins.webp "Palette SSO Admins")
![alt_text](/keycloak/user-management_saml-sso_keycloak-16-palette-sso-admins.webp "Palette SSO Admins")

5. Navigate back to the Keycloak admin console. From the left **Main Menu** click on **Users**. Create a user and ensure
the field **Username**, **Email**, and **First Name** are filled out. Click on **Save** to save the user.

![alt_text](/keycloak/user-management_saml-sso_keycloak-17-keycloak-user.webp "Keycloak user")
![alt_text](/keycloak/user-management_saml-sso_keycloak-17-keycloak-user.webp "Keycloak user")

6. Next, click on the **Credentials** tab and assign the user password.

![alt_text](/keycloak/user-management_saml-sso_keycloak-18-keycloak-password.webp "Keycloak password")
![alt_text](/keycloak/user-management_saml-sso_keycloak-18-keycloak-password.webp "Keycloak password")

Repeat the steps above for all users you want to add to the **admins** team. You can now log in to Palette with the
users you created in Keycloak. The users will be assigned the **Project Admin** role for the **Default** project. Check
Expand Down
Loading

0 comments on commit 74d442b

Please sign in to comment.