This getting started guide discusses all concepts required to use the SRG Identity library.
At its core, the SRG Identity library reduces to a single identity service class, SRGIdentityService
, which you instantiate for a given identity provider URL and an identity website where the user can login, for example:
SRGIdentityService *identityService = [[SRGIdentityService alloc] initWithWebserviceURL:webserviceURL websiteURL:websiteURL];
Both the webservice URLs and website URL must provide services expected by the library to work (convention over configuration).
You can have several identity services in an application, though most applications should require only one. To make it easier to access the main identity service of an application, the SRGIdentityService
class provides a class property to set and retrieve it as shared instance:
SRGIdentityService.currentIdentityService = [[SRGIdentityService alloc] initWithWebserviceURL:webserviceURL websiteURL:websiteURL];
For simplicity this getting started guide assumes that a shared service has been set. If you cannot use the shared instance, store the services you instantiated somewhere and provide access to them in some way.
Your application must declare at least one custom URL scheme, which is then used by the framework to transfer control back from the web browser when needed (e.g. after logging in or logging out):
- If your application already defines a custom scheme for some purpose, no additional work is required. SRG Identity will use the same scheme to transfer back control to your application and respond properly.
- If your application has no custom schemes, you need to add one to your application
Info.plist
so that SRG Identity can use it to transfer control back to your application.
No additional work is required for URL handling. SRG Identity namely takes care of injecting the required logic to your application delegate (iOS 12) or scene delegate (iOS 13 and above).
To allow for a user to login, call the -loginWithEmailAddress:
instance method:
[SRGIdentityService.currentIdentityService loginWithEmailAddress:nil];
- On iOS this presents a browser, in which the user can supply their credentials or open an account.
- On tvOS a dedicated in-app view is presented, with which users can only log in (a message invites them to open an account on a computer or mobile device).
- You can customize the logo displayed on this view by adding an
identity_service_logo
image file to your project (with recommended size of 150x150 px). - To allow credentials autofill from a companion device, enable web credentials sharing by adding the associated domains entitlement to your application and the associated domain file on your website.
- You can customize the logo displayed on this view by adding an
A user remains logged in until they log out.
On iOS login occurs within a simple Safari in-app browser by default. You might prefer using an authentication session, which lets user credentials be shared between your app and Safari, providing automatic login for apps associated with the same identity provider. Before the user can enter their credentials, a system alert will be displayed to inform them about credential sharing.
To enable this feature use the corresponding login method when creating the service:
SRGIdentityService.currentIdentityService = [[SRGIdentityService alloc] initWithWebserviceURL:webserviceURL websiteURL:websiteURL loginMethod:SRGIdentityLoginMethodAuthenticationSession];
Once a user has successfully logged in a corresponding session token is available in the keychain. Use the SRGIdentityService.currentIdentityService.sessionToken
property when you need to retrieve it.
When a user is logged in its account information can be displayed and edited within your application through a dedicated web page. To display this page, call -showAccountView
:
[SRGIdentityService.currentIdentityService showAccountView];
tvOS users must currently manage their account from a computer or mobile device.
To logout the current user, simply call -logout
;
[SRGIdentityService.currentIdentityService logout];
SRG Identity only takes care of authenticating a user. Once a token has been retrieved your application is namely responsible for calling other webservices on behalf of this user. Usually this is achieved by providing the session token in webservice requests, but how this is actually made depending on the service.
Server-side, third-party services themselves are integrated with the identity provider server to support authenticated requests. Since your application merely connects to third-party services to perform its work, it might receive an unauthorization error from them at some point. As third-party services are not identity providers, though, your application should not rely on such errors to force a user to logout or to clear local data. The third-party service might be wrong.
Instead, if you receive an unauthorization error from a third-party service, call -reportUnauthorization
on the identity service from which the token was used. This forces a check with the identity provider to verify whether the user is truly unauthorized or not:
- If still authorized, nothing happens beside an account update.
- If confirmed to be unauthorized, the user is automatically logged out. In such cases, the
SRGIdentityServiceUserDidLogoutNotification
notification is sent withSRGIdentityServiceUnauthorizedKey
set to@YES
in itsuserInfo
dictionary. You can for example use this information to display a corresponding information message to the user.