Use Identity Match to verify the ownership of a mobile phone number.
Identity Match compares user-supplied data, such as name, address, and date of birth, against authoritative sources. It returns match levels and an overall summary score, to help determine how closely the user's identity aligns with the information stored by these sources.
Identity Match is available for phone numbers in the following countries.
Identity Match is available for phone numbers in the United States and Brazil without additional carrier registration and approval.
Countries marked with a *
symbol require additional carrier registration and approval before using Identity Match. Once carrier registration and approval are complete, all successful queries will be billed to your account. For additional pricing and discount information, contact Sales.
Make a GET /v2/PhoneNumbers/{PhoneNumber}
request with the following as query parameters:
Fields=identity_match
FirstName=John
.1curl -X GET "https://lookups.twilio.com/v2/PhoneNumbers/{PhoneNumber}?Fields=identity_match&FirstName=John" \ -u2$TWILIO_ACCOUNT_SID:$TWILIO_AUTH_TOKEN
For detailed implementation examples, see Code examples and responses.
Provide the user-provided information as query parameters. Identity Match will provide match levels for how the given parameters compare against authoritative phone-based data sources.
Most of these parameters are optional for phone numbers in most countries. However, some countries have specific requirements.
Query parameter | Description | Max character length |
---|---|---|
FirstName | The user's first name. | 128 |
LastName | The user's last name. | 128 |
AddressLine1 | The user's first address line. Example: 1600 Pennsylvania Ave NW. | 256 |
AddressLine2 | The user's second address line. Example: Suite 2. | 256 |
City | The user's city. | 128 |
State | The user's country subdivision, such as state, province, or locality. | 128 |
PostalCode | The user's postal or ZIP code. | 10 |
AddressCountryCode | The user's country code. | 2 |
NationalId | The user's national ID, such as SSN. | 128 |
DateOfBirth | The user's date of birth in YYYYMMDD format. Example: 19901213. | 8 |
Some countries require specific parameters and have different data formatting rules. If a required parameter is missing, Error 60617 will be returned.
Parameter | Usage | Description |
---|---|---|
AddressLine1 | Optional | Use only the address formats in the following examples for flats, units, or apartments:
|
AddressLine2 | Don't include | Include this information in AddressLine1 . |
State | Optional | Use state abbreviations instead of the full state name. For example, QLD |
Parameter | Usage | Description |
---|---|---|
FirstName | Required | Use only the first word of the user's name if it contains multiple words. For example, use Luis for the name "Luis Carlos Teixeira Brito Junior." |
LastName | Required | Use all words after the first word of the user's name if it contains multiple words. For example, use Carlos Teixeira Brito Junior for the name "Luis Carlos Teixeira Brito Junior." |
AddressLine1 | Required | The user's address in the format [streetName streetNumber BL blNumber APT aptNumber neighborhoodName]. For example, RUA COSTA ESMERALDA 50 BL 14 APT 22 CENTR . |
AddressLine2 | Don't include | Include this information in AddressLine1 . |
City | Don't include | This parameter can't be evaluated in Brazil. |
AddressCountryCode | Don't include | This parameter can't be evaluated in Brazil. |
PostalCode | Don't include | This parameter can't be evaluated in Brazil. |
NationalId | Optional | The user's national ID, such as CPF. |
Parameter | Usage | Description |
---|---|---|
FirstName | Required | The user's first name. |
LastName | Required | The user's last name. |
AddressLine1 | Required | The street name and house number. For example, Immermannstraße 26 and Oderbergerstrasse 12 . |
City | Required | The user's city. |
PostalCode | Required | The user's postal code. |
DateOfBirth | Optional | The user's date of birth in YYYYMMDD format. |
Parameter | Usage | Description |
---|---|---|
FirstName | Required | The user's first name. |
LastName | Required | The user's last name. |
AddressLine1 | Required | The street name and house number or house name. If both the house number and house name are available, include them. |
PostalCode | Required | The user's postal code. |
Parameter | Usage | Description |
---|---|---|
FirstName | Required | The user's first name. |
LastName | Required | The user's last name. |
AddressLine1 | Required | The street type, street name, and building name or number. For example, via Garibaldi 27 or 27 via Garibaldi , Via Giacomo Quarenghi 34 or 34 Via Giacomo Quarenghi . |
PostalCode | Optional | The five-digit postal code. For example, 00015 . |
Parameter | Usage | Description |
---|---|---|
FirstName | Optional | The first initial of the user's name. For example, use L for the name "Luca." |
AddressLine1 | Optional | The street name and house number. For example, Jaarbeursplein 6A or Joris van Andringastraat 172 . |
PostalCode | Optional | The postal code consisting of four digits and two characters, with no spaces. For example, 3054SP or 3521AL . |
DateOfBirth | Optional | The user's date of birth in the YYYYMMDD format. For example, 19901214 . |
The response includes the identity_match
object, which contains match levels for the user's submitted data. The identity_match
object also contains a summary score that provides an overall match level for the user's identity.
Match level | Description | Example |
---|---|---|
exact_match | The user's data matches the mobile number's data exactly. | "Robert" matches "Robert". |
high_partial_match | The user's data almost exactly matches the mobile number's data. | "Robere" is a high partial match for "Robert". |
partial_match | The user's data moderately matches the mobile number's data. | "Bob", "Rob", or "R" are partial matches for "Robert". |
no_match | The user's data doesn't match the mobile number's data at all. | "John" doesn't match "Robert". |
no_data_available | No data is available for comparison. |
Attribute | Description | Allowed values |
---|---|---|
first_name_match | The match level for the FirstName attribute assigned to the submitted mobile number. | exact_match , high_partial_match , partial_match , no_match , no_data_available |
last_name_match | The match level for the LastName attribute assigned to the submitted mobile number. | exact_match , high_partial_match , partial_match , no_match , no_data_available |
address_line_match | The match level for the AddressLine1 and AddressLine2 attributes assigned to the submitted mobile number. | exact_match , high_partial_match , partial_match , no_match , no_data_available |
city_match | The match level for the City attribute assigned to the submitted mobile number. | exact_match , no_match , no_data_available |
state_match | The match level for the State attribute assigned to the submitted mobile number. | exact_match , no_match , no_data_available |
postal_code_match | The match level for the PostalCode attribute assigned to the submitted mobile number. | exact_match , no_match , no_data_available |
address_country_match | The match level for the AddressCountryCode attribute assigned to the submitted mobile number. | exact_match , no_match , no_data_available |
date_of_birth_match | The match level for the DateOfBirth attribute assigned to the submitted mobile number. | exact_match , high_partial_match (Canada only), partial_match (Canada only), no_match , no_data_available |
national_id_match | The match level for the NationalId attribute assigned to the submitted mobile number. | exact_match , no_match , no_data_available |
summary_score | A single summary score that indicates overall match level. | 0 , 20 , 40 , 70 , 80 , 100 |
The summary_score
represents the overall match level, with values ranging from 0
(no match) to 100
(exact match). Possible values include 0
, 20
, 40
, 70
, 80
, and 100
. This score isn't a percentage but is calculated based on the match values of the first_name_match
, last_name_match
, and address_line_match
properties.
The following table shows how the summary_score
is calculated based on different match scenarios:
first_name_match | last_name_match | address_line_match | summary_score |
---|---|---|---|
Any positive match: exact_match , high_partial_match , partial_match | Any positive match: exact_match , high_partial_match , partial_match | Any positive match: exact_match , high_partial_match , partial_match | 100 |
Any positive match: exact_match , high_partial_match , partial_match | Any negative match: no_match , no_data_available | Any positive match: exact_match , high_partial_match , partial_match | 80 |
Any positive match: exact_match , high_partial_match , partial_match | Any negative match: no_match , no_data_available | Any negative match: no_data_available | 70 |
Any positive match: exact_match , high_partial_match , partial_match | Any positive match: exact_match , high_partial_match , partial_match | Any negative match: no_match , no_data_available | 40 |
Any negative match: no_match , no_data_available | Any positive match: exact_match , high_partial_match , partial_match | Any positive match: exact_match , high_partial_match , partial_match | 20 |
Any positive match: exact_match , high_partial_match , partial_match | Any negative match: no_match , no_data_available | Any negative match: no_match , no_data_available | 0 |
Any negative match: no_match , no_data_available | Any positive match: exact_match , high_partial_match , partial_match | Any negative match: no_match , no_data_available | 20 |
Any negative match: no_match , no_data_available | Any negative match: no_match , no_data_available | Any positive match: exact_match , high_partial_match , partial_match | 0 |
Any negative match: no_match , no_data_available | Any negative match: no_match , no_data_available | Any negative match: no_match , no_data_available | 0 |
1// Download the helper library from https://www.twilio.com/docs/node/install2const twilio = require("twilio"); // Or, for ESM: import twilio from "twilio";34// Find your Account SID and Auth Token at twilio.com/console5// and set the environment variables. See http://twil.io/secure6const accountSid = process.env.TWILIO_ACCOUNT_SID;7const authToken = process.env.TWILIO_AUTH_TOKEN;8const client = twilio(accountSid, authToken);910async function fetchPhoneNumber() {11const phoneNumber = await client.lookups.v212.phoneNumbers("+14159929960")13.fetch({14addressCountryCode: "US",15addressLine1: "321 Main Street",16addressLine2: "Suite 2",17city: "New York",18dateOfBirth: "19901214",19fields: "identity_match",20firstName: "John",21lastName: "Doe",22nationalId: "YZ3456883",23postalCode: "10021",24state: "NY",25});2627console.log(phoneNumber.callingCountryCode);28}2930fetchPhoneNumber();
1{2"calling_country_code": "1",3"country_code": "US",4"phone_number": "+14159929960",5"national_format": "(415) 992-9960",6"valid": true,7"validation_errors": [],8"caller_name": null,9"sim_swap": null,10"call_forwarding": null,11"line_status": null,12"line_type_intelligence": null,13"identity_match": {14"first_name_match": "exact_match",15"last_name_match": "high_partial_match",16"address_lines_match": "no_match",17"city_match": "no_match",18"state_match": "high_partial_match",19"postal_code_match": "no_data_available",20"address_country_match": "exact_match",21"national_id_match": "exact_match",22"date_of_birth_match": "exact_match",23"summary_score": 90,24"error_code": null,25"error_message": null26},27"reassigned_number": null,28"sms_pumping_risk": null,29"phone_number_quality_score": null,30"pre_fill": null,31"url": "https://lookups.twilio.com/v2/PhoneNumbers/+14159929960"32}
Identity Match is most commonly used during new user onboarding workflows. Twilio recommends submitting all available end-user PII when a new user signs up for your service, with FirstName
, LastName
, and AddressLine1
as the minimum required parameters.
You can either rely on the summary score for a quick evaluation or implement more advanced logic based on individual parameter match levels. If you're validating more than the three key parameters mentioned above, Twilio suggests using your own match logic, as the summary score is calculated solely based on those parameters.
What's considered a "good match rate" for Identity Match depends on the attributes you prioritize for your use case and the quality of the data provided.
For example, imagine an end user is signing up for an online bank account. They're very likely to provide all the correct information. This will result in higher match rates across all data elements when that customer data is compared with data held at our authoritative sources.
Now imagine an end user is signing up for a social media account. They may not provide accurate data. This will result in lower match rates.
The quality of the data you submit directly impacts the match results returned by Identity Match.
No, the Identity Match API only supports a single input data set per request. This includes the name, address, date of birth, and national ID associated with the end user's mobile phone number. The API returns a single set of match results in response.