Keep data up to date¶
A local cached Mobile Key is a short-life cryptographic key, which allows the app to unlock a specific lock. When a valid Mobile Key is cached, the lock can also be unlocked when the smartphone has no network connection.
The Tapkey Mobile SDK for iOS offers multiple strategies to keep data up to date. For best results, they should be combined.
Regular polling¶
To ensure regular polling for notifications from the Tapkey Trust Service, it is recommended to use the Background Processing feature provided by iOS. Follow the steps below to properly configure your app for background processing functionality:
- Enable Background Processing:
- Open your project in Xcode and navigate to the "Signing & Capabilities" section.
- In the "Background Modes" section, enable the "Background processing" option.
-
Enable the BackgroundPolling in the initialization of the Tapkey Mobile SDK:
3. Permit Task via Info.plistfunc application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool { TapkeyMobileSdk.initialize { builder in // Enables the background polling with the default Interval of 8h builder .withBackgroundPolling() // Or configure a polling interval, that fits your requirement // builder // .withBackgroundPolling(interval: 12 * 60 * 60) } }
Add the Task ID
io.tapkey.mobile-BackgroundPolling
to the permitted task scheduler identifiers of the target app's Info.plist:<key>BGTaskSchedulerPermittedIdentifiers</key> <array> ... <string>io.tapkey.mobile-BackgroundPolling</string> </array>
Manual polling¶
While the Background App Refresh is periodically looking for updated keys, it is recommended to poll for updates whenever updates are expected. NotificationManager#pollForNotificationsAsync()
can be used to manually check for updates. Manually checking for updated keys is recommended in the following situations:
- After a user has been logged in to the SDK.
- After a new grant has been issued for a logged-in user.
- After a grant that affects the current user has been modified or revoked.
- After grants, affecting locks that one of the logged-in users has access to, have been revoked. The logged-in users might receive updated revocation information.
Push Notifications¶
With push notifications, Tapkey will notify clients when Mobile Keys have been created, changed, or revoked. The Tapkey Mobile SDK for iOS will automatically download or delete the Mobile Keys.
Supported Push Notification Providers
For now, only Firebase Cloud Messaging is supported.
Preparations¶
-
Setup Firebase Project
Follow the Firebase Documentation to create a Firebase project and to set up the iOS project.
-
Connect Tapkey with Firebase
Follow these steps to register a Mobile App and configure Push Notifications
Default Implementation¶
The Tapkey Mobile SDK for iOS provides a default implementation for iOS, which is easy to integrate. This implementation is perfect for apps, which do not use Firebase Cloud Messaging for their own purposes.
Install the TapkeyMobileLib/Fcm
module via Cocapods
source 'https://github.com/tapkey/TapkeyCocoaPods'
source 'https://cdn.cocoapods.org/'
use_frameworks!
target 'App' do
pod 'TapkeyMobileLib', 'x.x.x.x'
pod 'TapkeyMobileLib/Fcm', 'x.x.xx'
end
Enable Firebase Cloud Messaging during the bootstrapping of the Tapkey Mobiles SDK for iOS and create an instance of the TKMFirebasePushNotificationService
:
import TapkeyFcm
...
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
...
TapkeyMobileSdk.initialize { builder in
builder
.withFirebaseCloudMessaging()
....
}
guard let pushNotificationManager = TapkeyMobileSdk.serviceFactory.pushNotificationManager else {
fatalError("Push notification is not configured")
}
self.firebaseNotificationService = TKMFirebasePushNotificationService(pushNotificationManager: pushNotificationManager)
...
}
Delegate the didReceiveRemoteNotification
callback to the TKMFirebasePushNotificationService
instance:
import TapkeyFcm
...
func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any], fetchCompletionHandler handler: @escaping (UIBackgroundFetchResult) -> Void ) {
self.firebaseNotificationService.didReceiveRemoteNotification(userInfo, fetchCompletionHandler: handler)
}
That's all, the Tapkey MobileSDK for iOS will now use the configured Firebase Cloud Messaging for receiving Push Notifications.
Custom Implementation¶
If the target app is using already Firebase Cloud Messaging for its own purposes, it will be required to provide a custom implementation.
Create PushNotificationTokenProvider¶
Tapkey Mobile SDK for iOS requires a PushNotificationTokenProvider
to register for Push Notifications. Create a custom implementation, which fits the requirements of the target application.
public class CustomPushNotificiationProviderImpl: TKMPushNotificationTokenProvider {
public func registerForPushNotificationsAsync() -> TKMPromise<String> {
// ToDo: register for Push Notification and return the registration token
}
}
Register the custom implementation to the TKMServiceFactoryBuilder
:
TapkeyMobileSdk.initialize { builder in
builder
.setPushNotificationTokenProvider(CustomPushNotificiationProviderImpl())
....
}
Forward Push Notifications¶
When your app receives a Push Notification that is intended for the Tapkey Mobile SDK for iOS, it has to be forwarded.
Either forward all Notifications. Tapkey Mobile SDK for iOS will ignore Push Notifications, which are not intended for the Tapkey Mobile SDK for iOS. PushNotificationManager.receivedPushNotification(data)
will return if it was intended for Tapkey Mobile SDK for iOS or not.
public func didReceiveRemoteNotification(_ userInfo: [AnyHashable: Any], fetchCompletionHandler handler: @escaping (UIBackgroundFetchResult) -> Void) {
TapkeyMobileSdk.serviceFactory.pushNotificationManager
.receivedPushNotification(userInfo: userInfo)
.continueOnUi { handled in
if handled ?? false {
// was handled by tapkey
return
}
// Handle push notification
}
.finallyOnUi {
handler(UIBackgroundFetchResult.newData)
}
.conclude()
}
Or check if the Notification is intended for Tapkey Mobile SDK for iOS before forwarding it:
public func didReceiveRemoteNotification(_ userInfo: [AnyHashable: Any], fetchCompletionHandler handler: @escaping (UIBackgroundFetchResult) -> Void) {
if userInfo.keys.contains(TapkeyPushNotificationIdentifier) {
TapkeyMobileSdk.serviceFactory.pushNotificationManager
.receivedPushNotification(userInfo: userInfo)
.conclude()
return
}
// Handle push notification
}
Update Registration Token¶
When the Push Notification Registration Token has been changed, the new token must be forwarded to the Tapkey Mobile SDK for iOS:
TapkeyMobileSdk.serviceFactory.pushNotificationManager
.updateRegistrationToken(pushNotificationRegistrationToken: registrationToken)
.conclude()