This code has been written for the purpose of creating examples for the use of HelseID. We have tried to emulate real-life scenarios of authentication flows. If you find that any part of the code is illegible or hard to understand, we appreciate your feedback. Any input or advice that leads to improve the example code will be received with gratitude!
HelseID is a national authentication service for the healthcare sector in Norway. These code samples are targeted at technical personnel such as application architects and developers.
If you experience trouble while checking out this repository because of long paths, update your git config by running:
git config --global core.longpaths true
As HelseID is based on the OAuth 2.0 framework, both the code and the usage scenarios are strongly connected to this authorization protocol. If you have not had any previous experience with this framework, we strongly advise you to check out online resources on this topic. Good starting points can be found at OAuth 2.0 Simplified.
The examples connect to the HelseID test environment. For each example, there exists a corresponding client in HelseID. The sample code will be able to use 1) a client ID in connection with 2) a self-issued client assertion signed with a JWK-encoded private key in order to authenticate against HelseID.
For all samples that requires user authentication you can use our "TestIDP" which provides a way to simulate user login without the need for actual test users.
Please be advised that the sample code does not in any way represent working code for a production environment. In particular, special care MUST be taken in order to secure the private keys that the code uses to authenticate against HelseID.
These samples use either machine-to-machine or user logon authentication methods.
The code can be found in the SampleAPI
folder.
Most of the HelseID samples demonstrate how a client can access an API. Therefore, a sample API has been created such that other HelseID samples can access it. The API requires authentication before the client is granted access. The API should be run locally before trying to connect through another HelseID sample.
See SampleApi/README.md for more information.
The code can be found in the SpringSecurity
folder.
Most of the HelseID samples demonstrate how a client can access an API. Therefore, a sample API has been created such that other HelseID samples can access it. The API requires authentication before the client is granted access. The API should be run locally before trying to connect through another HelseID sample.
This version of the API is set up with the use of Spring Security for authorization. The code is also set up to use Nimbus OAuth SDK for the usage of DPoP.
HelseID supports the use of several grants, that is, the resource owner's (user or enterprise) authorization used by the client to obtain an access token. Code samples are provided for different scenarios, and each will use at least one grant type. The following grants are provided:
All these samples are configured to request a DPoP (Demonstrating Proof-of-Possession)-bound token.
The code can be found in the ClientCredentials
folder.
This sample use the Client Credentials Grant in order to request an access token from HelseID. Its intended usage is when you need to connect to an API resource without logging on a user.
This sample also contains a method for adding an underenhet (child organization) to the call to HelseID, as well as a method for accessing the client info endpoint for debug purposes.
When using this sample, you will also need to start the sample API.
See ClientCredentials/README.md for more information.
The code can be found in the SampleApi
folder.
This sample uses the Authorization Code Grant with the OpenID connect identity layer on top of OAuth 2.0 to demonstrate how a user can authenticated through HelseID.
You can use this sample for user login only, or, if you want to access an API, you will also need to start the sample API.
This sample also exhibits the use of the Refresh Token Grant.
See APIAccess/README.md for more information.
The code can be found in the SampleApiForTokenExchange
folder.
This sample uses the Token Exchange Grant. It sets up a simple demonstration of token exchange, using a sample API that uses HelseID to exchange an access token for another. This exchanged access token is then used with another API.
If you wish to use this sample, you will need to start both
- The API access sample in "token exchange mode"; see ApiAccess/README.md for details, and
- The sample API
See SampleApiForTokenExchange/README.md for more information.
For use in "native clients", i.e. applications that does not run in a web client, we have created a set of simple examples for the use of a system browser for login against HelseID. These examples can be found in the NativeClients
folder.
The sample demonstrates a simple user login. See NativeClients/SimpleNativeClientWithDPoP/README.md for more information.
The sample demonstrates how resource indicators are used to download multiple access tokens without performing multiple calls to the authorization endpoint. Each access token can then be used to call a specified API. See NativeClients/SimpleResourceIndicatorsDemo/README.md for more information.
The sample demonstrates how to use request objects for client authentication against HelseID. See NativeClients/SimpleRequestObjectsDemo.
We've created a set of samples for more advanced cases.
Running samples for Persontjenesten API clients that exchange valid tokens with HelseID.
Implementations:
We have included some tools to enable a smoother developing experience
A command line program to generate a key pair as a JSON Web Key (JWK). The sample creates two files where the first file contains the whole key pair (including the private key), while the second file only contains the public key. See HelseId.RsaJwk/README.md for a more detailed explanation.
An excellent introductory guide to OAuth 2 can be found here
You can find the OAuth 2 specs here: https://oauth.net/specs/
You can find the OpenID Connect specs here: https://openid.net/developers/specs/
More info can be found at https://nhn.no/helseid/ (in Norwegian) and https://dokumentasjon.helseid.no/.