AddressValidation class
google.maps.addressValidation.AddressValidation
class
Static class for accessing the AddressValidation APIs.
const {AddressValidation} = await google.maps.importLibrary("addressValidation");
Static Methods | |
|---|---|
fetchAddressValidation |
fetchAddressValidation(request)Parameters:
Return Value:
Promise<AddressValidation>Validates an address. See https://developers.google.com/maps/documentation/javascript/address-validation/validate-address. |
Properties | |
|---|---|
address
readonly |
Type:
Address optionalInformation about the address itself as opposed to the geocode. |
geocode
readonly |
Type:
Geocode optionalInformation about the location and place that the address geocoded to. |
metadata
readonly |
Type:
AddressMetadata optionalOther information relevant to deliverability. metadata is not guaranteed to be fully populated for every address sent to the Address Validation API. |
responseId
readonly |
Type:
string optionalThe UUID that identifies this response. If the address needs to be re-validated, this UUID must accompany the new request. |
uspsData
readonly |
Type:
USPSData optionalExtra deliverability flags provided by USPS. Only provided in region US and PR. |
verdict
readonly |
Type:
Verdict optionalOverall verdict flags |
Methods | |
|---|---|
Inherited:
toJSON
|
AddressValidationRequest interface
google.maps.addressValidation.AddressValidationRequest
interface
Request interface for AddressValidation.fetchAddressValidation.
Properties | |
|---|---|
address |
Type:
PostalAddressLiteralThe address being validated. Unformatted addresses should be submitted via PostalAddress.addressLines. |
placeAutocompleteElement
optional |
Type:
PlaceAutocompleteElement optionalIf using a PlaceAutocompleteElement, include it here to link the AddressValidation API calls with the autocomplete session token. |
previousResponseId
optional |
Type:
string optionalThis field must not be set for the first address validation request. If more requests are necessary to fully validate a single address (for example if the changes the user makes after the initial validation need to be re-validated), then each followup request must populate this field with the AddressValidation.responseId from the very first response in the validation sequence. |
sessionToken
optional |
Type:
AutocompleteSessionToken optionalA token which identifies an Autocomplete session for billing purposes. |
uspsCASSEnabled
optional |
Type:
boolean optionalEnables USPS CASS compatible mode. This affects only the AddressValidation.uspsData field of AddressValidation. Note: for USPS CASS enabled requests for addresses in Puerto Rico, a PostalAddress.regionCode of the address must be provided as "PR", or an PostalAddress.administrativeArea of the address must be provided as "Puerto Rico" (case-insensitive) or "PR". |
Address class
google.maps.addressValidation.Address
class
Details of the post-processed address. Post-processing includes correcting misspelled parts of the address, replacing incorrect parts, and inferring missing parts.
const {Address} = await google.maps.importLibrary("addressValidation");
Properties | |
|---|---|
components
readonly |
Type:
Array<AddressComponent>The individual address components of the formatted and corrected address, along with validation information. This provides information on the validation status of the individual components. |
formattedAddress
readonly |
Type:
string optionalThe post-processed address, formatted as a single-line address following the address-formatting rules of the region where the address is located. |
missingComponentTypes
readonly |
Type:
Array<string>The types of components that were expected to be present in a correctly formatted mailing address but were not found in the input AND could not be inferred. Components of this type are not present in formatted_address, postal_address, or address_components. An example might be ['street_number', 'route'] for an input like "Boulder, Colorado, 80301, USA". The list of possible types can be found here. |
postalAddress
readonly |
Type:
PostalAddress optionalThe post-processed address represented as a postal address. |
unconfirmedComponentTypes
readonly |
Type:
Array<string>The types of the components that are present in the address_components but could not be confirmed to be correct. This field is provided for the sake of convenience: its contents are equivalent to iterating through the address_components to find the types of all the components where the AddressComponent.confirmationLevel is not ConfirmationLevel.CONFIRMED or the AddressComponent.inferred flag is not set to true. The list of possible types can be found here. |
unresolvedTokens
readonly |
Type:
Array<string>Any tokens in the input that could not be resolved. This might be an input that was not recognized as a valid part of an address (for example in an input like "123235253253 Main St, San Francisco, CA, 94105", the unresolved tokens may look like ["123235253253"] since that does not look like a valid street number. |
Methods | |
|---|---|
Inherited:
toJSON
|
AddressComponent class
google.maps.addressValidation.AddressComponent
class
Represents a single component of an address (ex. street name, city).
const {AddressComponent} = await google.maps.importLibrary("addressValidation");
Properties | |
|---|---|
componentName
readonly |
Type:
string optionalThe component name text. For example, "5th Avenue" for a street name or "1253" for a street number, |
componentNameLanguageCode
readonly |
Type:
string optionalThe BCP-47 language code. This will not be present if the component name is not associated with a language, such as a street number. |
componentType
readonly |
Type:
string optionalThe type of the address component. See Table 2: Additional types returned by the Places service for a list of possible types. |
confirmationLevel
readonly |
Type:
ConfirmationLevel optionalIndicates the level of certainty that the component is correct. |
inferred
readonly |
Type:
booleanIf true, this component was not part of the input, but was inferred for the address location. Including this component is recommended for a complete address. |
replaced
readonly |
Type:
booleanIndicates the name of the component was replaced with a completely different one. For example, replacing a wrong postal code being with one that is correct for the address. This is not a cosmetic change; the input component has been changed to a different one. |
spellCorrected
readonly |
Type:
booleanIndicates a correction to a misspelling in the component name. The API does not always flag changes from one spelling variant to another, such as "centre" to "center". |
unexpected
readonly |
Type:
booleanIf true, this component is not expected to be present in a postal address for the given region. It has been retained only because it was part of the input. |
AddressMetadata class
google.maps.addressValidation.AddressMetadata
class
The metadata for the address. AddressMetadata is not guaranteed to be fully populated for every address sent to the Address Validation API.
const {AddressMetadata} = await google.maps.importLibrary("addressValidation");
Properties | |
|---|---|
business
readonly |
Type:
boolean |
poBox
readonly |
Type:
boolean |
residential
readonly |
Type:
boolean |
Methods | |
|---|---|
Inherited:
toJSON
|
ConfirmationLevel constants
google.maps.addressValidation.ConfirmationLevel
constants
The different possible values indicating the level of certainty that the component is correct.
These constants are also usable as strings. In TypeScript, the string literals are defined by the ConfirmationLevelString type.
const {ConfirmationLevel} = await google.maps.importLibrary("addressValidation");
Constants | |
|---|---|
CONFIRMED |
|
UNCONFIRMED_AND_SUSPICIOUS |
|
UNCONFIRMED_BUT_PLAUSIBLE |
|
Geocode class
google.maps.addressValidation.Geocode
class
Contains information about the place the input was geocoded to.
const {Geocode} = await google.maps.importLibrary("addressValidation");
Properties | |
|---|---|
bounds
readonly |
Type:
LatLngBounds optionalThe bounds of the geocoded place. |
featureSizeMeters
readonly |
Type:
number optionalThe size of the geocoded place, in meters. This is another measure of the coarseness of the geocoded location, but in physical size rather than in semantic meaning. |
location
readonly |
Type:
LatLngAltitude optionalThe geocoded location of the input. |
placeId
readonly |
Type:
string optionalThe Place ID of the geocoded place. Using Place is preferred over using addresses, latitude/longitude coordinates, or plus codes. Using coordinates for routing or calculating driving directions will always result in the point being snapped to the road nearest to those coordinates. This may not be a road that will quickly or safely lead to the destination and may not be near an access point to the property. Additionally, when a location is reverse geocoded, there is no guarantee that the returned address will match the original. |
placeTypes
readonly |
Type:
Array<string>The type(s) of place that the input geocoded to. For example, ['locality', 'political']. The full list of types can be found in the Geocoding API documentation. |
plusCode
readonly |
Type:
PlusCode optionalThe plus code corresponding to the location. |
Methods | |
|---|---|
fetchPlace |
fetchPlace()Parameters: None
Return Value: None
Returns a Place representation of this Geocode. To get full place details, a call to place.fetchFields() should be made. |
Inherited:
toJSON
| |
Granularity constants
google.maps.addressValidation.Granularity
constants
The various granularities that an address or a geocode can have. When used to indicate granularity for an address, these values indicate with how fine a granularity the address identifies a mailing destination. For example, an address such as "123 Main Street, Redwood City, CA, 94061" identifies a PREMISE while something like "Redwood City, CA, 94061" identifies a LOCALITY. However, if we are unable to find a geocode for "123 Main Street" in Redwood City, the geocode returned might be of LOCALITY granularity even though the address is more granular.
These constants are also usable as strings. In TypeScript, the string literals are defined by the GranularityString type.
const {Granularity} = await google.maps.importLibrary("addressValidation");
Constants | |
|---|---|
BLOCK |
The address or geocode indicates a block. Only used in regions which have block-level addressing, such as Japan. |
OTHER |
All other granularities, which are bucketed together since they are not deliverable. |
PREMISE |
Building-level result. |
PREMISE_PROXIMITY |
A geocode that approximates the building-level location of the address. |
ROUTE |
The geocode or address is granular to route, such as a street, road, or highway. |
SUB_PREMISE |
Below-building level result, such as an apartment. |
PossibleNextAction constants
google.maps.addressValidation.PossibleNextAction
constants
Offers an interpretive summary of the API response, intended to assist in determining a potential subsequent action to take. This field is derived from other fields in the API response and should not be considered as a guarantee of address accuracy or deliverability.
These constants are also usable as strings. In TypeScript, the string literals are defined by the PossibleNextActionString type.
const {PossibleNextAction} = await google.maps.importLibrary("addressValidation");
Constants | |
|---|---|
ACCEPT |
The API response does not contain signals that warrant one of the other PossibleNextAction values. You might consider using the post-processed address without further prompting your customer, though this does not guarantee the address is valid, and the address might still contain corrections. It is your responsibility to determine if and how to prompt your customer, depending on your own risk assessment. |
CONFIRM |
One or more fields of the API response indicate potential minor issues with the post-processed address, for example the postal_code address component was replaced. Prompting your customer to review the address could help improve the quality of the address. |
CONFIRM_ADD_SUBPREMISES |
The API response indicates the post-processed address might be missing a subpremises. Prompting your customer to review the address and consider adding a unit number could help improve the quality of the address. The post-processed address might also have other minor issues. Note: this enum value can only be returned for US addresses. |
FIX |
One or more fields of the API response indicate a potential issue with the post-processed address, for example the verdict.validation_granularity is OTHER. Prompting your customer to edit the address could help improve the quality of the address. |
USPSAddress class
google.maps.addressValidation.USPSAddress
class
USPS representation of a US address.
const {USPSAddress} = await google.maps.importLibrary("addressValidation");
Properties | |
|---|---|
city
readonly |
Type:
string optionalThe city name. |
cityStateZipAddressLine
readonly |
Type:
string optionalThe address line containing the city, state, and zip code. |
firm
readonly |
Type:
string optionalThe name of the firm. |
firstAddressLine
readonly |
Type:
string optionalThe first line of the address. |
secondAddressLine
readonly |
Type:
string optionalThe second line of the address. |
state
readonly |
Type:
string optionalThe 2-letter state code. |
urbanization
readonly |
Type:
string optionalThe Puerto Rican urbanization name. |
zipCode
readonly |
Type:
string optionalThe Postal code, e.g. "10009". |
zipCodeExtension
readonly |
Type:
string optionalThe 4-digit postal code extension, e.g. "5023". |
Methods | |
|---|---|
Inherited:
toJSON
|
USPSData class
google.maps.addressValidation.USPSData
class
The USPS data for the address. USPSData is not guaranteed to be fully populated for every US or PR address sent to the Address Validation API. It's recommended to integrate the backup address fields in the response if you utilize uspsData as the primary part of the response.
const {USPSData} = await google.maps.importLibrary("addressValidation");
Properties | |
|---|---|
abbreviatedCity
readonly |
Type:
string optionalAbbreviated city. |
addressRecordType
readonly |
Type:
string optionalType of the address record that matches the input address. |
carrierRoute
readonly |
Type:
string optionalThe carrier route code. A four character code consisting of a one letter prefix and a three digit route designator. |
carrierRouteIndicator
readonly |
Type:
string optionalCarrier route rate sort indicator. |
cassProcessed
readonly |
Type:
booleanIndicator that the request has been CASS processed. |
county
readonly |
Type:
string optionalCounty name. |
deliveryPointCheckDigit
readonly |
Type:
string optionalThe delivery point check digit. This number is added to the end of the delivery_point_barcode for mechanically scanned mail. Adding all the digits of the delivery_point_barcode, delivery_point_check_digit, postal code, and ZIP+4 together should yield a number divisible by 10. |
deliveryPointCode
readonly |
Type:
string optionalThe 2-digit delivery point code. |
dpvCMRA
readonly |
Type:
string optionalIndicates if the address is a CMRA (Commercial Mail Receiving Agency)--a private business receiving mail for clients. Returns a single character. |
dpvConfirmation
readonly |
Type:
string optionalThe possible values for DPV confirmation. Returns a single character or returns no value. |
dpvDoorNotAccessible
readonly |
Type:
string optionalFlag indicates addresses where USPS cannot knock on a door to deliver mail. Returns a single character. |
dpvDrop
readonly |
Type:
string optionalFlag indicates mail is delivered to a single receptable at a site. Returns a single character. |
dpvEnhancedDeliveryCode
readonly |
Type:
string optionalIndicates that more than one DPV return code is valid for the address. Returns a single character. |
dpvFootnote
readonly |
Type:
string optionalThe footnotes from delivery point validation. Multiple footnotes may be strung together in the same string. |
dpvNonDeliveryDays
readonly |
Type:
string optionalFlag indicates mail delivery is not performed every day of the week. Returns a single character. |
dpvNonDeliveryDaysValues
readonly |
Type:
number optionalInteger identifying non-delivery days. It can be interrogated using bit flags: 0x40 – Sunday is a non-delivery day 0x20 – Monday is a non-delivery day 0x10 – Tuesday is a non-delivery day 0x08 – Wednesday is a non-delivery day 0x04 – Thursday is a non-delivery day 0x02 – Friday is a non-delivery day 0x01 – Saturday is a non-delivery day |
dpvNoSecureLocation
readonly |
Type:
string optionalFlag indicates door is accessible, but package will not be left due to security concerns. Returns a single character. |
dpvNoStat
readonly |
Type:
string optionalIndicates whether the address is a no stat address or an active address. No stat addresses are ones which are not continuously occupied or addresses that the USPS does not service. Returns a single character. |
dpvNoStatReasonCode
readonly |
Type:
number optionalIndicates the NoStat type. Returns a reason code as int. |
dpvPBSA
readonly |
Type:
string optionalIndicates the address was matched to PBSA record. Returns a single character. |
dpvThrowback
readonly |
Type:
string optionalIndicates that mail is not delivered to the street address. Returns a single character. |
dpvVacant
readonly |
Type:
string optionalIndicates whether the address is vacant. Returns a single character. |
elotFlag
readonly |
Type:
string optionaleLOT Ascending/Descending Flag (A/D). |
elotNumber
readonly |
Type:
string optionalEnhanced Line of Travel (eLOT) number. |
errorMessage
readonly |
Type:
string optionalError message for USPS data retrieval. This is populated when USPS processing is suspended because of the detection of artificially created addresses. |
fipsCountyCode
readonly |
Type:
string optionalFIPS county code. |
hasDefaultAddress
readonly |
Type:
booleanIndicator that a default address was found, but more specific addresses exist. |
hasNoEWSMatch
readonly |
Type:
booleanThe delivery address is matchable, but the EWS file indicates that an exact match will be available soon. |
lacsLinkIndicator
readonly |
Type:
string optionalLACSLink indicator. |
lacsLinkReturnCode
readonly |
Type:
string optionalLACSLink return code. |
pmbDesignator
readonly |
Type:
string optionalPMB (Private Mail Box) unit designator. |
pmbNumber
readonly |
Type:
string optionalPMB (Private Mail Box) number. |
poBoxOnlyPostalCode
readonly |
Type:
booleanPO Box only postal code. |
postOfficeCity
readonly |
Type:
string optionalMain post office city. |
postOfficeState
readonly |
Type:
string optionalMain post office state. |
standardizedAddress
readonly |
Type:
USPSAddress optionalUSPS standardized address. |
suiteLinkFootnote
readonly |
Type:
string optionalFootnotes from matching a street or highrise record to suite information. If business name match is found, the secondary number is returned. |
Methods | |
|---|---|
Inherited:
toJSON
|
Verdict class
google.maps.addressValidation.Verdict
class
Represents the post-processed address for the supplied address.
const {Verdict} = await google.maps.importLibrary("addressValidation");
Properties | |
|---|---|
addressComplete
readonly |
Type:
booleanThe address is considered complete if there are no unresolved tokens, no unexpected or missing address components. If unset, indicates that the value is false. See Address.missingComponentTypes, Address.unresolvedTokens or AddressComponent.unexpected fields for more details. |
geocodeGranularity
readonly |
Type:
Granularity optionalInformation about the granularity of the Geocode. This can be understood as the semantic meaning of how coarse or fine the geocoded location is. |
hasInferredComponents
readonly |
Type:
booleanAt least one address component was inferred (i.e. added) that wasn't in the input, see AddressComponent for details. |
hasReplacedComponents
readonly |
Type:
boolean optionalAt least one address component was replaced - see AddressComponent for details. |
hasUnconfirmedComponents
readonly |
Type:
booleanAt least one address component cannot be categorized or validated, see AddressComponent for details. |
inputGranularity
readonly |
Type:
Granularity optionalThe granularity of the input address. This is the result of parsing the input address and does not give any validation signals. For validation signals, refer to validationGranularity. |
readonly |
Type:
PossibleNextAction optionalA possible next action to take based on other fields in the API response. See PossibleNextAction for details. |
validationGranularity
readonly |
Type:
Granularity optionalThe granularity level that the API can fully validate the address to. For example, a validationGranularity of PREMISE indicates all address components at the level of PREMISE and broader can be validated. |