29 lines
1.5 KiB
PL/PgSQL
29 lines
1.5 KiB
PL/PgSQL
# cdb_conf geocoder config example
|
|
INSERT INTO cdb_conf VALUES ('geocoder_conf', '{"geocoder_db": {"host": "localhost", "port": "5432", db": "cartodb_dev_user_274bf952-8568-4598-9efd-be92ed3d2ead_db", "user": "development_cartodb_user_274bf952-8568-4598-9efd-be92ed3d2ead"}, "redis": {"host": "localhost", "port": 6379, "db": 5 } }')
|
|
|
|
CREATE OR REPLACE FUNCTION cartodb._geocoder_admin0_polygons(search text)
|
|
RETURNS Geometry AS
|
|
$$
|
|
db_connection_str = plpy.execute("SELECT * FROM cartodb._Geocoder_Server_Conf() conf;")[0]['conf']
|
|
return plpy.execute("SELECT cartodb._Geocoder_Admin0_Polygons('{0}', session_user, txid_current(), '{1}') as geom".format(search, db_connection_str))[0]['geom']
|
|
$$ LANGUAGE plpythonu SECURITY DEFINER;
|
|
|
|
CREATE OR REPLACE
|
|
FUNCTION cartodb._geocoder_server_conf()
|
|
RETURNS text AS
|
|
$$
|
|
conf = plpy.execute("SELECT cartodb.CDB_Conf_GetConf('geocoder_conf') conf")[0]['conf']
|
|
if conf is None:
|
|
raise "There is no geocoder server configuration "
|
|
else:
|
|
import json
|
|
params = json.loads(conf)
|
|
db_params = params['geocoder_db']
|
|
return "host={0} port={1} dbname={2} user={3}".format(db_params['host'],db_params['port'],db_params['db'],db_params['user'])
|
|
$$ LANGUAGE 'plpythonu';
|
|
|
|
CREATE OR REPLACE FUNCTION cartodb._geocoder_admin0_polygons(search text, user_id name, tx_id bigint, db_connection_str text)
|
|
RETURNS Geometry AS $$
|
|
CONNECT db_connection_str;
|
|
SELECT geocode_admin0(search, tx_id, user_id);
|
|
$$ LANGUAGE plproxy; |