Overview
OTPless SDK accepts the user’s identity (phone number or email), authenticates through multiple channels, and returns a secure token upon success.The merchant app sends this token to its backend, which verifies it with the OTPless Server before proceeding with the user journey.
Integration Steps
Step 1: Add SDK Dependency
First, let’s add the OTPLESS SDK to your project. Update your app’sbuild.gradle file by adding the following dependency:
Please check the latest version of the SDK here.
Make sure to synchronize your Gradle project to fetch the dependency.
Step 2: Update AndroidManifest.xml
Add this intent filter to your LoginActivity inAndroidManifest.xml:
This step is only needed for Magic Link. Smart Auth integration do not require this manifest intent-filter.
🔍 Example: If your App ID is “AcmeApp123”, scheme becomes otpless.acmeapp123
Additionally, ensure your activity is set to singleTop launch mode and that the exported attribute is true:
This step is only needed for Magic Link. Smart Auth integration do not require this manifest intent-filter.
Smart Authentication (SNA) Setup
- Make sure that Silent Network Authentication is enabled on the OTPLESS dashboard.
- Once you have successfully integrated OTPLESS Android SDK in your application, you only have to add the following line in your app’s
AndroidManifestfile in the<application>tag:
Step 3: Add SDK Initialization
ImportOtplessSDK in your LoginActivity.ktfile:
LoginActivity or LoginFragment depending upon your application architecture.
In case of:
- LoginActivity - Initialise the SDK in the
onCreate()function - LoginFragment - Initialise the SDK in the
onViewCreated()function.
Step 4: Handle Callback
Now, let’s implement a callback method to handle the response from the OTPLESS SDK (SDK callback flow).Handle Initiate Error Response:
Handle Verify Response
onNewIntent()
onNewIntent overriding is only needed for Magic Link. Smart Auth integration do not require this step.
Error Codes
Checkout error codes hereResponse Objects Structure
- SDK_READY
- FAILED
- INITIATE
- OTP_AUTO_READ
- VERIFY
- ONETAP
- DELIVERY_STATUS
- FALLBACK_TRIGGERED
Step 5: Initiate Authentication
Well done! You have completed the foundational setup of the SDK. Now, let’s move to the next step and understand how to initiate and verify different authentication modes. Choose the authentication mode you want to integrate from the options below:- Phone Auth
- Email Auth
- OAUTH
Phone Authentication 📱
Phone authentication allows users to verify their identity using their phone number. Merchants can choose from various authentication methods:
Phone authentication allows users to verify their identity using their phone number. Merchants can choose from various authentication methods:
- Silent Authentication (SNA) – Automatically verifies the user without requiring OTP or MAGICLINK.
- OTP on Desired Channel – Sends a one-time password (OTP) via SMS, WhatsApp, or another preferred channel.
- Magic Link – Sends a link that users can click to authenticate.
- SNA + OTP – Uses silent authentication first and falls back to OTP if needed.
- OTP + Magic Link – Sends both an OTP and a magic link, allowing users to authenticate via either method.
Verify OTP
To verify the OTP entered by the user, use theverify method with the necessary parameters. Verifying OTP is required only in case of OTP authentication. No need to verify OTP in case of MAGICLINK.