PH4H-app-backend/docs/keycloak-setup.md
2025-09-16 08:00:11 +10:00

3.9 KiB
Raw Blame History

Keycloak Setup

This guide explains how to configure the backend service to work with Keycloak. Throughout these instructions, we assume you are already logged in with the admin account.

Activate Authentication

Before using the API service, you must enable authentication and set the client ID so the backend can perform operations on Keycloak, such as registering users.

  1. Open the Keycloak service at http://localhost:9083/.

  2. Once the page loads, ensure you are in the correct realm. The realm name is specified in the .env file:

    Change Realm

  3. To enable authentication:

    • Go to the admin-cli configuration:

      Admin CLI Access

    • Scroll down to the Capability Config section and enable the two switches as shown below:

      Set Authentication

    • Click Save to apply the changes.

  4. To retrieve the client credentials:

    • Navigate to the Credentials tab.

    • Copy the client secret value (it may be hidden by default).

      Get Client Secret

This client secret is required in the Docker Compose file to configure the backend service. Add it to the appropriate section:

Client ID in Docker Compose

Set Roles for Backend Interaction

To allow the backend service to perform all necessary operations, the admin role must have all service account roles assigned.

  1. Go to the Service Account Roles tab.

  2. Click Apply Roles to assign roles.

    Service Account Roles

  3. To simplify selection:

    • Change the page size to show 100 roles per page:

      Show 100 Roles

    • Select all roles by clicking the checkbox in the table header:

      Select All Roles

  4. After selecting all roles, click Assign. You should now see all roles listed as assigned:

    Role Account List

Set Custom Redirect URI (Optional)

If you are not using the provided P4H4 application and plan to integrate with the Keycloak service directly, you must configure your own redirect URIs.

To do this:

  1. Navigate to the Clients tab in Keycloak.
  2. Select the app client ID.

Navigate to app client ID

  1. Go to the Access Settings section.
  2. Under Valid Redirect URIs, add your desired redirect URI.

Add redirect URI

  1. Click Save to apply your changes.

This ensures your application can successfully handle authentication responses from Keycloak.

Set Frontend URL (for local development)

To test all Keycloak features in your local environment or when using IP addresses as domains, you need to configure the Frontend URL in your realm settings. You can do this by going to Realm Settings → General, as shown in the image below:

Add redirect URI

When working locally, do not use localhost. Instead, use 10.0.2.2.
This should point to the URL where Keycloak is running, so dont forget to include the port.

Set Authenticationl email

For recover password and similar services, a SMTP email account must be set to send emails to users. To do this:

  1. Ensure you are in lacpass realm.
  2. Go to Realm settings tab on the botton left.
  3. Go to Email tab.

Go to mail tab

  1. On the bottom set your STMP credentials in the Connection & Authentication section and save.

Configure your SMTP