Keycloak integration

SAYMON provides the possibility of its users to authorize via Keycloak server.

Server setup

In order to set up the interaction between the SAYMON server and the external Keycloak server, it is necessary to obtain at least one of the parameters:

  • Realm Certificate, which is used by the Keycloak to sign the user tokens;

  • Backend-client configuration file.

Setting up the client and obtaining parameters are implemented in the Keycloak Administration Console.

Realm Certificate

In order to obtain the Realm Certificate, it is necessary to:

  1. Select the required realm from the list (SAYMON here):
    image

  2. In the Realm Settings section on the Tokens tab find the token signature algorithm (RS256 here):

    image

  3. On the Keys tab find the certificate for the algorithm:

    image

  4. The image button in the corresponding line shows the certificate:

    image

    It is recommended to save the data to the keycloak_realm_certificate file.

Backend-client

Clients are connection parameters to the Keycloak server for external applications which authorize users.

The main feature of the Backend-client is its own authentication: this client gets confidential access with the secret key.

In order to set up the Backend-client, it is necessary to:

  1. Select the required realm from the list (SAYMON here):

    image

  2. Click the image button in the Clients section:

    image

  3. Enter the Backend-client’s name into the Client ID field:

    image

    and click the image button.

  4. Set the Client authentication slider to the On position:

    image

    and click the image button.

  5. Select Download adapter config in the Action menu:

    image

  6. Click the image button to obtain the Backend-client configuration file in the JSON format:

    image

SAYMON Server configuring

In order to interact with the Keycloak server, on the SAYMON server it is necessary to:

  1. Add the Keycloak section to the server configuration file /etc/saymon/saymon-server.conf:

    "keycloak": {
      "realm_certificate": "<data from the keycloak_realm_certificate>",
     "realm_certificate_file": "/etc/saymon/keycloak_realm_certificate",
        "config_file": "/etc/saymon/keycloak_backend.json"
    }

    where

    • realm_certificate is the data from the Keycloak Realm Certificate;

    • realm_certificate_file is the path to the file with the Keycloak Realm Certificate;

    • config_file is the path to the configuration file, generated by the Keycloak server for the Backend-client.

      The parameters are listed in descending order of priority when specified simultaneously. It is sufficient to specify one of the parameters in order to work with Keycloak.
  2. Restart the saymon-server service:

    $sudo service saymon-server restart

Web interface setup

In order to get the possibility to authorize users via Keycloak in the SAYMON web interface, it is necessary to obtain the Frontend-client configuration file.

Setting up the client and obtaining the configuration file are implemented in the Keycloak Administration Console.

Frontend-client

The main feature of the Frontend-client is the absence of its own authentication: this client gets public access.

In order to set up the Frontend-client, it is necessary to:

  1. Select the required realm from the list (SAYMON here):

    image

  2. Click the image button in the Clients section:

    image

  3. Enter the Frontend-client’s name into the Client ID field:

    image

    and click the image button.

  4. Set the Client authentication slider to the Off position:

    image

    and click the image button.

  5. On the Settings tab in the Access settings section specify the correct URI addresses, from which access to the Keycloak server will be implemented and to which users will be redirected after successful authentication and exit:

    image

    and click the image button.

  6. Select Download adapter config in the Action menu:

    image

  7. Click the image button to obtain the Frontend-client configuration file in the JSON format:

    image

SAYMON web interface configuring

In order to activate the authorization via Keycloak in the system web interface, it is necessary to:

  1. Add the Authentication section to the SAYMON client configuration file /etc/saymon/saymon-client.yaml:

    authentication:
      availableMethods:
        - "native"
        - "keycloak"
      methodByDefault: "keycloak"
        services:
          keycloak:
            configUri: keycloak_frontend.json

    where

    • availableMethods is the list of available authentication methods for users;

    • methodByDefault is the authentication method offered to the user when displaying of the authentication form;

    • configUri is the configuration file generated by the Keycloak server for the Frontend-client.

      The Frontend-client configuration file must be placed to the /etc/saymon folder.
  2. Reload the SAYMON page in the web browser.