IAM Service¶
All operations within the ICOS Continuum require authentication and proper authorization before execution. These functionalities are provided by the Identity and Access Management (IAM) component, which is invoked in nearly all interactions between components and is integral to the realization of all functionalities.
Three scenarios are analyzed to demonstrate how:
- Users' authentication and authorization are achieved.
- Service-to-Service authentication and authorization is achieved.
- Cross-Controller identities and authorization are achieved.
The IAM component manages users who are Application Integrators interacting with ICOS for deploying and managing their applications. This does not include end users of the applications or devices within the Cloud Continuum.
All workflows rely on the OAuth2.0 protocol for communication between components, ensuring state-of-the-art security, trust, and an easy integration with both existing and new components.
Access the Keycloak Administration Console¶
Keycloak comes with a web-based administration console that can be used to administer the users and services. The exact endpoint depends on the exposure configuration of the ICOS Core deployment (see Service Exposure section).
To access the console:
- open the URL (e.g.
https://iam.core.my-continuum.com/
) in the browser. - the user is
icos-admin
- the password can be retrieved directly from the Kubernetes cluster where the ICOS Core is running:
A more detailed usage guide can be found in the Keycloak Administration Guide.
Retrieve the IAM Public Key¶
The Keycloak Server Public Key is the key used to verify the tokens issued by the server. It is required as configuration parameter of the ICOS Controller and ICOS Agent Suites.
To retrieve the public key, first log-in to the Keycloak Administration Console (see here). Then:
- Select the realm
- Click on Realm Settings
- Click on the Keys tab
- Locate the
RSA256 - RSA
key - Click on the Public Key button and copy the key shown
data:image/s3,"s3://crabby-images/95d89/95d890b9588f9df6450992d1ca0dc970178942c9" alt="Public Key"
Create a user¶
To create a new user, first log-in to the Keycloak Administration Console (see here). Then:
- Select the realm
- Click on Users
- Click on Add User
data:image/s3,"s3://crabby-images/36c36/36c36cb16e34c1ae617f7ee03f62357d8985b0f9" alt="Create a user - Step 1"
In the wizard, fill-in the user details and click on Save
Warning
Make sure also email
, First name
and Last name
fields are filled. They are required to have a valid user
data:image/s3,"s3://crabby-images/20a64/20a641d5d1c37e36e864205cfa7471c989a43a36" alt="Create a user - Step 2"
Finally, set a password for the new user:
- Click on the Credentials tab
- Click on Set Password
- Specify the new password. Make sure to un-check the Temporary option
- Click on Save
data:image/s3,"s3://crabby-images/9b478/9b47867c47d790db04a10bc47144d0345ad2ffc0" alt="Create a user - Step 2"
Create an OpenId Connect client¶
To be completed. For the moment, please refer to the official Keycloak documentation here.