2020-01-14 20:33:33 +08:00
|
|
|
--DO NOT MODIFY THIS FILE, IT IS GENERATED AUTOMATICALLY FROM SOURCES
|
|
|
|
-- Complain if script is sourced in psql, rather than via CREATE EXTENSION
|
|
|
|
\echo Use "ALTER EXTENSION cdb_dataservices_server UPDATE TO '0.36.0'" to load this file. \quit
|
|
|
|
|
|
|
|
CREATE OR REPLACE FUNCTION cdb_dataservices_server.cdb_geocode_street_point(username TEXT, orgname TEXT, searchtext TEXT, city TEXT DEFAULT NULL, state_province TEXT DEFAULT NULL, country TEXT DEFAULT NULL)
|
|
|
|
RETURNS Geometry AS $$
|
|
|
|
from cartodb_services.metrics import metrics
|
|
|
|
from cartodb_services.tools import Logger,LoggerConfig
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._connect_to_redis('{0}')".format(username))
|
|
|
|
redis_conn = GD["redis_connection_{0}".format(username)]['redis_metrics_connection']
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._get_geocoder_config({0}, {1})".format(plpy.quote_nullable(username), plpy.quote_nullable(orgname)))
|
|
|
|
user_geocoder_config = GD["user_geocoder_config_{0}".format(username)]
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._get_logger_config()")
|
|
|
|
logger_config = GD["logger_config"]
|
|
|
|
logger = Logger(logger_config)
|
|
|
|
|
|
|
|
params = {'username': username, 'orgname': orgname, 'searchtext': searchtext, 'city': city, 'state_province': state_province, 'country': country}
|
|
|
|
|
|
|
|
with metrics('cdb_geocode_street_point', user_geocoder_config, logger, params):
|
|
|
|
if user_geocoder_config.heremaps_geocoder:
|
|
|
|
here_plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_here_geocode_street_point($1, $2, $3, $4, $5, $6) as point; ", ["text", "text", "text", "text", "text", "text"])
|
|
|
|
return plpy.execute(here_plan, [username, orgname, searchtext, city, state_province, country], 1)[0]['point']
|
|
|
|
elif user_geocoder_config.google_geocoder:
|
|
|
|
google_plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_google_geocode_street_point($1, $2, $3, $4, $5, $6) as point; ", ["text", "text", "text", "text", "text", "text"])
|
|
|
|
return plpy.execute(google_plan, [username, orgname, searchtext, city, state_province, country], 1)[0]['point']
|
|
|
|
elif user_geocoder_config.mapzen_geocoder:
|
|
|
|
mapzen_plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_mapzen_geocode_street_point($1, $2, $3, $4, $5, $6) as point; ", ["text", "text", "text", "text", "text", "text"])
|
|
|
|
return plpy.execute(mapzen_plan, [username, orgname, searchtext, city, state_province, country], 1)[0]['point']
|
|
|
|
elif user_geocoder_config.mapbox_geocoder:
|
|
|
|
mapbox_plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_mapbox_geocode_street_point($1, $2, $3, $4, $5, $6) as point; ", ["text", "text", "text", "text", "text", "text"])
|
|
|
|
return plpy.execute(mapbox_plan, [username, orgname, searchtext, city, state_province, country], 1)[0]['point']
|
|
|
|
elif user_geocoder_config.tomtom_geocoder:
|
|
|
|
tomtom_plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_tomtom_geocode_street_point($1, $2, $3, $4, $5, $6) as point; ", ["text", "text", "text", "text", "text", "text"])
|
|
|
|
return plpy.execute(tomtom_plan, [username, orgname, searchtext, city, state_province, country], 1)[0]['point']
|
|
|
|
elif user_geocoder_config.geocodio_geocoder:
|
|
|
|
geocodio_plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_geocodio_geocode_street_point($1, $2, $3, $4, $5, $6) as point; ", ["text", "text", "text", "text", "text", "text"])
|
|
|
|
return plpy.execute(geocodio_plan, [username, orgname, searchtext, city, state_province, country], 1)[0]['point']
|
|
|
|
else:
|
|
|
|
raise Exception('Requested geocoder is not available')
|
|
|
|
|
2020-03-10 22:45:04 +08:00
|
|
|
$$ LANGUAGE @@plpythonu@@ STABLE PARALLEL RESTRICTED;
|
2020-01-14 20:33:33 +08:00
|
|
|
|
|
|
|
|
|
|
|
CREATE OR REPLACE FUNCTION cdb_dataservices_server.cdb_geocodio_geocode_street_point(username TEXT, orgname TEXT, searchtext TEXT, city TEXT DEFAULT NULL, state_province TEXT DEFAULT NULL, country TEXT DEFAULT NULL)
|
|
|
|
RETURNS Geometry AS $$
|
|
|
|
# The configuration is retrieved but no checks are performed on it
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._connect_to_redis('{0}')".format(username))
|
|
|
|
redis_conn = GD["redis_connection_{0}".format(username)]['redis_metrics_connection']
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._get_geocoder_config({0}, {1})".format(plpy.quote_nullable(username), plpy.quote_nullable(orgname)))
|
|
|
|
user_geocoder_config = GD["user_geocoder_config_{0}".format(username)]
|
|
|
|
|
|
|
|
geocodio_plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_geocodio_geocode_street_point($1, $2, $3, $4, $5, $6) as point; ", ["text", "text", "text", "text", "text", "text"])
|
|
|
|
return plpy.execute(geocodio_plan, [username, orgname, searchtext, city, state_province, country], 1)[0]['point']
|
|
|
|
|
2020-03-10 22:45:04 +08:00
|
|
|
$$ LANGUAGE @@plpythonu@@ STABLE PARALLEL RESTRICTED;
|
2020-01-14 20:33:33 +08:00
|
|
|
|
|
|
|
|
|
|
|
CREATE OR REPLACE FUNCTION cdb_dataservices_server._cdb_geocodio_geocode_street_point(username TEXT, orgname TEXT, searchtext TEXT, city TEXT DEFAULT NULL, state_province TEXT DEFAULT NULL, country TEXT DEFAULT NULL)
|
|
|
|
RETURNS Geometry AS $$
|
|
|
|
from iso3166 import countries
|
|
|
|
from cartodb_services.tools import ServiceManager, QuotaExceededException
|
|
|
|
from cartodb_services.geocodio import GeocodioGeocoder
|
|
|
|
from cartodb_services.tools.country import country_to_iso3
|
|
|
|
from cartodb_services.refactor.service.geocodio_geocoder_config import GeocodioGeocoderConfigBuilder
|
|
|
|
|
|
|
|
import cartodb_services
|
|
|
|
cartodb_services.init(plpy, GD)
|
|
|
|
|
|
|
|
service_manager = ServiceManager('geocoder', GeocodioGeocoderConfigBuilder, username, orgname, GD)
|
|
|
|
|
|
|
|
try:
|
|
|
|
service_manager.assert_within_limits()
|
|
|
|
geocoder = GeocodioGeocoder(service_manager.config.geocodio_api_key, service_manager.logger, service_manager.config.service_params)
|
|
|
|
|
|
|
|
country_iso3166 = None
|
|
|
|
if country:
|
|
|
|
country_iso3 = country_to_iso3(country)
|
|
|
|
if country_iso3:
|
|
|
|
country_iso3166 = countries.get(country_iso3).alpha2.lower()
|
|
|
|
|
|
|
|
coordinates = geocoder.geocode(searchtext=searchtext, city=city,
|
|
|
|
state_province=state_province,
|
|
|
|
country=country_iso3166)
|
|
|
|
|
|
|
|
if coordinates:
|
|
|
|
service_manager.quota_service.increment_success_service_use()
|
|
|
|
plan = plpy.prepare("SELECT ST_SetSRID(ST_MakePoint($1, $2), 4326); ", ["double precision", "double precision"])
|
|
|
|
point = plpy.execute(plan, [coordinates[0], coordinates[1]], 1)[0]
|
|
|
|
return point['st_setsrid']
|
|
|
|
else:
|
|
|
|
service_manager.quota_service.increment_empty_service_use()
|
|
|
|
return None
|
|
|
|
except QuotaExceededException as qe:
|
|
|
|
service_manager.quota_service.increment_failed_service_use()
|
|
|
|
return None
|
|
|
|
except BaseException as e:
|
|
|
|
import sys
|
|
|
|
service_manager.quota_service.increment_failed_service_use()
|
|
|
|
service_manager.logger.error('Error trying to geocode street point using Geocodio', sys.exc_info(), data={"username": username, "orgname": orgname})
|
|
|
|
raise Exception('Error trying to geocode street point using Geocodio')
|
|
|
|
finally:
|
|
|
|
service_manager.quota_service.increment_total_service_use()
|
2020-03-10 22:45:04 +08:00
|
|
|
$$ LANGUAGE @@plpythonu@@ STABLE PARALLEL RESTRICTED;
|
2020-01-14 20:33:33 +08:00
|
|
|
|
|
|
|
|
|
|
|
CREATE OR REPLACE FUNCTION cdb_dataservices_server._cdb_bulk_geocode_street_point(username TEXT, orgname TEXT, searches jsonb)
|
|
|
|
RETURNS SETOF cdb_dataservices_server.geocoding AS $$
|
|
|
|
from cartodb_services.metrics import metrics
|
|
|
|
from cartodb_services.tools import Logger
|
|
|
|
import json
|
|
|
|
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._connect_to_redis('{0}')".format(username))
|
|
|
|
redis_conn = GD["redis_connection_{0}".format(username)]['redis_metrics_connection']
|
|
|
|
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._get_geocoder_config({0}, {1})".format(plpy.quote_nullable(username), plpy.quote_nullable(orgname)))
|
|
|
|
user_geocoder_config = GD["user_geocoder_config_{0}".format(username)]
|
|
|
|
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._get_logger_config()")
|
|
|
|
logger_config = GD["logger_config"]
|
|
|
|
logger = Logger(logger_config)
|
|
|
|
|
|
|
|
params = {'username': username, 'orgname': orgname, 'searches': json.loads(searches)}
|
|
|
|
|
|
|
|
with metrics('cdb_bulk_geocode_street_point', user_geocoder_config, logger, params):
|
|
|
|
if user_geocoder_config.google_geocoder:
|
|
|
|
provider_function = "_cdb_bulk_google_geocode_street_point";
|
|
|
|
elif user_geocoder_config.heremaps_geocoder:
|
|
|
|
provider_function = "_cdb_bulk_heremaps_geocode_street_point";
|
|
|
|
elif user_geocoder_config.tomtom_geocoder:
|
|
|
|
provider_function = "_cdb_bulk_tomtom_geocode_street_point";
|
|
|
|
elif user_geocoder_config.mapbox_geocoder:
|
|
|
|
provider_function = "_cdb_bulk_mapbox_geocode_street_point";
|
|
|
|
elif user_geocoder_config.geocodio_geocoder:
|
|
|
|
provider_function = "_cdb_bulk_geocodio_geocode_street_point";
|
|
|
|
else:
|
|
|
|
raise Exception('Requested geocoder is not available')
|
|
|
|
|
|
|
|
plan = plpy.prepare("SELECT * FROM cdb_dataservices_server.{}($1, $2, $3); ".format(provider_function), ["text", "text", "jsonb"])
|
|
|
|
return plpy.execute(plan, [username, orgname, searches])
|
|
|
|
|
2020-03-10 22:45:04 +08:00
|
|
|
$$ LANGUAGE @@plpythonu@@ STABLE PARALLEL RESTRICTED;
|
2020-01-14 20:33:33 +08:00
|
|
|
|
|
|
|
|
|
|
|
CREATE OR REPLACE FUNCTION cdb_dataservices_server._cdb_bulk_geocodio_geocode_street_point(username TEXT, orgname TEXT, searches jsonb)
|
|
|
|
RETURNS SETOF cdb_dataservices_server.geocoding AS $$
|
|
|
|
from cartodb_services import run_street_point_geocoder
|
|
|
|
from cartodb_services.tools import ServiceManager
|
|
|
|
from cartodb_services.refactor.service.geocodio_geocoder_config import GeocodioGeocoderConfigBuilder
|
|
|
|
from cartodb_services.geocodio import GeocodioBulkGeocoder
|
|
|
|
from cartodb_services.tools import Logger
|
|
|
|
import cartodb_services
|
|
|
|
cartodb_services.init(plpy, GD)
|
|
|
|
|
|
|
|
logger_config = GD["logger_config"]
|
|
|
|
logger = Logger(logger_config)
|
|
|
|
service_manager = ServiceManager('geocoder', GeocodioGeocoderConfigBuilder, username, orgname, GD)
|
|
|
|
geocoder = GeocodioBulkGeocoder(service_manager.config.geocodio_api_key, service_manager.logger, service_manager.config.service_params)
|
|
|
|
return run_street_point_geocoder(plpy, GD, geocoder, service_manager, username, orgname, searches)
|
2020-03-10 22:45:04 +08:00
|
|
|
$$ LANGUAGE @@plpythonu@@ STABLE PARALLEL RESTRICTED;
|
2020-01-14 20:33:33 +08:00
|
|
|
CREATE OR REPLACE FUNCTION cdb_dataservices_server.cdb_geocode_admin0_polygon(username text, orgname text, country_name text)
|
|
|
|
RETURNS Geometry AS $$
|
|
|
|
from cartodb_services.metrics import QuotaService
|
|
|
|
from cartodb_services.metrics import InternalGeocoderConfig
|
|
|
|
from cartodb_services.metrics import metrics
|
|
|
|
from cartodb_services.tools import Logger,LoggerConfig
|
|
|
|
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._connect_to_redis('{0}')".format(username))
|
|
|
|
redis_conn = GD["redis_connection_{0}".format(username)]['redis_metrics_connection']
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._get_internal_geocoder_config({0}, {1})".format(plpy.quote_nullable(username), plpy.quote_nullable(orgname)))
|
|
|
|
user_geocoder_config = GD["user_internal_geocoder_config_{0}".format(username)]
|
|
|
|
|
|
|
|
plpy.execute("SELECT cdb_dataservices_server._get_logger_config()")
|
|
|
|
logger_config = GD["logger_config"]
|
|
|
|
logger = Logger(logger_config)
|
|
|
|
quota_service = QuotaService(user_geocoder_config, redis_conn)
|
|
|
|
|
|
|
|
params = {'username': username, 'orgname': orgname, 'country_name': country_name}
|
|
|
|
|
|
|
|
with metrics('cdb_geocode_admin0_polygon', user_geocoder_config, logger, params):
|
|
|
|
try:
|
|
|
|
plan = plpy.prepare("SELECT cdb_dataservices_server._cdb_geocode_admin0_polygon(trim($1)) AS mypolygon", ["text"])
|
|
|
|
rv = plpy.execute(plan, [country_name], 1)
|
|
|
|
result = rv[0]["mypolygon"]
|
|
|
|
if result:
|
|
|
|
quota_service.increment_success_service_use()
|
|
|
|
return result
|
|
|
|
else:
|
|
|
|
quota_service.increment_empty_service_use()
|
|
|
|
return None
|
|
|
|
except BaseException as e:
|
|
|
|
import sys
|
|
|
|
quota_service.increment_failed_service_use()
|
|
|
|
logger.error('Error trying to geocode admin0 polygon', sys.exc_info(), data={"username": username, "orgname": orgname})
|
|
|
|
raise Exception('Error trying to geocode admin0 polygon')
|
|
|
|
finally:
|
|
|
|
quota_service.increment_total_service_use()
|
2020-03-10 22:45:04 +08:00
|
|
|
$$ LANGUAGE @@plpythonu@@ STABLE PARALLEL RESTRICTED;
|