Time based Authentication

TOTP Generation and validation APIs

API calls are region specific. Please make sure you are subscribed to a specific region and have a valid Renda API Key before making API calls.

Region Specific URLs: Ireland(Europe): https://api-eu.renda.io North Virginia(US): https://api-us.renda.io Mumbai(APAC): https://api-apac.renda.io

get
Get Ping

https://api-<region>.renda.io/totp/ping
Region specific URLs: Ireland(Europe):https://api-eu.renda.io/totp/ping North Virginia(US): https://api-us.renda.io/totp/ping Mumbai(APAC): https://api-apac.renda.io/totp/ping
Request
Response
Request
Headers
x-api-key
required
string
Renda API Key
Response
200: OK
Ping successful
{
"type": "Success",
"message": "Renda.io ping successful"
}
]
403: Forbidden
Invalid API Key
{
"message”:”Please check the following: 1) An *active* Renda.io
subscription 2) API being invoked must be *Subscribed* in Renda
developer portal 3) A valid *API Key* must be passed in ‘x-api-key’
request header parameter. Please refer to Renda documentation for
more details - https://documentation.renda.io"
}

post
generateQRCode

https://api-<region>.renda.io/totp/generateQRCode
Generate QR Code API encodes any form data such as text, URL, phone numbers etc., into a QR code.
Request
Response
Request
Headers
x-api-key
required
string
Renda API Key
Accept
optional
string
*/*
Content-type
required
string
application/x-www-form-urlencoded
Form Data Parameters
data
required
string
Data to be encoded in the QR Code
Response
200: OK
QR code in png format
<QR Code in png format>
400: Bad Request
[
{
"type": "Error",
"message": "No Data provided to generate QR Code"
}
]
403: Forbidden
Invalid API Request
{
"message": "Unsupported API request. Please refer to Renda
documentation for more details documentation.renda.io"
}

post
onboardUser

https://api-<region>/renda.io/totp/onboardUser
Onboard user API generates a secret key based on userid(which can be email address, name, number etc.,) and application ID. This API is useful to build user onboarding/authentication module whereby users can be authenticated using time based one time password (TOTP) generated by any soft token generator. This API returns a secret key, OTP URL, QR Code image encoded with the OTP URL which can be scanned to setup any soft key generator and a current TOTP passcode
Request
Response
Request
Headers
x-api-key
required
string
Renda API Key
Content-Type
optional
string
application/x-www-form-urlencoded
Form Data Parameters
userID
required
string
User ID (Email address, Employee ID etc.,)
applicationID
required
string
Application ID (Name of the app)
tokenValidity
optional
string
Token refresh interval - Default is 30 secs
tokenLength
optional
string
Token Length - Default is 6 digits
Response
200: OK
{
"secretKey": "LVJFKZI5AJZXIZKG",
"otpURL": "otpauth://totp/Renda:jafferali?secret=LVJFKZI5AJZXIZKG&period=30&digits=6&algorithm=SHA1&issuer=Renda",
"QRCode": "",
"token": "605250"
}
400: Bad Request
Parameters missing
[
{
"type": "Error",
"message": "User ID is mandatory"
},
{
"type": "Error",
"message": "Application ID is mandatory"
}
]

post
getOTP

https://api-<region>.renda.io/totp/getOTP
This API fetches the current valid OTP for a specified secret key. Token validity and token length parameters can be passed if they customised to be more than 30 seconds in duration and 6 digits in length
Request
Response
Request
Headers
x-api-key
required
string
Renda API Key
Content-Type
optional
string
application/x-www-form-urlencoded
Form Data Parameters
secret
required
string
Secret Key
tokenValidity
optional
string
Token validity (default to 30 secs)
tokenLength
optional
string
Token length (defaults to 6 digits)
Response
200: OK
{
"currentToken": "667122",
"timeUsed": 10,
"timeRemaining": 20,
"previousToken": "008989",
"nextToken": "390535"
}
400: Bad Request
Bad request
[
{
"type": "Error",
"message": "secret cannot be empty"
}
]
403: Forbidden
{
"message": "Unsupported API request. Please refer to Renda
documentation for more details documentation.renda.io"
}

post
verifyOTP

https://api-<region>.renda.io/totp/verifyOTP
This API method verifies the provided one time password(OTP) against a specific Secret key. Token validity can be passed in the validity period needs to be extended beyond the default 30 seconds.
Request
Response
Request
Headers
x-api-key
required
string
Renda API key
Content-Type
optional
string
application/x-www-form-urlencoded
Form Data Parameters
secret
required
string
Secret Key
token
required
string
OTP Token
tokenValidity
optional
string
Token validity (Default 30 seconds)
Response
200: OK
{
"isValid": false,
"token": "911726",
"timeUsed": 27,
"timeRemaining": 3
}
400: Bad Request
Mandatory parameters missing
[
{
"type": "Error",
"message": "Token cannot be empty"
},
{
"type": "Error",
"message": "Secret cannot be empty"
}
]
403: Forbidden
Invalid API Call
{
"message": "Unsupported API request. Please refer to Renda
documentation for more details documentation.renda.io"
}