POSTVerify Sender OTP
Verify the sender OTP to authenticate the PPI Levin wallet and return the sender's profile and balance.
Validates the OTP issued by Get Sender Information / Onboard Sender. For an existing sender the response returns the full wallet customer_profile (limits, balance, KYC state) and a wallet_token used by downstream calls. For a new customer the flow continues to Aadhaar validation (Aadhar Validation Pending) and then PAN (Pan Number Required).
Path parameters
| Field | Type | Required | Description |
|---|---|---|---|
customer_id | string | required | Sender's 10-digit mobile number.e.g. 9444444444 |
customer_idstringRequiredSender's 10-digit mobile number.
example: 9444444444
Body parameters
| Field | Type | Required | Description |
|---|---|---|---|
initiator_id | string | required | Registered mobile number of the API user (see Platform Credentials).e.g. 9962981729 |
user_code | string | required | User code of the retailer/agent the service is run for.e.g. 20810200 |
client_ref_id | string | optional | Unique reference id per API call, generated by your system.e.g. REQ-20260101-001 |
otp | integer | required | OTP received from Get Sender Information, Onboard Sender, or Validate Aadhaar.e.g. 123456 |
otp_ref_id | integer | required | otp_ref_id received from Get Sender Information, Onboard Sender, or Validate Aadhaar.e.g. 66748392 |
intent_id | string | required | Intent flag: "19" for sender onboarding, "20" for Aadhaar validation.e.g. 19 |
initiator_idstringRequiredRegistered mobile number of the API user (see Platform Credentials).
example: 9962981729
user_codestringRequiredUser code of the retailer/agent the service is run for.
example: 20810200
client_ref_idstringoptionalUnique reference id per API call, generated by your system.
example: REQ-20260101-001
otpintegerRequiredOTP received from Get Sender Information, Onboard Sender, or Validate Aadhaar.
example: 123456
otp_ref_idintegerRequiredotp_ref_id received from Get Sender Information, Onboard Sender, or Validate Aadhaar.
example: 66748392
intent_idstringRequiredIntent flag: "19" for sender onboarding, "20" for Aadhaar validation.
example: 19
Headers
| Field | Type | Required | Description |
|---|---|---|---|
developer_key | string | required | Static API key issued to your account after KYC. |
secret-key | string | required | Dynamic per-request signature: base64(HMAC-SHA256(timestamp, base64(access_key))). |
secret-key-timestamp | string | required | Current time in milliseconds since UNIX epoch, used to compute secret-key. Must match server time. |
content-type | string | required | application/jsone.g. application/json |
developer_keystringRequiredStatic API key issued to your account after KYC.
secret-keystringRequiredDynamic per-request signature: base64(HMAC-SHA256(timestamp, base64(access_key))).
secret-key-timestampstringRequiredCurrent time in milliseconds since UNIX epoch, used to compute secret-key. Must match server time.
content-typestringRequiredapplication/json
example: application/json
Responses
statusnumberPrimary success indicator (0 = success).
messagestringHuman-readable response / error message.
response_status_idnumberGranular status id; see the shared error-codes table.
response_type_idnumberA unique id for every possible response shape (success or error) — useful for client logic branching and analytics.
dataobjectAPI-specific response payload.
customer_profileobjectSender's wallet profile — limits, balance, KYC state, and usage chart.
namestringRegistered name of the sender.
mobilestringSender's mobile number.
total_monthly_limitstringTotal monthly transfer limit (INR).
next_allowed_limitstringRemaining transfer limit for the period (INR).
balancestringCurrent wallet balance (INR).
ekyc_enablednumberWhether biometric eKYC is enabled (1) or not (0).
kyc_statenumberKYC completion state.
chartarrayUsage breakdown (used / remaining / unavailable).
data_type_idnumberChart data type identifier.
dataobjectUsed / remaining / unavailable amounts.
usednumberAmount used in the period (INR).
remainingnumberAmount remaining in the period (INR).
unavailablenumberAmount blocked/unavailable (INR).
wallet_tokenstringWallet authentication token (JWT) required by downstream PPI Levin calls.
is_registerednumberWhether the sender is already fully registered.
next_allowed_limitnumberRemaining transfer limit at the top level (INR).