All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.mapbox.api.matching.v5.MatchingResponseFactory Maven / Gradle / Ivy

package com.mapbox.api.matching.v5;

import com.mapbox.api.directions.v5.models.RouteOptions;
import com.mapbox.api.directions.v5.utils.ParseUtils;
import com.mapbox.api.matching.v5.models.MapMatchingMatching;
import com.mapbox.api.matching.v5.models.MapMatchingResponse;
import com.mapbox.geojson.Point;

import java.util.ArrayList;
import java.util.List;

import retrofit2.Response;

/**
 * @since 4.4.0
 */
class MatchingResponseFactory {

  private static final String PLACEHOLDER_UUID = "mapmatching";
  private final MapboxMapMatching mapboxMapMatching;

  MatchingResponseFactory(MapboxMapMatching mapboxMapMatching) {
    this.mapboxMapMatching = mapboxMapMatching;
  }

  Response generate(Response response) {
    if (isNotSuccessful(response)) {
      return response;
    } else {
      return Response.success(
        response
          .body()
          .toBuilder()
          .matchings(generateRouteOptions(response))
          .build(),
        new okhttp3.Response.Builder()
          .code(200)
          .message("OK")
          .protocol(response.raw().protocol())
          .headers(response.headers())
          .request(response.raw().request())
          .build());
    }
  }

  private boolean isNotSuccessful(Response response) {
    return !response.isSuccessful()
      || response.body() == null
      || response.body().matchings() == null
      || response.body().matchings().isEmpty();
  }

  private List generateRouteOptions(Response response) {
    List matchings = response.body().matchings();
    List modifiedMatchings = new ArrayList<>();
    for (MapMatchingMatching matching : matchings) {
      modifiedMatchings.add(matching.toBuilder().routeOptions(
        RouteOptions.builder()
          .profile(mapboxMapMatching.profile())
          .coordinates(formatCoordinates(mapboxMapMatching.coordinates()))
          .annotations(mapboxMapMatching.annotations())
          .approachesList(ParseUtils.parseToStrings(mapboxMapMatching.approaches()))
          .language(mapboxMapMatching.language())
          .radiusesList(ParseUtils.parseToDoubles(mapboxMapMatching.radiuses()))
          .user(mapboxMapMatching.user())
          .voiceInstructions(mapboxMapMatching.voiceInstructions())
          .bannerInstructions(mapboxMapMatching.bannerInstructions())
          .roundaboutExits(mapboxMapMatching.roundaboutExits())
          .geometries(mapboxMapMatching.geometries())
          .overview(mapboxMapMatching.overview())
          .steps(mapboxMapMatching.steps())
          .voiceUnits(mapboxMapMatching.voiceUnits())
          .requestUuid(PLACEHOLDER_UUID)
          .accessToken(mapboxMapMatching.accessToken())
          .waypointIndicesList(ParseUtils.parseToIntegers(mapboxMapMatching.waypointIndices()))
          .waypointNamesList(ParseUtils.parseToStrings(mapboxMapMatching.waypointNames()))
          .baseUrl(mapboxMapMatching.baseUrl())
          .build()
      ).build());
    }
    return modifiedMatchings;
  }

  private static List formatCoordinates(String coordinates) {
    String[] coordPairs = coordinates.split(";", -1);
    List coordinatesFormatted = new ArrayList<>();
    for (String coordPair : coordPairs) {
      String[] coords = coordPair.split(",", -1);
      coordinatesFormatted.add(
        Point.fromLngLat(Double.valueOf(coords[0]), Double.valueOf(coords[1])));

    }
    return coordinatesFormatted;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy