com.smartystreets.api.us_street.Lookup Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of smartystreets-java-sdk Show documentation
Show all versions of smartystreets-java-sdk Show documentation
A library to help Java developers easily access the SmartyStreets APIs.
package com.smartystreets.api.us_street;
import com.fasterxml.jackson.annotation.JsonProperty;
import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
/**
* In addition to holding all of the input data for this lookup, this class also
* will contain the result of the lookup after it comes back from the API.
* @see "https://smartystreets.com/docs/cloud/us-street-api#input-fields"
*/
public class Lookup implements Serializable {
//region [ Fields ]
private List result;
private String inputId;
private String street;
private String street2;
private String secondary;
private String city;
private String state;
private String zipCode;
private String lastline;
private String addressee;
private String urbanization;
private String match;
private String format;
private int candidates;
//This is a temporary flag meant to fix an intermittent data issue
//Unless explicitly instructed by the Smarty Tech Support team, DO NOT use this parameter
private String compatibility;
//endregion
//region [ Constructors ]
public Lookup() {
this.candidates = 1;
this.result = new ArrayList<>();
}
/**
* This constructor accepts a freeform address. That means the whole address is in one string.
* @param freeformAddress
*/
public Lookup(String freeformAddress) {
this();
this.street = freeformAddress;
}
//endregion
//region [ Methods ]
void addToResult(Candidate newCandidate) {
this.result.add(newCandidate);
}
//endregion
//region [ Getters ]
@JsonProperty("result")
public List getResult() {
return this.result;
}
public Candidate getResult(int index) {
return this.result.get(index);
}
@JsonProperty("input_id")
public String getInputId() {
return this.inputId;
}
@JsonProperty("street")
public String getStreet() {
return this.street;
}
@JsonProperty("street2")
public String getStreet2() {
return this.street2;
}
@JsonProperty("secondary")
public String getSecondary() {
return this.secondary;
}
@JsonProperty("city")
public String getCity() {
return this.city;
}
@JsonProperty("state")
public String getState() {
return this.state;
}
@JsonProperty("zipcode")
public String getZipCode() {
return this.zipCode;
}
@JsonProperty("lastline")
public String getLastline() {
return this.lastline;
}
@JsonProperty("addressee")
public String getAddressee() {
return this.addressee;
}
@JsonProperty("urbanization")
public String getUrbanization() {
return this.urbanization;
}
@JsonProperty("match")
public String getMatch() {
if (this.match == null)
return null;
if (this.match.equals("strict") )
return "strict";
if (this.match.equals("invalid") )
return "invalid";
if (this.match.equals("enhanced") )
return "enhanced";
return null;
}
@JsonProperty("compatibility")
public String getCompatibility() {
//This is a temporary flag meant to fix an intermittent data issue
//Unless explicitly instructed by the Smarty Tech Support team, DO NOT use this parameter
return this.compatibility;
}
@JsonProperty("format")
public String getFormat(){
if (this.format == null)
return null;
if (this.format.equals("default"))
return "default";
if (this.format.equals("project-usa"))
return "project-usa";
return null;
}
@JsonProperty("candidates")
public int getMaxCandidates() {
return this.candidates;
}
//endregion
//region [ Setters ]
public void setResult(List result) {
this.result = result;
}
public Lookup setInputId(String inputId) {
this.inputId = inputId;
return this;
}
/**
* You can optionally put the entire address in the street field,
* and leave the other fields blank. We call this a freeform address.
* Note: Freeform addresses are slightly less reliable.
*
* @param street If using a freeform address, do not include country information
*/
public void setStreet(String street) {
this.street = street;
}
public void setStreet2(String street2) {
this.street2 = street2;
}
public void setSecondary(String secondary) {
this.secondary = secondary;
}
public void setCity(String city) {
this.city = city;
}
public void setState(String state) {
this.state = state;
}
public void setZipCode(String zipCode) {
this.zipCode = zipCode;
}
public void setLastline(String lastline) {
this.lastline = lastline;
}
public void setAddressee(String addressee) {
this.addressee = addressee;
}
public void setUrbanization(String urbanization) {
this.urbanization = urbanization;
}
public void setCompatibility(String compatibility) {
//This is a temporary flag meant to fix an intermittent data issue
//Unless explicitly instructed by the Smarty Tech Support team, DO NOT use this parameter
this.compatibility = compatibility;
}
/**
* Sets the match output strategy to be employed for this lookup.
*
* @see "https://smartystreets.com/docs/cloud/us-street-api#input-fields"
* @param match The match output strategy
*/
public void setMatch(MatchType match) {
this.match = match.getName();
}
/**
* Sets the format output for this lookup
* @param format The format output
*/
public void setFormat(OutputFormat format) {
this.format = format.getName();
}
/**
* Sets the maximum number of valid addresses returned when the input is ambiguous.
* @param candidates Defaults to 1. Must be an integer between 1 and 10, inclusive.
* @throws IllegalArgumentException
*/
public void setMaxCandidates(int candidates) throws IllegalArgumentException {
if (candidates > 0) {
this.candidates = candidates;
} else {
throw new IllegalArgumentException("Max candidates must be a positive integer.");
}
}
//endregion
}