Merge pull request #103 from OpenSprinkler/reduce-geocoding-usage
Cache invalid locations
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
import fs = require("fs");
|
||||
|
||||
import { GeoCoordinates } from "../../types";
|
||||
import { CodedError, ErrorCode } from "../../errors";
|
||||
|
||||
export abstract class Geocoder {
|
||||
|
||||
@@ -39,11 +40,26 @@ export abstract class Geocoder {
|
||||
*/
|
||||
public async getLocation( location: string ): Promise<GeoCoordinates> {
|
||||
if ( this.cache.has( location ) ) {
|
||||
return this.cache.get( location );
|
||||
const coords: GeoCoordinates = this.cache.get( location );
|
||||
if ( coords == null ) {
|
||||
// Throw an error if there are no results for this location.
|
||||
throw new CodedError( ErrorCode.NoLocationFound );
|
||||
} else {
|
||||
return coords;
|
||||
}
|
||||
}
|
||||
|
||||
try {
|
||||
const coords: GeoCoordinates = await this.geocodeLocation( location );
|
||||
this.cache.set( location, coords );
|
||||
return coords;
|
||||
} catch ( ex ) {
|
||||
if ( ex instanceof CodedError && ex.errCode == ErrorCode.NoLocationFound ) {
|
||||
// Store in the cache the fact that this location has no results.
|
||||
this.cache.set( location, null );
|
||||
}
|
||||
|
||||
throw ex;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -27,7 +27,6 @@ export default class GoogleMaps extends Geocoder {
|
||||
}
|
||||
|
||||
if ( !data.results.length ) {
|
||||
console.log( `No results found for location "${ location }"` );
|
||||
throw new CodedError( ErrorCode.NoLocationFound );
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user