Veriph.One's API (1.X.X)
Download OpenAPI specification:Download
This is the documentation for Veriph.One's integration and service APIs. You can find more information about our company at www.veriph.one.
This API is grouped into specific categories based on common platform use-cases; for example:
- The SDK Integration group is used to make a complete integration with our platform and use all of our verification methods insided your mobile and web apps. This is the most common use case.
- The Helper Services group aggregates endpoints used for more complex interactions with our platforms where you want to go beyond our SDK's functionality.
- Lastly, the Misc category is used to interact and monitor our infrastructure.
This API is documented in OpenAPI format and can also be explored using Swagger via its standalone website, or its JSON and YAML definitions.
The endpoints shown here are offered under API-Key-based authentication. Please consider that some endpoints require only your API Key, while others need your Secret as well. Keep your credentials safe and never include them in your code repositories as plain text. Also, don't expose your API Secret to client-side code, as it can be reverse-engineered.
Our versioning strategy goes beyond a global API version, and we follow a pattern where endpoints have individual versions instead of the API as a whole. This allows for more versatility and better backwards compatibility. Please consider that only major versions (e.g., v1.X.X or v2.X.X) will be incompatible to endpoints with previous versions.
Start a verification session
Create a verification session for the SDK using the configuration of the API Key provide as credentials. It can be further customized by passing the optional configuration
parameter. Please ensure that the metadata
object is correctly filled as it is used to configure the user experience and detect fraud. Additionally, if you pass an object to the optional prefilledPhoneNumber
, you can set up a 2FA/MFA flow or one where the user will need to verify a specific number; this interacts prefilledPhoneNumber.userCanEdit
to allow them to change the number to be verified.
header Parameters
x-api-key required | string Your Veriph.One API Key |
Request Body schema: application/jsonrequired
object This object determines whether the verification process will capture an unknown number or do a 2FA/MFA flow with a known one. In case of the latter, the verification will be rejected if the user verifies a different number. | |
required | object Necessary data to detect bots, unique transactions, fraudsters, and user's approximate location. |
object Used to setup the verification process based on context provided by your application. |
Responses
Request samples
- Payload
{- "prefilledPhoneNumber": {
- "countryCode": "string",
- "cellphoneNumber": "string",
- "userCanEdit": false
}, - "metadata": {
- "userId": "string",
- "userAgent": "string",
- "ipAddress": "string"
}, - "configuration": {
- "locale": "en",
- "enforceInput": false
}
}
Response samples
- 200
- 400
- 403
{- "uuid": "string",
- "createdAt": "2019-08-24T14:15:22Z",
- "redirectionUrl": "string"
}
Get verification result (v1.0.0)
Obtain the results of a verification using a session UUID and your API Key credentials. This endpoint should never be called from client-side software to avoid leaking your API Key.
query Parameters
sessionUuid required | string |
header Parameters
authorization required | string Your Veriph.One API Key Secret; using the Basic auth structure: |
x-api-key required | string Your Veriph.One API Key |
Responses
Response samples
- 200
- 400
- 403
{- "prefilledCountryCode": "string",
- "prefilledPhoneNumber": "string",
- "createdAt": "2019-08-24T14:15:22Z",
- "closedAt": "2019-08-24T14:15:22Z",
- "userId": "string",
- "firstSuccessfulAttempt": {
- "uuid": "string",
- "countryCodeInput": "string",
- "phoneNumberInput": "string",
- "method": 0,
- "status": 0,
- "createdAt": "2019-08-24T14:15:22Z"
}, - "attempts": [
- {
- "uuid": "string",
- "countryCodeInput": "string",
- "phoneNumberInput": "string",
- "method": 0,
- "status": 0,
- "createdAt": "2019-08-24T14:15:22Z"
}
]
}
Get verification result (v1.1.0)
Obtain the results of a verification using a session UUID and your API Key credentials. This endpoint should never be called from client-side software to avoid leaking your API Key. Version 1.1.0 also includes data enrichment objects that contain information on the phone number that was verified and the context of the verification process. These data points are optional and can be ommitted to reduce latency.
query Parameters
sessionUuid required | string |
enrichmentType required | number Default: 0 Determines the type of enrichment you want to obtain. Take into consideration that if you request all of the data points, the payload will increase in size substantially and latency might be introduced. We recommend only getting the data points you need based on the context around the verification. By default, no enrichment is done. See catalog of possible values here. |
header Parameters
authorization required | string Your Veriph.One API Key Secret; using the Basic auth structure: |
x-api-key required | string Your Veriph.One API Key |
Responses
Response samples
- 200
- 400
- 403
{- "uuid": "string",
- "createdAt": "2019-08-24T14:15:22Z",
- "closedAt": "2019-08-24T14:15:22Z",
- "initialConfiguration": {
- "prefilledCountryCode": {
- "countryIsoCode3166_2": "string",
- "phoneCode": "string"
}, - "prefilledPhoneNumber": "string",
- "userId": "string",
- "locale": "string",
- "enforceInput": true
}, - "type": "string",
- "result": {
- "status": 0,
- "parsedStatus": {
- "isOpen": true,
- "wasSuccessful": true,
- "hasErrors": true,
- "errorDestinationMismatch": true,
- "errorOriginMismatch": true,
- "errorInvalidated": true,
- "errorExpired": true,
- "errorClientDisabled": true,
- "errorMethodTampering": true,
- "errorTooManySubmissions": true,
- "errorExceededAttemptQuota": true,
- "errorUserCancelledAttempt": true
}, - "methodUsedSuccessfully": 0,
- "verifiedNumber": {
- "countryCode": {
- "countryIsoCode3166_2": "string",
- "phoneCode": "string"
}, - "phoneNumber": "string",
- "metadata": {
- "serviceProvider": {
- "legalName": "string",
- "brandName": "string",
- "isRetail": true,
- "isB2B": true,
- "sellsVirtualNumbers": true,
- "sellsSatellitePhones": true,
- "isWhiteLabel": true,
- "sellsIPTelephony": true,
- "sellsVoIP": true,
- "sellsVoLTE": true
}, - "numberMetadata": {
- "isGeographic": true,
- "geographicData": {
- "locality": "string",
- "municipality": "string",
- "state": "string",
- "type": 0
}, - "nonGeographicData": {
- "type": 0
}
}, - "blacklistMatches": {
- "publicVirtualNumbers": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
], - "scammerBlacklists": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
], - "communityFraudBlacklists": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
]
}, - "knownCapabilities": {
- "lastSMSReceived": "2019-08-24T14:15:22Z",
- "lastSMSSent": "2019-08-24T14:15:22Z",
- "lastWhatsAppReceived": "2019-08-24T14:15:22Z",
- "lastWhatsAppSent": "2019-08-24T14:15:22Z",
- "lastPhoneCallReceived": "2019-08-24T14:15:22Z",
- "lastPhoneCallMade": "2019-08-24T14:15:22Z"
}
}
}
}, - "verificationMetadata": {
- "userAgent": "string",
- "userIpAddress": "string",
- "proxyIpAddress": "string",
- "userIpMetadata": {
- "geolocation": {
- "city": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0
}, - "continent": {
- "geoNameId": 0,
- "localizedName": "string",
- "code": "string"
}, - "country": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string"
}, - "accuracyRadiusInKm": 0,
- "avgIncomeInUSD": 0,
- "latitude": 0,
- "longitude": 0,
- "populationDensity": 0,
- "timezone": "string",
- "zipCode": "string",
- "zipCodeConfidence": 0
}, - "ipCountryRegistration": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string"
}, - "ipCountryAssociation": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string",
- "type": "string"
}, - "ipCountrySubdivisions": [
- {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string"
}
], - "autonomousSystemNumber": 0,
- "autonomousSystemOrganization": "string",
- "connectionType": "string",
- "domain": "string",
- "externalIpAddress": "string",
- "isAnonymous": true,
- "isAnonymousVpn": true,
- "isHostingProvider": true,
- "isPublicProxy": true,
- "isResidentialProxy": true,
- "isTorExitNode": true,
- "ispName": "string",
- "mobileCountryCode": "string",
- "mobileNetworkCode": "string",
- "network": "string",
- "organization": "string",
- "staticIpScore": 0,
- "userCountInLast24Hrs": 0,
- "userType": "string"
}, - "sessionDuration": 0,
- "attempts": [
- {
- "uuid": "string",
- "method": 0,
- "status": 0,
- "createdAt": "2019-08-24T14:15:22Z",
- "attemptCancellationReason": "string",
- "numberUsed": {
- "countryCode": {
- "countryIsoCode3166_2": "string",
- "phoneCode": "string"
}, - "phoneNumber": "string",
- "metadata": {
- "serviceProvider": {
- "legalName": "string",
- "brandName": "string",
- "isRetail": true,
- "isB2B": true,
- "sellsVirtualNumbers": true,
- "sellsSatellitePhones": true,
- "isWhiteLabel": true,
- "sellsIPTelephony": true,
- "sellsVoIP": true,
- "sellsVoLTE": true
}, - "numberMetadata": {
- "isGeographic": true,
- "geographicData": {
- "locality": "string",
- "municipality": "string",
- "state": "string",
- "type": 0
}, - "nonGeographicData": {
- "type": 0
}
}, - "blacklistMatches": {
- "publicVirtualNumbers": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
], - "scammerBlacklists": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
], - "communityFraudBlacklists": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
]
}, - "knownCapabilities": {
- "lastSMSReceived": "2019-08-24T14:15:22Z",
- "lastSMSSent": "2019-08-24T14:15:22Z",
- "lastWhatsAppReceived": "2019-08-24T14:15:22Z",
- "lastWhatsAppSent": "2019-08-24T14:15:22Z",
- "lastPhoneCallReceived": "2019-08-24T14:15:22Z",
- "lastPhoneCallMade": "2019-08-24T14:15:22Z"
}
}
}, - "messagesReceivedFromUser": [
- {
- "sentAt": "2019-08-24T14:15:22Z",
- "receivedAt": "2019-08-24T14:15:22Z",
- "channel": 0,
- "wasOTP": true,
- "userWhatsAppProfileName": "string",
- "usedThirdPartyIntegration": true
}
], - "messagesSentToUser": [
- {
- "sentAt": "2019-08-24T14:15:22Z",
- "receivedAt": "2019-08-24T14:15:22Z",
- "channel": 0,
- "wasOTP": true,
- "userWhatsAppProfileName": "string",
- "usedThirdPartyIntegration": true
}
]
}
], - "languagesUsed": [
- "string"
]
}
}
Send a non-SDK OTP
This endpoint is a standalone service that allows your application to send OTP messages via SMS, WhatsApp (requires initial setup; contact us for more information), and phone call without using the Veriph.One SDK. Please note that this service has an independent billing scheme (per message sent not successful verification), and by using it you are losing SMS pumping protection and other important security features.
header Parameters
authorization required | string Your Veriph.One API Key Secret; using the Basic auth structure: |
x-api-key required | string Your Veriph.One API Key |
Request Body schema: application/jsonrequired
countryCode required | string Expected number's country code, without '+' sign or non-numeric characters |
cellphoneNumber required | string Expected phone number without country code or non-numeric characters |
channel required | number The channel to use for the message. Values: SMS [0], WhatsApp [1], Phone Call [2]. |
otpCode required | string The OTP to include in the message template. Enforced string length range: 4-16. Only alphanumeric characters accepted (no diacritics, whitespace or symbols): 0-9, a-z, and A-Z. |
brandLabel required | string A string to let user know who is sending the OTP, use a short brand/product name; must be at least 2 characters long. The string might be shortened if space is needed to fit the message inside a single SMS message. The string is shown inside parentheses for SMS/WhatsApp; for example, in english: |
locale required | string Default: "en" String determining the language of the message to be sent in ISO 639-1 format. Currently, only |
userAgent required | string or null Used to detect fraudsters, bots, and identity theft; please ensure that you are sending proper values as obtained by your server. |
ipAddress required | string or null The user's IP address captured by your server. This is a critical data point to detect fraud, offer the best verification methods available, among other operations. |
Responses
Request samples
- Payload
{- "countryCode": "string",
- "cellphoneNumber": "string",
- "channel": 0,
- "otpCode": "string",
- "brandLabel": "string",
- "locale": "en",
- "userAgent": "string",
- "ipAddress": "string"
}
Response samples
- 200
- 400
- 401
- 402
- 403
{- "createdAt": "2019-08-24T14:15:22Z",
- "countryCode": "string",
- "phoneNumber": "string",
- "channel": 0,
- "locale": "string",
- "referenceId": "string"
}
Phone number and IP address enrichment
This endpoint is a standalone version of our Get Verification Result service that allows your application to get data known for an IP address and/or phone number. It can be used to enrich user profiles, feed risk and credit models, stop fraud, detect hackers, and more. Please note that this service has an independent billing scheme (per request), and by using it you are losing the benefits of the SDK (e.g., additional enrichment, phone number verification, fraud prevention, etc). Even though your app can send either phone number or IP address, we recommend sending both for better results. Finally, this service is only available to paid plans and accounts with a minimum balance of 1 USD.
header Parameters
authorization required | string Your Veriph.One API Key Secret; using the Basic auth structure: |
x-api-key required | string Your Veriph.One API Key |
Request Body schema: application/jsonrequired
required | object or null The phone number to enrich; can be provided as a string in E.164 format (e.g., +14155552671) or an object containing country code and number separately. Can only be null if ipAddress is provided. |
ipAddress required | string or null The IP address to enrich; must be in IPv4 or IPv6 format. Can only be null if phoneNumber is provided. Please note that invalid, reserved, private, or local IP addresses (e.g., 127.0.0.1) will return no information. |
Responses
Request samples
- Payload
{- "phoneNumber": {
- "ituFormatedPhoneNumber": "string",
- "splitPhoneNumber": {
- "countryCode": "string",
- "phoneNumber": "string"
}
}, - "ipAddress": "string"
}
Response samples
- 200
- 400
- 402
- 403
{- "countryCode": {
- "countryIsoCode3166_2": "string",
- "phoneCode": "string"
}, - "phoneNumber": "string",
- "phoneNumberDetails": {
- "serviceProvider": {
- "legalName": "string",
- "brandName": "string",
- "isRetail": true,
- "isB2B": true,
- "sellsVirtualNumbers": true,
- "sellsSatellitePhones": true,
- "isWhiteLabel": true,
- "sellsIPTelephony": true,
- "sellsVoIP": true,
- "sellsVoLTE": true
}, - "numberMetadata": {
- "isGeographic": true,
- "geographicData": {
- "locality": "string",
- "municipality": "string",
- "state": "string",
- "type": 0
}, - "nonGeographicData": {
- "type": 0
}
}, - "blacklistMatches": {
- "publicVirtualNumbers": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
], - "scammerBlacklists": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
], - "communityFraudBlacklists": [
- {
- "firstAppearance": "2019-08-24T14:15:22Z",
- "lastReport": "2019-08-24T14:15:22Z",
- "listName": "string"
}
]
}, - "knownCapabilities": {
- "lastSMSReceived": "2019-08-24T14:15:22Z",
- "lastSMSSent": "2019-08-24T14:15:22Z",
- "lastWhatsAppReceived": "2019-08-24T14:15:22Z",
- "lastWhatsAppSent": "2019-08-24T14:15:22Z",
- "lastPhoneCallReceived": "2019-08-24T14:15:22Z",
- "lastPhoneCallMade": "2019-08-24T14:15:22Z"
}
}, - "userIpAddress": "string",
- "proxyIpAddress": "string",
- "userIpMetadata": {
- "geolocation": {
- "city": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0
}, - "continent": {
- "geoNameId": 0,
- "localizedName": "string",
- "code": "string"
}, - "country": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string"
}, - "accuracyRadiusInKm": 0,
- "avgIncomeInUSD": 0,
- "latitude": 0,
- "longitude": 0,
- "populationDensity": 0,
- "timezone": "string",
- "zipCode": "string",
- "zipCodeConfidence": 0
}, - "ipCountryRegistration": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string"
}, - "ipCountryAssociation": {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string",
- "type": "string"
}, - "ipCountrySubdivisions": [
- {
- "geoNameId": 0,
- "localizedName": "string",
- "confidence": 0,
- "isoCode": "string"
}
], - "autonomousSystemNumber": 0,
- "autonomousSystemOrganization": "string",
- "connectionType": "string",
- "domain": "string",
- "externalIpAddress": "string",
- "isAnonymous": true,
- "isAnonymousVpn": true,
- "isHostingProvider": true,
- "isPublicProxy": true,
- "isResidentialProxy": true,
- "isTorExitNode": true,
- "ispName": "string",
- "mobileCountryCode": "string",
- "mobileNetworkCode": "string",
- "network": "string",
- "organization": "string",
- "staticIpScore": 0,
- "userCountInLast24Hrs": 0,
- "userType": "string"
}
}