This is a simple OIDC adapter acting as Relying Party in the Gematik OIDC Federation (GesundheitsID) and providing standard OIDC for clients. Clients use standard OIDC code flow and the adapter translates the request to OIDC federation. As a result, an id_token is returned with all requested scopes/claims.
If any questions arise, please don’t hesitate to contact BAYOOMED GmbH via info@bayoomed.com. As a full-service DiGA provider, we do not only provide the GesundheitsID implementation, but also ePA connections, penetration tests for your application and much more.
- Spin up the docker compose file in src directory
- Add entry to your hosts file (/etc/hosts) for rp pointing to 127.0.0.1 (needed to make the redirects work)
- Navigate to http://localhost:8088/realms/testadapter/account/#/ and click on "sign in"
- "Gesundheits-ID Custom Theme" has a fake login button enabled that will issue a (fake) id_token to keycloak
- Only Code Flow is supported
- Only confidential clients supported (if you have an app, you can use it anyway, but the client_secret wont be secure...)
- Only scope "oidc" supported for client configuration and must be present in request. The actual scope used to request tokens from federation is configurable
- Usage of PKCE/S256 is mandatory unless PKCE is configured as optional in client configuration (see AuthServerOptions.cs)
- No refresh token supported (for this usecase not needed)
- UserInfo endpoint does not return any additional data. It is implemented because some clients need it to work.
- The returned sub claim is unique for a distinct user (calculated from iss and sub of sec IdP). See "A_23035 - pseudonymes Attribut "sub""
See discovery document for more information on configuration options.
- Request X-Authorization Header value from Gematik to be able to test against Gematik sectorial IdP and add it to environment (see compose file)
- Set your private keys in configuration, deploy and register your IdP with Gematik (dont use the default keys - for obvious reasons...)
See docker compose for an example on how to add additional styles. You can also overwrite the default page by mounting a volume.
The insurance seletion can be done outside of this project (e.g. inside an app). For this you have to set the login_hint parameter in the authorization request to the vaule of the selected id retrieved from idp endpoint.
The compose file starts the following services:
- OIDC Adapter
- Keycloak (configured to use the adapter as external identity provider)
- Redis (required for environment==production)
- Services to work with OpenTelemetry Tracing, Metrics and Logging
Configuration is done using dotnet appsettings.json files. Individual configuration values can be overwritten using environment variables. See https://learn.microsoft.com/en-us/aspnet/core/fundamentals/configuration/?view=aspnetcore-8.0#naming-of-environment-variables For an explanation of configurable settings see the *Options.cs classes in the root directory.
- Requirement: A_23042 - Verifikation der Certificate Transparency für TLS Verbindungen in die VAU
- This req is not implemented in code. Instead we use a curated list of ca-certificates when building the container. This is not part of this project.
- Additional security aspects are covered by our infrstructure (using reverse proxy, TLS enforcement, WAF, etc.).
- JWT decryption using ES256 is not possible out of the box using dotnet running on linux. Therefore jose-jwt https://github.com/dvsekhvalnov/jose-jwt is used.
- OpenTelemetry instrumentation via code has been removed in favor of OTEL automatic instrumentation. See compose file and Dockerfile_OTel