HYPR Passwordless Authenticators
Guidelines for implementing the various HYPR Mobile App authenticator choices.
SDK for Android
build.gradle
The recommended way to install the library for Android is using the build system Gradle.
Do not add custom module dependencies to app/build.gradle
. Depending on which authenticators you plan to use, you must add custom library dependencies to app/<module_name>/build.gradle
.
The following code is a copy of app/build.gradle
installed by default during the Quick Start:
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
ext {
kotlin_version = '1.9.10'
}
repositories {
google()
jcenter()
maven {
url "https://plugins.gradle.org/m2/"
}
}
dependencies {
classpath 'com.android.tools.build:gradle:8.1.4'
classpath 'org.sonarsource.scanner.gradle:sonarqube-gradle-plugin:2.7.1'
classpath 'com.google.gms:google-services:4.4.0'
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
buildscript {
repositories {
flatDir {
dirs 'libs'
}
google()
jcenter()
mavenLocal()
if (project.hasProperty('REPO_URL')) maven { url "${REPO_URL}/groups/public" }
mavenCentral()
}
}
repositories {
flatDir {
dirs 'libs'
}
if (project.hasProperty('REPO_URL')) maven { url "${REPO_URL}/groups/public" }
google()
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
CustomHyprDbAdapter
Extend a CustomHyprDbAdapter
subclass from the existing HyprDbAdapter
class to provide helper methods for user management.
public class CustomHyprDbAdapter extends HyprDbAdapter {
/**
* Called after a new App Profile is created.
* Put any DB customizations here for the new App Profile.
*
* @param context current context
* @param appProfile appProfile object that was just created
*/
@Override
public void onNewAppProfileCreated(@NonNull final Context context,
@NonNull HyprAppProfileData appProfile) {
// customizations go here
}
}
To learn more about App Profiles, see the App Profiles page.
App
Create an App
subclass extending the MultiDexApplication
class. This will perform the HYPR Setup, which will initialize the HYPR crypto library and initialize your CustomHyprDbAdapter
class mentioned above.
public class App extends MultiDexApplication {
private static CustomHyprDbAdapter sHyprDbAdapter;
private static boolean sIsHyprInitComplete = false;
@Override
public void onCreate() {
super.onCreate();
sHyprDbAdapter = new CustomHyprDbAdapter();
// HYPR Setup - Initializes the HYPR Crytpo Library
HyprInit.getInstance().initTrustData(this, new HyprInit.InitTrustDataCallback() {
@Override
public void onInstallComplete() {
Log.d("App", "onInstallComplete");
sIsHyprInitComplete = true;
Toast.makeText(App.this, "Crypto Initialization Complete", Toast.LENGTH_SHORT).show();
}
@Override
public void onInstallError(@NonNull String error,
@Nullable Throwable throwable) {
Log.e("App", "onInstallError " + error);
}
}, sHyprDbAdapter);
}
public static CustomHyprDbAdapter getHyprDbAdapter() {
return sHyprDbAdapter;
}
public static boolean isSetupComplete() {
return sIsHyprInitComplete;
}
}
AndroidManifest.xml
Modify the Android manifest. If Android is to use your MultiDexApplication
subclass mentioned above, include the App
class in AndroidManifest.xml
as shown below; otherwise, continue.
<manifest>
<application
android:name="<your file path to>/App">
</manifest>
SDK for iOS
For information on individual authenticator methods, see the appropriate articles in this section.