This example shows how a mobile application will use Airlock IAM as an OAuth 2.0 client for a remote authorization server to authenticate a user. The mobile application will obtain a bearer token and use it to access a protected resource.
- The mobile app tries to access the protected resource.
- The access fails since the mobile app is not authorized.
- The mobile app starts an authentication flow with Airlock IAM.
- The flow is configured with an SSO (single sign-on) step and therefore requests an authorization request from the OAuth 2.0 client.
- The authorization request is delivered to the SSO step.
- The SSO step sends a response to the mobile app with the nextStep set to
OAUTH2_CLIENT_AUTHORIZATION_REQUIRED
. This response includes the authorization request and URL of the remote authorization server. - The mobile app opens a system browser with the URL of the remote authorization server and the authorization request.
- The system browser connects to the remote authorization server and the user is authenticated.
In this step, the remote authorization server will also obtain the consent of the user for the requested scopes. - The authorization server provides the system browser with the authorization response. This response contains the authorization code.
- The system browser forwards the authorization response to the mobile client.
- The mobile client forwards the authorization response to the SSO step.
- The SSO step forwards the authorization response to the OAuth 2.0 client.
- The OAuth 2.0 client connects to the remote authorization server to trade the authorization code for the tokens.
- The remote authorization server returns access, refresh, and optionally ID token to the OAuth 2.0 client.
- The OAuth 2.0 client reports success to the SSO step.
- The SSO step completes the authentication flow and triggers identity propagation for the target application.
- The mobile application receives the propagated identity and accesses the protected business service.