com.mapbox.api.geocoding.v5.models.GeocodingResponse Maven / Gradle / Ivy
package com.mapbox.api.geocoding.v5.models;
import android.support.annotation.NonNull;
import com.google.auto.value.AutoValue;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.TypeAdapter;
import com.mapbox.geojson.BoundingBox;
import com.mapbox.geojson.FeatureCollection;
import com.mapbox.geojson.Geometry;
import com.mapbox.geojson.Point;
import com.mapbox.geojson.gson.BoundingBoxDeserializer;
import com.mapbox.geojson.gson.BoundingBoxSerializer;
import com.mapbox.geojson.gson.GeometryDeserializer;
import com.mapbox.geojson.gson.GeometryTypeAdapter;
import com.mapbox.geojson.gson.PointDeserializer;
import java.io.Serializable;
import java.util.List;
/**
* This is the initial object which gets returned when the geocoding request receives a result.
* Since each result is a {@link CarmenFeature}, the response simply returns a list of those
* features.
*
* @since 1.0.0
*/
@AutoValue
public abstract class GeocodingResponse implements Serializable {
private static final String TYPE = "FeatureCollection";
/**
* Create a new instance of this class by passing in a formatted valid JSON String.
*
* @param json a formatted valid JSON string defining a GeoJson Geocoding Response
* @return a new instance of this class defined by the values passed inside this static factory
* method
* @since 3.0.0
*/
@NonNull
public static GeocodingResponse fromJson(@NonNull String json) {
Gson gson = new GsonBuilder()
.registerTypeAdapter(Point.class, new PointDeserializer())
.registerTypeAdapter(Geometry.class, new GeometryDeserializer())
.registerTypeAdapter(BoundingBox.class, new BoundingBoxDeserializer())
.registerTypeAdapterFactory(GeocodingAdapterFactory.create())
.create();
return gson.fromJson(json, GeocodingResponse.class);
}
/**
* Create a new instance of this class by using the {@link Builder} class.
*
* @return this classes {@link Builder} for creating a new instance
* @since 3.0.0
*/
@NonNull
public static Builder builder() {
return new AutoValue_GeocodingResponse.Builder()
.type(TYPE);
}
/**
* A geocoding response will always be an extension of a {@link FeatureCollection} containing
* additional information.
*
* @return the type of GeoJSON this is
* @since 1.0.0
*/
@NonNull
public abstract String type();
/**
* A list of space and punctuation-separated strings from the original query.
*
* @return a list containing the original query
* @since 1.0.0
*/
@NonNull
public abstract List query();
/**
* A list of the CarmenFeatures which contain the results and are ordered from most relevant to
* least.
*
* @return a list of {@link CarmenFeature}s which each represent an individual result from the
* query
* @since 1.0.0
*/
@NonNull
public abstract List features();
/**
* A string attributing the results of the Mapbox Geocoding API to Mapbox and links to Mapbox's
* terms of service and data sources.
*
* @return information about Mapbox's terms of service and the data sources
* @since 1.0.0
*/
@NonNull
public abstract String attribution();
/**
* Convert the current {@link GeocodingResponse} to its builder holding the currently assigned
* values. This allows you to modify a single variable and then rebuild the object resulting in
* an updated and modified {@link GeocodingResponse}.
*
* @return a {@link GeocodingResponse.Builder} with the same values set to match the ones defined
* in this {@link GeocodingResponse}
* @since 3.0.0
*/
@NonNull
public abstract Builder toBuilder();
/**
* This takes the currently defined values found inside this instance and converts it to a GeoJson
* string.
*
* @return a JSON string which represents this Geocoding Response
* @since 1.0.0
*/
@NonNull
public String toJson() {
Gson gson = new GsonBuilder()
.registerTypeAdapter(Geometry.class, new GeometryTypeAdapter())
.registerTypeAdapter(BoundingBox.class, new BoundingBoxSerializer())
.registerTypeAdapterFactory(GeocodingAdapterFactory.create())
.create();
return gson.toJson(this, GeocodingResponse.class);
}
/**
* Gson TYPE adapter for parsing Gson t«o this class.
*
* @param gson the built {@link Gson} object
* @return the TYPE adapter for this class
* @since 3.0.0
*/
public static TypeAdapter typeAdapter(Gson gson) {
return new AutoValue_GeocodingResponse.GsonTypeAdapter(gson);
}
/**
* This builder can be used to set the values describing the {@link GeocodingResponse}.
*
* @since 3.0.0
*/
@AutoValue.Builder
@SuppressWarnings("unused")
public abstract static class Builder {
/**
* This describes the TYPE of GeoJson geometry this object is, thus this will always return
* {@link FeatureCollection}. Note that this isn't public since it should always be set to
* "FeatureCollection"
*
* @param type a String which describes the TYPE of geometry, for this object it will always
* return {@code FeatureCollection}
* @return this builder for chaining options together
* @since 3.0.0
*/
abstract Builder type(@NonNull String type);
/**
* A list of space and punctuation-separated strings from the original query.
*
* @param query a list containing the original query
* @return this builder for chaining options together
* @since 3.0.0
*/
public abstract Builder query(@NonNull List query);
/**
* A list of the CarmenFeatures which contain the results and are ordered from most relevant to
* least.
*
* @param features a list of {@link CarmenFeature}s which each represent an individual result
* from the query
* @return this builder for chaining options together
* @since 3.0.0
*/
public abstract Builder features(@NonNull List features);
/**
* A string attributing the results of the Mapbox Geocoding API to Mapbox and links to Mapbox's
* terms of service and data sources.
*
* @param attribution information about Mapbox's terms of service and the data sources
* @return this builder for chaining options together
* @since 1.0.0
*/
public abstract Builder attribution(@NonNull String attribution);
/**
* Build a new {@link GeocodingResponse} object.
*
* @return a new {@link GeocodingResponse} using the provided values in this builder
* @since 3.0.0
*/
public abstract GeocodingResponse build();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy