(Legacy) iOS/tvOS SDK Cookbook iostvos-sdk-cookbook
Introduction intro
This document describes the entitlement workflows that a Programmer鈥檚 upper-level application can implement through the APIs exposed by the iOS/tvOS AccessEnabler library.
The 51黑料不打烊 Pass Authentication entitlement solution for iOS/tvOS is ultimately divided into two domains:
-
The UI domain - this is the upper-level application layer which implements the UI and uses the services provided by the AccessEnabler library to provide access to restricted content.
-
The AccessEnabler domain - this is where the entitlement workflows are implemented in the form of:
- Network calls made to 51黑料不打烊鈥檚 backend servers
- Business-logic rules related to the authentication and authorization workflows
- Management of various resources and processing of workflow state (such as the token cache)
The goal of the AccessEnabler domain is to hide all the complexities of the entitlement workflows, and provide to the upper-layer application (through the AccessEnabler library) a set of simple entitlement primitives with which you implement the entitlement workflows:
- Set the requestor identity
- Check and get authentication against a particular identity provider
- Check and get authorization for a particular resource
- Logout
- Apple SSO flows by proxing the Apple VSA framework
The AccessEnabler鈥檚 network activity takes place in its own thread, so the UI thread is never blocked. As a result, the two-way communication channel between the two application domains must follow a fully asynchronous pattern:
- The UI application layer sends messages to the AccessEnabler domain via the API calls exposed by the AccessEnabler library.
- The AccessEnabler responds to the UI layer through the callback methods included in the AccessEnabler protocol which the UI layer registers with the AccessEnabler library.
Configuring the Experience Cloud ID Service (Visitor ID) visitorIDSetup
Configuring the Experience Cloud ID value is important from the Analytics point of view. Once a visitorID
value is set, the SDK sends this information along with every netwrok call and the 51黑料不打烊 Pass Authentication server collects this information. You can correlate the analytics from 51黑料不打烊 Pass Authentication service with any other anayltics reports that you may have from other applications or websites. Information on how to setup visitorID can be found here.
Entitlement Flows entitlement
A. Prerequisites
B. Startup Flow
C. Authentication Flow withouth Apple SSO
D. Authentication Flow with Apple SSO on iOS
E. Authentication Flow with Apple SSO on tvOS
F. Authorization Flow
G. View Media Flow
H. Logout Flow without Apple SSO
I. Logout Flow with Apple SSO
A. Prerequisites prereqs
-
Create your callback functions:
-
setRequestorComplete()
-
Triggered by setRequestor(), returns success or failure.
-
Success indicates you can proceed with entitlement calls.
-
- Triggered by
getAuthentication()
only if the user has not selected a provider (MVPD) and is not yet authenticated. - The
mvpds
parameter is an array of providers available to the user.
- Triggered by
-
setAuthenticationStatus(status, errorcode)
- Triggered by
checkAuthentication()
every time. - Triggered by
getAuthentication()
only if the user is already authenticated and has selected a provider. - Status returned is success or failure, the errorcode describes the type of the failure.
- Triggered by
-
- Triggered by
getAuthentication()
after the user selects an MVPD. Theurl
parameter provides the location of the MVPD鈥檚 login page.
- Triggered by
-
sendTrackingData(event, data)
- Triggered by
checkAuthentication()
,getAuthentication()
,checkAuthorization()
,getAuthorization()
,setSelectedProvider()
. - The
event
parameter indicates which entitlement event occurred; thedata
parameter is a list of values relating to the event.
- Triggered by
-
setToken(token, resource)
- Triggered by checkAuthorization() and getAuthorization() after a successful authorization to view a resource.
- The
token
parameter is the short-lived media token; theresource
parameter is the content that the user is authorized to view.
-
tokenRequestFailed(resource, code, description)
- Triggered by checkAuthorization() and getAuthorization() after an unsuccessful authorization.
- The
resource
parameter is the content that the user was attempting to view; thecode
parameter is the error code indicating what type of failure occurred; thedescription
parameter describes the error associated with the error code.
-
selectedProvider(mvpd)
- Triggered by
getSelectedProvider()
. - The
mvpd
parameter provides information about the provider selected by the user.
- Triggered by
-
setMetadataStatus(metadata, key, arguments)
- Triggered by
getMetadata().
- The
metadata
parameter provides the specific data you requested; thekey
parameter is the key used in the getMetadata() request; and thearguments
parameter is the same dictionary that was passed to getMetadata().
- Triggered by
-
preauthorizedResources(authorizedResources)
-
Triggered by
checkPreauthorizedResources()
. -
The
authorizedResources
parameter presents the resources that the user
is authorized to view.
-
-
presentTvProviderDialog(viewController)
- Triggered by getAuthentication() when the current requestor supports at least on MVPD that has SSO support.
- The viewController parameter is the Apple SSO Dialog and needs to be presented on the main view controller.
-
dismissTvProviderDialog(viewController)
- Triggered by a user action (by selecting 鈥淐ancel鈥 or 鈥淥ther TV Providers鈥 from the Apple SSO Dialog).
- The viewController parameter is the Apple SSO Dialog and needs to be dismissed from the main view controller.
-
B. Startup Flow startup_flow
-
Start the upper-level application.
-
Initiate 51黑料不打烊 Pass Authentication
a. Call
init
to create a single instance of the 51黑料不打烊 Pass Authentication AccessEnabler.- Dependency: 51黑料不打烊 Pass Authentication Native iOS/tvOS Library (AccessEnabler)
b. Call
setRequestor()
to establish the identity of the Programmer; pass in the Programmer鈥檚requestorID
and(optionally) an array of 51黑料不打烊 Pass Authentication endpoints. For tvOS you will also need to provide the public key and the secret. See Clientless documentation for details.-
Dependency: Valid 51黑料不打烊 Pass Authentication RequestorID (Work with your 51黑料不打烊 Pass Authentication Account
Manager to arrange this). -
Triggers:
setRequestorComplete() callback.
note note NOTE No entitlement requests can be completed until the requestor identity is fully established. This effectively means that while setRequestor()
is still running, all subsequent entitlement requests. For example,checkAuthentication()
are blocked.You have two implementation options: Once the requestor identification information is sent to the backend server, the UI application layer may choose one of the two following approaches:
-
Wait for the triggering of the
setRequestorComplete()
callback (part of the AccessEnabler delegate). This option provides the most certainty thatsetRequestor()
completed, so it is recommended for most implementations. -
Continue without waiting for the triggering of the
setRequestorComplete()
callback, and start issuing entitlement requests. These calls (checkAuthentication, checkAuthorization, getAuthentication, getAuthorization, checkPreauthorizedResource, getMetadata, logout) are queued by the AccessEnabler library, which will make the actual network calls after thesetRequestor()
. This option can occasionally be disrupted if, for example, the network connection is unstable.
-
Call
checkAuthentication()
to check for an existing authentication without initiating the full Authentication flow. If this call succeeds, you can proceed directly to the Authorization flow. If not, proceed to the Authentication flow.-
Dependency: A successful call to setRequestor() (this dependency applies to all subsequent calls as well).
-
Triggers: setAuthenticationStatus() callback.
-
C. Authentication Flow without Apple SSO authn_flow_wo_applesso
-
Call
getAuthentication()
to initiate the authentication flow, or to get confirmation that the user is already
authenticated.Triggers:
-
The setAuthenticationStatus() callback, if the user is already authenticated. In this case, proceed directly to the Authorization Flow.
-
The displayProviderDialog() callback, if the user is not yet authenticated.
-
-
Present the user with the list of providers sent to
displayProviderDialog()
. -
After the user selects a provider, obtain the URL of the user鈥檚 MVPD from the
navigateToUrl:
ornavigateToUrl:useSVC:
callback and open aUIWebView/WKWebView
orSFSafariViewController
controller and direct that controller to the URL. -
Through the
UIWebView/WKWebView
orSFSafariViewController
instantiated in the previous step, the user lands on the MVPD鈥檚 login page and inputs login credentials. Several redirect operations take place within the controller.
null
as a parameter. This allows the AccessEnabler to clean up it鈥檚 internal state and reset the Authentication Flow.-
Upon a successful login by the user, your application layer detects the loading of a specific custom URL. Note that this specific custom URL is actually invalid, and it is not intended for the controller to actually load it. It must be only interpreted by your application as a signal that the authentication flow has completed and that it is safe to close the
UIWebView/WKWebView
orSFSafariViewController
controller. In case aSFSafariViewController
controller is required to be used the specifc custom URL is defined by theapplication's custom scheme
(e.g.adbe.u-XFXJeTSDuJiIQs0HVRAg://adobe.com
), otherwise this specific custom URL is defined by theADOBEPASS_REDIRECT_URL
constant (that is,adobepass://ios.app
). -
Close the UIWebView/WKWebView or SFSafariViewController controller and call AccessEnabler鈥檚
handleExternalURL:url
API method, which instructs the AccessEnabler to retrieve the authentication token from the backend server. -
(Optional) Call
checkPreauthorizedResources(resources)
to check which resources the user is authorized to view. Theresources
parameter is an array of protected resources that is associated with the user鈥檚 authentication token. One use for the authorization information obtained from the user鈥檚 MVPD is to decorate your UI(for example, locked / unlocked symbols next to protected content).- Triggers:
preauthorizedResources()
callback - Execution point: After the completed Authentication Flow
- Triggers:
-
If authentication was successful, proceed to the Authorization Flow.
D. Authentication Flow with Apple SSO on iOS authn_flow_with_applesso
-
Call
getAuthentication()
to initiate the authentication flow, or to get confirmation that the user is already authenticated.
Triggers:- The presentTvProviderDialog() callback, if the user is not authenticated and the current requestor has at least on MVPD that supports SSO. If no MVPDs support SSO, the classic authentication flow will be used.
-
After the user selects a provider the AccessEnabler library will obtain an authentication token with the information provided by Apple鈥檚 VSA framework.
-
The setAuthenticatiosStatus() callback will be triggered. At this point the user should be authenticated with Apple SSO.
-
[Optional] Call
checkPreauthorizedResources(resources)
to check which resources the user is authorized to view. Theresources
parameter is an array of protected resources that is associated with the user鈥檚 authentication token. One use for the authorization information obtained from the user鈥檚 MVPD is to decorate your UI (for example, locked / unlocked symbols next to protected content).- Triggers:
preauthorizedResources()
callback - Execution point: After the completed Authentication Flow
- Triggers:
-
If authentication was successful, proceed to the Authorization Flow.
E. Authentication Flow with Apple SSO on tvOS authn_flow_with_applesso_tvOS
-
Call
getAuthentication()
to initiate the
authentication flow, or to get confirmation that the user is already
authenticated.
Triggers:- The
presentTvProviderDialog()
callback, if the user is not authenticated and the current requestor has at least on MVPD that supports SSO. If no MVPDs support SSO, the classic authentication flow will be used.
- The
-
After the user selects a provider the
status()
callback will be called. A registration code will be provided and the AccessEnabler library will start polling the server for a successfull second screen authentication. -
If the registration code provided was used to successfully authenticate on the second screen, the
setAuthenticatiosStatus()
callback will be triggered. At this point the user should be authenticated with Apple SSO. -
[Optional] Call
checkPreauthorizedResources(resources)
to check which resources the user is authorized to view. Theresources
parameter is an array of protected resources that is associated with the user鈥檚 authentication token. One use for the authorization information obtained from the user鈥檚 MVPD is to decorate your UI (for example, locked / unlocked symbols next to protected content).-
Triggers:
preauthorizedResources()
callback -
Execution point: After the completed Authentication Flow
-
-
If authentication was successful, proceed to the Authorization Flow.
F. Authorization Flow authz_flow
-
Call getAuthorization() to initiate the authorization flow.
- Dependency: Valid ResourceID(s) agreed upon with the MVPD(s).
- Resource IDs should be the same as those used on any other devices or platforms, and will be the same across MVPDs. For information on Resource IDs, see Identifying Protected Resources
-
Validate authentication and authorization.
-
If the getAuthorization() call succeeds: The user has valid AuthN and AuthZ tokens (the user is authenticated and authorized to watch the requested media).
-
If getAuthorization() fails: Examine the exception thrown to determine its type (AuthN, AuthZ, or something else):
- If it was an authentication (AuthN) error then re-start the authentication flow.
- If it was an authorization (AuthZ) error then the user is not authorized to watch the requested media and some kind of error message should be displayed to the user.
- If there was some other type of error (connection error, network error, etc.) then display an appropriate error message to the user.
-
-
Validate the Short Media Token.
Use the 51黑料不打烊 Pass Authentication Media Token Verifier library to verify the short-lived media token returned from the getAuthorization() call above:- If the validation succeeds: Play the requested media for the user.
- If the validation fails: The AuthZ token was invalid, the media request should be refused, and an error message should be displayed to the user.
-
Return to your normal application flow.
G. View Media Flow media_flow
-
User selects the media to view.
-
Is the media protected? Your application checks if the selected media is protected:
-
If the selected media is protected, your application starts the Authorization Flow above.
-
If the selected media is not protected, then play the media for
the user.
-
H. Logout Flow without Apple SSO logout_flow_wo_AppleSSO
-
Call
logout()
to log the user out. The AccessEnabler clears out all cached values and tokens. After clearing out the cache, the AccessEnabler makes a server call to clean the server-side sessions. Note that since the server call could result in a SAML redirect to the IdP (this allows for the session clean-up on the IdP side), this call must follow all redirects. For this reason, this call must be handled inside a UIWebView/WKWebView or SFSafariViewController controller.a. Following the same pattern as the authentication workflow, the AccessEnabler domain makes a request to the UI application layer, via the
navigateToUrl:
ornavigateToUrl:useSVC:
callback, to create a UIWebView/WKWebView or SFSafariViewController controller and instruct that to load the URL provided in the callback鈥檚url
parameter. This is the URL of the logout endpoint on the backend server.b. Your application must monitor the activity of the
UIWebView/WKWebView or SFSafariViewController
controller and detect the moment when it loads a specific custom URL, as it goes through several redirects. Note that this specific custom URL is actually invalid, and it is not intended for the controller to actually load it. It must be only interpreted by your application as a signal that the logout flow has completed and that it is safe to close theUIWebView/WKWebView
orSFSafariViewController
controller. When the controller loads this specific custom URL your application must close theUIWebView/WKWebView or SFSafariViewController
controller and call AccessEnabler鈥檚handleExternalURL:url
API method. In case aSFSafariViewController
controller is required to be used the specifc custom URL is defined by theapplication's custom scheme
(for example,adbe.u-XFXJeTSDuJiIQs0HVRAg://adobe.com
), otherwise this specific custom URL is defined by theADOBEPASS_REDIRECT_URL
constant (that is,adobepass://ios.app
).note note NOTE The logout flow differs from the authentication flow in that the user is not required to interact with the UIWebView/WKWebView or SFSafariViewController in any way. The UI application layer uses a UIWebView/WKWebView or SFSafariViewController to make sure that all the redirects are being followed. Therefore, it is possible (and recommended) to make the controller invisible (i.e. hidden) during the logout process.