PUTValidate eKYC OTP
Confirm sender eKYC by verifying the OTP sent to the Aadhaar-linked mobile.
Final step of the sender eKYC flow. Submit the OTP received on the Aadhaar-linked mobile number along with the otp_ref_id and kyc_request_id from the Sender eKYC response. On success the sender's account is upgraded to fully KYC-verified status with a ₹25,000 monthly limit.
Path parameters
| Field | Type | Required | Description |
|---|---|---|---|
customer_id | string | required | Sender's 10-digit mobile number.e.g. 9123456789 |
customer_idstringRequiredSender's 10-digit mobile number.
example: 9123456789
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 | string | required | One-time password received on the sender's Aadhaar-linked mobile number.e.g. 784512 |
otp_ref_id | string | required | OTP reference ID returned by the Sender eKYC (or Onboard Sender) API call.e.g. OTPREF20240101001 |
kyc_request_id | string | required | KYC request identifier returned by the Sender eKYC API call.e.g. KYC20240101001 |
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
otpstringRequiredOne-time password received on the sender's Aadhaar-linked mobile number.
example: 784512
otp_ref_idstringRequiredOTP reference ID returned by the Sender eKYC (or Onboard Sender) API call.
example: OTPREF20240101001
kyc_request_idstringRequiredKYC request identifier returned by the Sender eKYC API call.
example: KYC20240101001
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_idstringSender's mobile number (echoed back).
kyc_verifiedbooleanConfirms successful eKYC completion.
available_limitnumberUpdated monthly transfer limit after KYC (in INR).