PingOne MFA Mobile SDK is a set of components and services targeted at enabling organizations to include multifactor authentication (MFA) into native applications.
This solution leverages Ping Identity’s expertise in MFA technology, as a component that can be embedded easily and quickly into a new or existing application.
Release notes can be found here.
Reference documentation is available for PingOne MFA Mobile SDK, describing its capabilities, features, installation and setup, integration with mobile apps, deployment and more:
- Introduction to PingOne MFA
- PingOne MFA Mobile SDK Overview
- PingOne MFA Mobile SDK API Documentation
- PingOne MFA Mobile SDK Sample App
- PingOne MFA SDK Ready-For-Use Authenticator App
- Prerequisites
- Device Integrity Validation
PingOne MFA Mobile SDK supports Android 8.0 (API level 26) and up, Gradle 7.2 and up, Java 17 and up. Starting Android 13 (API level 33) the application needs to request the 'Post Notifications' permission from the user in order to show notifications. For more information see Notification Runtime Permission Documentation.
- Version 1.9.0 of the PingOne MFA SDK for Android did not support SL4J dependency version 2.0.0 or higher. This limitation affects users who require SL4J version 2.0.0 or higher to run their application. SL4J is a logging library that is commonly used by Java applications. The PingOne MFA SDK uses SL4J as a dependency to log its own internal messages. Workaround: Use a compatible version of SL4J (lower than 2.0.0).
This issue was fixed in version 1.10.0.
Prepare the FCM push messaging mandatory data from Firebase developers console:
- Package name
- Server key
- google-services.json
Refer to: Add Firebase to your Android project.
Prepare the HMS push messaging mandatory data from Huawei developers console:
- Package name
- App ID
- Client ID
- Client secret
- agconnect-services.json
Refer to: Integrating Push Kit.
Add the google-services.json retrieved from the Firebase developers console to your project.
When configuring your PingOne MFA SDK application in the PingOne admin web console you should fill in the Package Name and the Server Key. See Edit an application in the administration guide.
Add the agconnect-services.json retrieved from the Huawei developers console to your project.
When configuring your PingOne MFA SDK application in the PingOne admin web console you should fill in the Package Name, App ID, Client ID and the Client Secret. See Edit an application in the administration guide.
- In the Project
build.gradle
file, make sure you have themavenCentral
repository:
// ...
repositories {
mavenCentral()
}
// ...
- In the application
build.gradle
file add the latest version of the PingOne MFA Android SDK:
dependencies {
// Check for the latest version at https://search.maven.org/search?q=g:com.pingidentity.pingonemfa
implementation 'com.pingidentity.pingonemfa:android-sdk:1.10.0'
}
PingOne MFA SDK utilizes push messaging in order to authenticate end users. PingOne MFA SDK can work side by side within an app that uses push messaging. This page details the steps needed in order to work with push messages in Android. Your application may receive push messages from the PingOne SDK server, and also from other sources. As a result, your implementation of the FirebaseMessagingService or HmsMessageService will have to differentiate between push messages sent from the PingOne SDK server and other messages, and pass them to the PingOne SDK component for processing.
In your app, add the appropriate section in your AndroidManifest.xml file (FCM or HMS messaging service), and add the appropriate class.
Retrieve the Push Registration Token from the FCM or HMS and set it in the PingOne Library by calling
public static void setDeviceToken(Context context, String token, NotificationProvider provider, PingOneSDKCallback callback);
For FCM:
PingOne.setDeviceToken(context, token, NotificationProvider.FCM, new PingOne.PingOneSDKCallback())
For HMS:
PingOne.setDeviceToken(context, token, NotificationProvider.HMS, new PingOne.PingOneSDKCallback())
Make sure you set the device’s push token before you call PingOne.pair
, and make sure you update the PingOne MFA SDK Library with the new device's push token each time it changes.
PingOne MFA SDK will only handles push notifications which were issued by the PingOne SDK server. For other push notifications, the PingOneSDKError
object with the code 10002, unrecognizedRemoteNotification
will be returned.
You can use the "category" field to customize the notification behavior according to the value set on the PingOne server. Retrieve the category of the push message by calling remoteMessage.getData().get("category")
.
For information on selecting a category on the server side, see: edit a notification template.
Implement the PingOne library’s push handling by passing the RemoteMessage received from FCM to the PingOne Library. (Note: you must override the onMessageReceived
method of the FirebaseMessagingService
)
@Override
public void onMessageReceived(final RemoteMessage remoteMessage) {
PingOne.processRemoteNotification(context, remoteMessage, new PingOne.PingOneNotificationCallback() {
@Override public void onComplete(@Nullable NotificationObject notificationObject, PingOneSDKError error) {
if (notificationObject == null){
//the push is not from PingOne - apply your customized application logic
}else{
//the object contains two options - approve and deny - present them to the user
}
}
});
}
Implement the PingOne library’s push handling by passing the RemoteMessage data received from HMS to the PingOne Library. (Note: you must override the onMessageReceived
method of the HmsMessageService
)
@Override
public void onMessageReceived(final RemoteMessage remoteMessage) {
PingOne.processRemoteNotification(context, remoteMessage.getData(), new PingOne.PingOneNotificationCallback() {
@Override public void onComplete(@Nullable NotificationObject notificationObject, PingOneSDKError error) {
if (notificationObject == null){
//the push is not from PingOne - apply your customized application logic
}else{
//the object contains two options - approve and deny - present them to the user
}
}
});
}
Beginning with version 1.9.0, PingOne Android SDK uses the Google Play Integrity API to perform device integrity validation for threat protection. Previously, the SDK used Google's SafetyNet API. Use of the SafetyNet API has been deprecated, and device integrity validation will fail for applications using SDK version 1.9.0 and higher if they have not been updated to use the Play Integrity API.
To use the Play Integrity API:
- Setup a Google Cloud project and enable Play Integrity API in the project. Find the project number in the project settings.
- Add a Play Integrity API dependency in your application:
dependencies{ implementation "com.google.android.play:integrity:1.1.0" }
- Pass your Google Cloud project number to the SDK by calling:
public static void setGooglePlayIntegrityProjectNumber(Context context, String projectNumber);
Refer to Use the Play Integrity API for details on setting up and managing the Play Integrity API.
See the Mobile device integrity check section in the PingOne MFA SDK for Android for detailed step-by-step instructions.
THE SAMPLE CODE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SAMPLE CODE OR THE USE OR OTHER DEALINGS IN
THE SAMPLE CODE. FURTHERMORE, THIS SAMPLE CODE IS NOT COMMERCIALLY SUPPORTED BY PING IDENTITY BUT QUESTIONS MAY BE ADDRESSED TO PING'S SUPPORT CENTER OR MAY BE OTHERWISE ADDRESSED IN THE RELATED DOCUMENTATION.
Any questions or issues should go to the support center, or may be discussed in the Ping Identity developer communities.