Android
Integrating ezto verify's SDK into your Flutter project for Android is straightforward. Follow our comprehensive documentation and sample code snippets to quickly implement user verification features.
1 Requirements
The minimum requirements needed in order to use the ezto verify SDK in your Flutter project. Ensure your development environment meets these prerequisites before proceeding with the integration.
- Dart SDK 3.4.0 and above
- Flutter SDK 3.22.0 and above
- Android 5 (API level 21)
2 Installation
To add the ezto verify SDK to your Flutter project, it is necessary to add the below code to your pubspec.yaml
file in the dependency section.
dependencies:
eztoverify: 8.0.5+25011602
3 Permissions
This section lists the permissions that need to be declared in your AndroidManifest.xml
file located in <PROJECT_DIR>\android\app\src\main\AndroidManifest.xml
. These permissions are required for the ezto verify SDK to function correctly, allowing it to access the necessary device features.
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.VIDEO_CAPTURE" />
<uses-permission android:name="android.permission.AUDIO_CAPTURE" />
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
4 Setup
This section explains how to set up the ezto verify SDK for different verification methods available. Currently, we have Android setup available for Biometric, FIDO, UAE PASS Verification, and DeepLink.
For the ezto verify SDK, the following requirement must be added to the android/build.gradle
file.
allprojects {
repositories {
google()
mavenCentral()
}
// Add this
subprojects {
afterEvaluate { project ->
if (project.hasProperty('android')) {
project.android {
if (namespace == null) {
namespace = project.group
}
}
}
}
}
}
Biometric
To enable Biometric in your Flutter project. It covers the necessary changes to your activity class and configuration in the build.gradle
file.
If you are using
FlutterActivity
directly, change it toFlutterFragmentActivity
in yourAndroidManifest.xml.
If you are using a custom activity, update your
MainActivity.kt
:
import io.flutter.embedding.android.FlutterFragmentActivity
class MainActivity: FlutterFragmentActivity() {
// ...
}
or MainActivity.java:
import io.flutter.embedding.android.FlutterFragmentActivity;
public class MainActivity extends FlutterFragmentActivity {
// ...
}
FIDO / Passkeys
To setup FIDO or Passkeys, it is necessary to include the proguard-rules.pro
to your project to ensure proper functionality.
-if class androidx.credentials.CredentialManager
-keep class androidx.credentials.playservices.** {
*;
}
UAE PASS Verification
This setup is optional and is only required when using UAE Pass.
To enable UAE PASS Verification, it is required to add the queries
section to your AndroidManifest.xml
file located in <PROJECT_DIR>\android\app\src\main\AndroidManifest.xml
:
<queries>
<package android:name="ae.uaepass.mainapp"/>
<package android:name="ae.uaepass.mainapp.stg"/>
</queries>
DeepLink
To setup the DeepLink functionality, it is required to intent filters and configurations in the AndroidManifest.xml
file located in <PROJECT_DIR>\android\app\src\main\AndroidManifest.xml
to handle deep links correctly.
<!-- By default, flutter Activity is set with android:launchMode="singleTop". This is perfectly fine and expected, but this launches another instance of your app, specifically for the requested view.
If you don't want this behaviour, you can set android:launchMode="singleInstance" in your AndroidManifest.xml to avoid another flutter warmup. -->
<activity
android:launchMode="singleInstance">
<!-- Make sure you explicitly set android:autoVerify to "true". -->
<intent-filter android:autoVerify="true">
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<!-- If a user clicks on a shared link that uses the "http" scheme, your
app should be able to delegate that traffic to "https". -->
<data android:scheme="https" />
<!-- Include one or more domains that should be verified. -->
<!-- Replace example.ezto.io with your ezto verify workspace url -->
<!-- Go to Dashboard > Settings > General, copy the URL. -->
<data android:host="example.ezto.io" />
<data android:path="/auth/deeplink.html" />
</intent-filter>
</activity>