Skip to content

Commit

Permalink
Improve Check-in service integration guide (#638)
Browse files Browse the repository at this point in the history
This pull request aims to improve the integration documentation for EGI
Check-in. The changes include providing additional clarity regarding the
purpose and differences of the development environment compared to the
demo and production environments.

# Summary

A note has been added to highlight that the development environment is
intended for testing the latest features and may differ from demo/prod
in terms of stability and functionality. These changes aim to improve
the understanding of the integration process and help users make
informed decisions about the integration environment when testing their
Service Providers.

---------

Co-authored-by: Enol Fernández <[email protected]>
  • Loading branch information
NicolasLiampotis and enolfc authored Mar 3, 2024
1 parent 2867095 commit 856e744
Showing 1 changed file with 46 additions and 115 deletions.
161 changes: 46 additions & 115 deletions content/en/providers/check-in/sp/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -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.**
Expand Down Expand Up @@ -1535,119 +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

##### Error messages referring to missing `code_challenge`, `code_challenge_method` or `code_verifier` HTTP parameter
Expand Down Expand Up @@ -1719,6 +1610,46 @@ 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

Check failure on line 1616 in content/en/providers/check-in/sp/_index.md

View workflow job for this annotation

GitHub Actions / Check Spelling

`JWT` is not a recognized word. (unrecognized-spelling)
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
Expand Down

1 comment on commit 856e744

@github-actions
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@check-spelling-bot Report

🔴 Please review

See the 📜action log or 📝 job summary for details.

Unrecognized words (13)
checkin
CUID
deregistration
edu
img
JWK
jwt
OID
rsa
saml
sid
uid
vhost
To accept these unrecognized words as correct, you could run the following commands

... in a clone of the [email protected]:EGI-Federation/documentation.git repository
on the main branch (ℹ️ how do I use this?):

curl -s -S -L 'https://raw.githubusercontent.com/check-spelling/check-spelling/main/apply.pl' |
perl - 'https://github.com/EGI-Federation/documentation/actions/runs/8129699632/attempts/1'
Available 📚 dictionaries could cover words (expected and unrecognized) not in the 📘 dictionary

This includes both expected items (11) from .github/actions/spelling/expect.txt and unrecognized words (13)

Dictionary Entries Covers Uniquely
cspell:php/dict/php.txt 1689 4 2
cspell:npm/dict/npm.txt 302 3 1
cspell:node/dict/node.txt 891 3
cspell:k8s/dict/k8s.txt 153 2
cspell:aws/aws.txt 218 1 1

Consider adding them (in .github/workflows/spelling.yml) for uses: check-spelling/check-spelling@main in its with:

      with:
        extra_dictionaries:
          cspell:php/dict/php.txt
          cspell:npm/dict/npm.txt
          cspell:node/dict/node.txt
          cspell:k8s/dict/k8s.txt
          cspell:aws/aws.txt

To stop checking additional dictionaries, add (in .github/workflows/spelling.yml) for uses: check-spelling/check-spelling@main in its with:

check_extra_dictionaries: ''

Please sign in to comment.