From 7f2dcbabcbadcd7356c94d8f623ae0bf21e19fd4 Mon Sep 17 00:00:00 2001 From: Nicolas Liampotis <nliam@grnet.gr> Date: Mon, 26 Feb 2024 14:30:30 +0200 Subject: [PATCH 1/4] Add note about differences between devel and demo/prod --- content/en/providers/check-in/sp/_index.md | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/content/en/providers/check-in/sp/_index.md b/content/en/providers/check-in/sp/_index.md index 13355d22d3..8768853732 100644 --- a/content/en/providers/check-in/sp/_index.md +++ b/content/en/providers/check-in/sp/_index.md @@ -84,8 +84,12 @@ The integration follows a two-step process: development instance service requests can be self-reviewed without the need to wait for approval from an administrator. As with the demo instance, the development instance allows for testing authentication and authorisation - without affecting the production Check-in service. **NB: the list of - supported Identity Providers in the development instance is limited. + without affecting the production Check-in service. **NB: The development + environment is intended for testing the latest features of Check-in and + may differ from the demo and production environments in terms of stability + and functionality. + Keep in mind that the supported Identity Providers in the development + instance are limited. Therefore, we recommend using any of the social identity providers or the [EGI SSO](https://sso.egi.eu/admin/) to test the login workflow when using the development instance.** From 09eefe8b03fbab6ef8a18e8f9b70072ab17fe840 Mon Sep 17 00:00:00 2001 From: Nicolas Liampotis <nliam@grnet.gr> Date: Thu, 29 Feb 2024 17:36:56 +0200 Subject: [PATCH 2/4] Remove obsolete OIDC client migration guide --- content/en/providers/check-in/sp/_index.md | 153 ++++++--------------- 1 file changed, 41 insertions(+), 112 deletions(-) diff --git a/content/en/providers/check-in/sp/_index.md b/content/en/providers/check-in/sp/_index.md index 8768853732..b804531e88 100644 --- a/content/en/providers/check-in/sp/_index.md +++ b/content/en/providers/check-in/sp/_index.md @@ -1539,118 +1539,6 @@ $sessionName = "simple-oidc-client-php"; $sessionLifetime = 60*60; // must be equal to access token validation time in seconds ``` -### Client Migration to Keycloak - -The migration guide below applies to OIDC clients registered in the -**Development**, **Demo** and **Production** environments of Check-in. - -**Development and Demo**: Beginning June 24, 2022, clients using the legacy -Check-in OIDC endpoints will no longer be supported. - -**Production**: Beginning October 21, 2022, clients using the legacy Check-in -OIDC endpoints will no longer be supported. - -{{% alert title="Note" color="info" %}} For OpenStack Services please read the -OpenStack specific migration guide on -[Cloud Compute documentation](../../cloud-compute/openstack/aai.md#client-migration-to-keycloak). -{{% /alert %}} - -#### How to Migrate your Service to Keycloak - -All the clients that were registered in MITREid Connect have been moved to -Keycloak preserving all the options (Client ID, Client Secret, Redirect URIs -etc.), so you do not need to re-register your Service. - -##### New Endpoints - -The first thing you need to do is to update the OIDC endpoints according to the -[Endpoints](#endpoints) table. If the Application/Library supports Dynamic -Discovery, then you need to update on the `issuer`. Otherwise, you need to -update all the Endpoints separately. - -##### Size of the Tokens - -The size of the Access/Refresh Tokens that are issued by Keycloak is larger of -the respective Tokens created by MITREid Connect. For example, the size of an -Access Token is around 1400 characters, depending on the information that are -included in the payload of the JWT. So make sure that your OIDC implementation -can handle larger Tokens. - -##### Logout - -The Redirect URI query parameter in the logout request has been changed from -`redirect` to `post_logout_redirect_uri` and must be URL encoded. Also, the -value of the `post_logout_redirect_uri` must be defined in the **Valid Redirect -URIs** of the Service configuration in the EGI Federation Registry. - -##### Token Introspection - -The Token Introspection is available to all the clients that are using any -authentication method (`client_secret_basic`, `client_secret_post`, -`client_secret_jwt` or `private_key_jwt`) (Confidential Clients) to the Token -Endpoint. Public Clients (clients that do not use any authentication method) -will not be able to get a successful response from the Introspection Endpoint. -Saying that, the "Introspection" option in the EGI Federation Registry will be -removed. - -##### PKCE - -If you are **not** using PKCE (Proof Key for Code Exchange), please make sure to -**disable** the "PKCE Code Challenge Method" in the Service configuration in -[EGI Federation Registry](https://aai.egi.eu/federation), otherwise you will get -the following HTTP response during the authentication flow: - -```http -error=invalid_request&error_description=Missing parameter: code_challenge_method -``` - -##### Device Code Grant - -If you are using a confidential client with the Device Code grant, please make -sure that the `client_secret` is present in the request to the Device Code -Endpoint either as HTTP Basic or HTTP POST parameter (see -[Device Authorization Request](#1-device-authorization-request)). - -##### Token Exchange Grant - -If you are using the Token Exchange grant, please make sure that the `audience` -(Optional) defines the logical name of the service that the token will be used -for; when specified, it must match the client ID of a client registered in -Check-in otherwise an `invalid_client` error is returned -(`"description": "audience not found"`) - -##### Client Credentials Grant - -If you are using the Client Credentials grant, there is a minor change in the -responses from UserInfo and Introspection Endpoints. The **Client ID** of the -client is **not** released as the `sub` claim any more and has replaced with by -the `client_id` claim. The `sub` contains the identifier of the client which is -unique, non-reassignable and scoped `@egi.eu`. - -##### Obtain Refresh Tokens - -If you have obtained an Refresh Token from EGI Check-in Token Portal or -oidc-agent issued by the MITREid Connect instance, you will need to replace them -by creating new Refresh Tokens issued by Keycloak. - -- If you have obtained Refresh Tokens using the EGI Check-in Token Portal, - please check the following table: - - | Environment | URL | - | ----------- | ------------------------------- | - | Production | <https://aai.egi.eu/token> | - | Demo | <https://aai-demo.egi.eu/token> | - | Development | <https://aai-dev.egi.eu/token> | - -- If you have obtained Refresh Tokens using the oidc-agent, please use the - following command: - - ```shell - $ oidc-gen --pub --issuer <ISSUER> --scope ... - ``` - - {{% alert title="Note" color="info" %}} You can find the `ISSUER` in the - [Endpoints](#endpoints) table.{{% /alert %}} #### Common issues @@ -1723,6 +1611,47 @@ proxy_buffer_size 128k; proxy_busy_buffers_size 256k; ``` +##### Size of the Tokens + +The size of an Access Token is around 1400 characters, depending on the +information (claims) included in the payload of the JWT. So make sure that +your OIDC implementation can handle large Tokens. + +##### Token Introspection errors + +The Token Introspection is available to all the clients that are using any +authentication method (`client_secret_basic`, `client_secret_post`, +`client_secret_jwt` or `private_key_jwt`) (Confidential Clients) to the Token +Endpoint. Public Clients (clients that do not use any authentication method) +will not be able to get a successful response from the Introspection Endpoint. + +##### PKCE errors + +If you are **not** using PKCE (Proof Key for Code Exchange), please make sure to +**disable** the "PKCE Code Challenge Method" in the Service configuration in +[EGI Federation Registry](https://aai.egi.eu/federation), otherwise you will get +the following HTTP response during the authentication flow: + +```http +error=invalid_request&error_description=Missing parameter: code_challenge_method +``` + +##### Device Code Grant + +If you are using a confidential client with the Device Code grant, please make +sure that the `client_secret` is present in the request to the Device Code +Endpoint either as HTTP Basic or HTTP POST parameter (see +[Device Authorization Request](#1-device-authorization-request)). + +##### Token Exchange Grant + +If you are using the Token Exchange grant, please make sure that the `audience` +(Optional) defines the logical name of the service that the token will be used +for; when specified, it must match the client ID of a client registered in +Check-in otherwise an `invalid_client` error is returned +(`"description": "audience not found"`) + + ## Integrating Science Gateways with RCauth for obtaining (proxy) certificates In order for Science Gateways (VO portals) to obtain RFC proxy certificates From 3b7be8babc048385963fa4e2143b911295f5d7b4 Mon Sep 17 00:00:00 2001 From: Nicolas Liampotis <nliam@grnet.gr> Date: Thu, 29 Feb 2024 17:41:31 +0200 Subject: [PATCH 3/4] Remove redundant empty line --- content/en/providers/check-in/sp/_index.md | 1 - 1 file changed, 1 deletion(-) diff --git a/content/en/providers/check-in/sp/_index.md b/content/en/providers/check-in/sp/_index.md index b804531e88..3f794015d8 100644 --- a/content/en/providers/check-in/sp/_index.md +++ b/content/en/providers/check-in/sp/_index.md @@ -1651,7 +1651,6 @@ for; when specified, it must match the client ID of a client registered in Check-in otherwise an `invalid_client` error is returned (`"description": "audience not found"`) - ## Integrating Science Gateways with RCauth for obtaining (proxy) certificates In order for Science Gateways (VO portals) to obtain RFC proxy certificates From fb56e4da00fe46f74d3363d6d129cbe0575c3be7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Enol=20Fern=C3=A1ndez?= <enol.fernandez@egi.eu> Date: Sun, 3 Mar 2024 10:59:57 +0000 Subject: [PATCH 4/4] Update content/en/providers/check-in/sp/_index.md --- content/en/providers/check-in/sp/_index.md | 1 - 1 file changed, 1 deletion(-) diff --git a/content/en/providers/check-in/sp/_index.md b/content/en/providers/check-in/sp/_index.md index 3f794015d8..99dbe4acff 100644 --- a/content/en/providers/check-in/sp/_index.md +++ b/content/en/providers/check-in/sp/_index.md @@ -1539,7 +1539,6 @@ $sessionName = "simple-oidc-client-php"; $sessionLifetime = 60*60; // must be equal to access token validation time in seconds ``` - #### Common issues ##### Error messages referring to missing `code_challenge`, `code_challenge_method` or `code_verifier` HTTP parameter