From 53bd388a655579803f3a46dcbe856100274a3a8b Mon Sep 17 00:00:00 2001 From: Mike Bryant Date: Wed, 6 Mar 2024 09:20:18 +0000 Subject: [PATCH] More robustness for AWS Geocoder --- .../geocoding/AwsGeocodingService.scala | 41 +++++++++++-------- 1 file changed, 25 insertions(+), 16 deletions(-) diff --git a/modules/portal/app/services/geocoding/AwsGeocodingService.scala b/modules/portal/app/services/geocoding/AwsGeocodingService.scala index d24d6c5b0..8e2852a8c 100644 --- a/modules/portal/app/services/geocoding/AwsGeocodingService.scala +++ b/modules/portal/app/services/geocoding/AwsGeocodingService.scala @@ -17,7 +17,6 @@ object AwsGeocodingService { val credentials = StaticCredentialsProvider.create(new AwsCredentials { override def accessKeyId(): String = config.getString("config.aws.credentials.access-key-id") - override def secretAccessKey(): String = config.getString("config.aws.credentials.secret-access-key") }) val region: AwsRegionProvider = new AwsRegionProvider { @@ -36,7 +35,19 @@ case class AwsGeocodingService @Inject()(credentials: AwsCredentialsProvider, re private val logger = play.api.Logger(classOf[AwsGeocodingService]) - override def geocode(address: AddressF): Future[Option[Point]] = { + override def geocode(address: AddressF): Future[Option[Point]] = Future { + if (address.postalAddress.trim.nonEmpty && address.countryCode3.nonEmpty) { + try runLocationGeocode(address) catch { + case e: Exception => + logger.error(s"Error geocoding address: $address", e) + None + } + } else { + None + } + } + + private def runLocationGeocode(address: AddressF): Option[Point] = { val client: LocationClient = LocationClient .builder() .credentialsProvider(credentials) @@ -50,19 +61,17 @@ case class AwsGeocodingService @Inject()(credentials: AwsCredentialsProvider, re .maxResults(1) .build() - Future { - client.searchPlaceIndexForText(request) - .results() - .asScala - .headOption - .map { result => - logger.debug(s"Geocoding result: $result, point: ${result.place().geometry().point()}") - val lonLat = result.place().geometry().point() - Point( - BigDecimal(lonLat.get(1)), - BigDecimal(lonLat.get(0)) - ) - } - } + client.searchPlaceIndexForText(request) + .results() + .asScala + .headOption + .map { result => + logger.debug(s"Geocoding result: $result, point: ${result.place().geometry().point()}") + val lonLat = result.place().geometry().point() + Point( + BigDecimal(lonLat.get(1)), + BigDecimal(lonLat.get(0)) + ) + } } }