nominatim_fdw

This Release
nominatim_fdw 1.0.0
Date
Status
Stable
Abstract
Nominatim Foreign Data Wrapper for PostgreSQL
Description
A PostgreSQL Foreign Data Wrapper to access data from Nominatim servers using simple function calls.
Released By
jim
License
MIT
Resources
Special Files
Tags

Extensions

nominatim_fdw 1.0.0
Nominatim Foreign Data Wrapper for PostgreSQL

README


Nominatim Foreign Data Wrapper for PostgreSQL (nominatim_fdw)

The nominatim_fdw is a PostgreSQL Foreign Data Wrapper to access data from Nominatim servers using simple function calls.

CI

Index

Requirements

Build and Install

To compile the source code you need to ensure the pg_config executable is properly set when you run make - this executable is typically in your PostgreSQL installation's bin directory. After that, just run make in the root directory:

bash $ cd nominatim_fdw $ make

After compilation, just run make install to install the Foreign Data Wrapper:

bash $ make install

After building and installing the extension you're ready to create the extension in a PostgreSQL database with CREATE EXTENSION:

sql CREATE EXTENSION nominatim_fdw;

To install an specific version add the full version number in the WITH VERSION clause

sql CREATE EXTENSION nominatim_fdw WITH VERSION '1.0';

To run the predefined regression tests run make installcheck with the user postgres:

bash $ make PGUSER=postgres installcheck

Update

To update the extension's version you must first build and install the binaries and then run ALTER EXTENSION:

sql ALTER EXTENSION nominatim_fdw UPDATE;

To update to an specific version use UPDATE TO and the full version number

sql ALTER EXTENSION nominatim_fdw UPDATE TO '1.1';

Usage

To use the nominatim_fdw you must first create a SERVER to connect to a Nominatim endpoint. After that, you can retrieve the data using the nominatim_fdw functions.

CREATE SERVER

The SQL command CREATE SERVER defines a new foreign server, which in this case means a Nominatim server. The user who defines the server becomes its owner. A SERVER requires an url, so that nominatim_fdw knows where to sent the requests.

The following example creates a SERVER that connects to the OpenStreetMap Nominatim Server:

sql CREATE SERVER osm FOREIGN DATA WRAPPER nominatim_fdw OPTIONS (url 'https://nominatim.openstreetmap.org');

Server Options

| Server Option | Type | Description | |---------------|----------------------|--------------------------------------------------------------------------------------------------------------------| | url | required | URL address of the Nominatim endpoint. | http_proxy | optional | Proxy for HTTP requests. | proxy_user | optional | User for proxy server authentication. | proxy_user_password | optional | Password for proxy server authentication. | connect_timeout | optional | Connection timeout for HTTP requests in seconds (default 300 seconds). | max_connect_retry | optional | Number of attempts to retry a request in case of failure (default 3 times). | max_request_redirect | optional | Limit of how many times the URL redirection may occur. If that many redirections have been followed, the next redirect will cause an error. Not setting this parameter or setting it to 0 will allow an infinite number of redirects.

ALTER SERVER

All options and parameters set to a SERVER can be changed, dropped, and new ones can be added using ALTER SERVER statements.

Adding options

sql ALTER SERVER osm OPTIONS (ADD max_connect_rety '5');

Changing previously configured options

sql ALTER SERVER osm OPTIONS (SET url 'https://a.new.url');

Dropping options

sql ALTER SERVER osm OPTIONS (DROP http_proxy);

Functions

This section describes the nominatim_fdw functions, which are mapped to the Nominatim standard search endpoints search, reverse and lookup.

Nominatim_Search

Description

The search API allows you to look up a location from a textual description or address. Just like the Nominatim API, the foreign data wrapper supports structured and free-form search queries, which are distinguished by either spliting the address components into different paramenteres, such as street, county, state, or providing a single string in the parameter q.

Availability: 1.0.0

Synopsis

SETOF Record nominatim_search(parameters)

Parameters

| Parameter | Type | Description | |---|---|---| | server_name | required | Foreign Data Wrapper server created using the CREATE SERVER statement. | | q | optional | Free-form query string to search for (default unset) | | amenity | optional | name and/or type of POI (default unset) | | street | optional | housenumber and streetname (default unset) | | city | optional | city (default unset) | | county | optional | county (default unset) | | state | optional | state (default unset) | | country | optional | country (default unset) | | postalcode | optional | postal code (default unset) | | limit | optional | limits the maximum number of returned results (default 10) | | addressdetails | optional | includes a breakdown of the address into elements (default false) | | extratags | optional | additional information in the result that is available in the database, e.g. wikipedia link, opening hours. (default false) | | namedetails | optional | include a full list of names for the result. (default false) | | accept_language | optional | language string as in "Accept-Language" HTTP header (default en_US). This overrides the accept_language set in the CREATE SERVER statement | | countrycodes | optional | comma-separated list of country codes (default unset) | | layer | optional | comma-separated list of: address, poi, railway, natural, manmade (default unset) | | featureType | optional | one of: country, state, city, settlement (default unset) | | exclude_place_ids | optional | comma-separeted list of place ids (default unset) | | viewbox | optional | bounding box as in <x1>,<y1>,<x2>,<y2> (default unset) | | bounded | optional | When bounded is set to true and the viewbox is small enough, then an amenity-only search is allowed. Give the special keyword for the amenity in square brackets, e.g. [pub] and a selection of objects of this type is returned. There is no guarantee that the result returns all objects in the area. (default false) | | polygon_type | optional | one of: polygon_geojson, polygon_kml, polygon_svg, polygon_text (default *unset*) | |polygon_treshold| optional | floating-point number (default0.0) | |email| optional | valid email address (default *unset*) | |dedupe| optional | discards duplicated entries (defaulttrue`) |

As in the Nominatim API, the free-form query string parameter q cannot be combined with the parameters amenity, street, city, county, state, country and `postalcode, as they are used in structured calls.


Usage

For these examples we assume the following SERVER:

sql CREATE SERVER osm FOREIGN DATA WRAPPER nominatim_fdw OPTIONS (url 'https://nominatim.openstreetmap.org');

Free-form search

```sql SELECT osm_id, ref, lon, lat, boundingbox FROM nominatim_search(server_name => 'osm', q => 'Neubrückenstraße 63, münster, germany');

osm_id | ref | lon | lat | boundingbox
-----------+-----------------+-----------+------------+------------------------------------------- 121736959 | Theater Münster | 7.6293918 | 51.9648162 | 51.9644060,51.9652417,7.6286897,7.6304381 (1 row) ```

Structured search

```sql SELECT osm_id, ref, lon, lat, boundingbox FROM nominatim_search(server_name => 'osm', street => 'neubrückenstraße 63', city => 'münster');

osm_id | ref | lon | lat | boundingbox
-----------+-----------------+-----------+------------+------------------------------------------- 121736959 | Theater Münster | 7.6293918 | 51.9648162 | 51.9644060,51.9652417,7.6286897,7.6304381 (1 row) `` Strcutured search withextratags`

```sql SELECT osm_id, ref, lon, lat, jsonb_pretty(extratags) AS extratags FROM nominatim_search(server_name => 'osm', street => 'neubrückenstraße 63', city => 'münster', extratags => true); osm_id | ref | lon | lat | extratags
-----------+-----------------+-----------+------------+-------------------------------------------------------------------------------------------------------- 121736959 | Theater Münster | 7.6293918 | 51.9648162 | { + | | | | "image": "https://upload.wikimedia.org/wikipedia/commons/6/64/Muenster_Stadttheater_%2881%29.JPG",+ | | | | "layer": "-1", + | | | | "toilets": "customers", + | | | | "building": "civic", + | | | | "location": "surface", + | | | | "wikidata": "Q2415904", + | | | | "wikipedia": "de:Theater Münster", + | | | | "roof:shape": "flat", + | | | | "start_date": "1956", + | | | | "wheelchair": "yes", + | | | | "contact:fax": "+49 251 5909202", + | | | | "roof:colour": "#F5F5DC", + | | | | "contact:email": "info-theater@stadt-muenster.de", + | | | | "contact:phone": "+49 251 5909205", + | | | | "roof:material": "gravel", + | | | | "building:colour": "silver", + | | | | "building:levels": "2", + | | | | "contact:website": "https://www.theater-muenster.com/start/index.html", + | | | | "building:material": "concrete", + | | | | "construction_date": "1956", + | | | | "wikimedia_commons": "Category:Theater Münster", + | | | | "toilets:wheelchair": "yes" + | | | | } (1 row)

```

Nominatim_Reverse

Description

Reverse geocoding generates an address from a coordinate given as latitude and longitude. The reverse geocoding API does not exactly compute the address for the coordinate it receives. It works by finding the closest suitable OSM object and returning its address information. This may occasionally lead to unexpected results.

Availability: 1.0.0

Synopsis

SETOF Record nominatim_reverse(parameters)

Parameters

| Parameter | Type | Description | |---|---|--- | server_name | required | Foreign Data Wrapper server created using the CREATE SERVER statement. | | addressdetails | optional | includes a breakdown of the address into elements (default false) | | extratags | optional | additional information in the result that is available in the database, e.g. wikipedia link, opening hours. (default false) | | namedetails | optional | includes a full list of names for the result. (default false) | | accept_language | optional | language string as in "Accept-Language" HTTP header (default en_US). This overrides the accept_language set in the CREATE SERVER statement | | zoom | optional | Level of detail required for the address. This is a number that corresponds roughly to the zoom level used in XYZ tile sources in frameworks like Leaflet.js, Openlayers etc. In terms of address details the zoom levels are as follows: 3 country, 5 state, 8 county, 10 city, 12 town / borough, 13 village / suburb, 14 neighbourhood, 15 any settlement, 16 major streets, 17 major and minor streets, 18 building (default 18) | | layer | optional | comma-separated list of: address, poi, railway, natural, manmade (default unset) | | polygon_type | optional | one of: polygon_geojson, polygon_kml, polygon_svg, polygon_text (default unset) | | polygon_treshold | optional | floating-point number. When one of the polygon_* outputs is chosen, return a simplified version of the output geometry. The parameter describes the tolerance in degrees with which the geometry may differ from the original geometry. Topology is preserved in the geometry. (default 0.0) | | email | optional | In case you're using the public Nominatim service: If you are making large numbers of requests, please include an appropriate email address to identify your requests. See Nominatim's Usage Policy for more details. You may ignore this parameter if you're hosting your server (default unset) |


Usage

For these examples we assume the following SERVER:

sql CREATE SERVER osm FOREIGN DATA WRAPPER nominatim_fdw OPTIONS (url 'https://nominatim.openstreetmap.org');

Address generation for the coordinates 7.6293 longitude and 51.9648 latitude:

```sql SELECT osm_id, result, boundingbox FROM nominatim_reverse( server_name => 'osm', lon => 7.6293, lat => 51.9648,
extratags => true);

osm_id | result | boundingbox
-----------+--------------------------------------------------------------------------------------------------------------------------+------------------------------------------- 121736959 | Theater Münster, 63, Neubrückenstraße, Martini, Altstadt, Münster-Mitte, Münster, North Rhine-Westphalia, 48143, Germany | 51.9644060,51.9652417,7.6286897,7.6304381 (1 row) ```

Nominatim_Lookup

Description

The lookup API allows to query the address and other details of one or multiple OSM objects like node, way or relation.

Availability: 1.0.0

Synopsis

SETOF Record nominatim_lookup(parameters)

Parameters

| Parameter | Type | Description | |---|---|--- | server_name | required | Foreign Data Wrapper server created using the CREATE SERVER statement. | | addressdetails | optional | includes a breakdown of the address into elements (default false) | | extratags | optional | additional information in the result that is available in the database, e.g. wikipedia link, opening hours. (default false) | | namedetails | optional | include a full list of names for the result. (default false) | | accept_language | optional | language string as in "Accept-Language" HTTP header (default en_US). This overrides the accept_language set in the CREATE SERVER | | polygon_type | optional | one of: polygon_geojson, polygon_kml, polygon_svg, polygon_text (default *unset*) | |polygon_treshold| optional | floating-point number (default0.0) | |email` | optional | valid email address (default unset) |

Usage

For these examples we assume the following SERVER:

sql CREATE SERVER osm FOREIGN DATA WRAPPER nominatim_fdw OPTIONS (url 'https://nominatim.openstreetmap.org');

```sql SELECT osm_id, display_name FROM nominatim_lookup( server_name => 'osm', osm_ids => 'W121736959');

osm_id | display_name
-----------+-------------------------------------------------------------------------------------------------------------------------- 121736959 | Theater Münster, 63, Neubrückenstraße, Martini, Altstadt, Münster-Mitte, Münster, North Rhine-Westphalia, 48143, Germany (1 row) ```

nominatim_fdw_version

Description

Shows the version of the installed nominatim_fdw and its main libraries.

Availability: 1.0.0

Synopsis

text nominatim_fdw_version();

Usage

```sql SELECT nominatim_fdw_version();

nominatim_fdw_version

nominatim_fdw = 1.0.0, libxml/2.9.10 libcurl/7.74.0 OpenSSL/1.1.1w zlib/1.2.11 brotli/1.0.9 libidn2/2.3.0 libpsl/0.21.0 (+libidn2/2.3.0) libssh2/1.9.0 nghttp2/1.43.0 librtmp/2.3 (1 row) ```

Deploy with Docker

To deploy nominatim_fdw with docker just pick one of the supported PostgreSQL versions, install the requirements and compile the source code. For instance, a nominatim_fdw Dockerfile for PostgreSQL 15 should look like this (minimal example):

```dockerfile FROM postgres:15

RUN apt-get update && \ apt-get install -y make gcc postgresql-server-dev-15 libxml2-dev libcurl4-openssl-dev

RUN tar xvzf nominatim_fdw-[VERSION].tar.gz && \ cd nominatim_fdw-[VERSION] && \ make -j && \ make install ```

To build the image save it in a Dockerfile and run the following command in the root directory - this will create an image called nominatim_fdw_image.:

bash $ docker build -t nominatim_fdw_image .

After successfully building the image you're ready to run or create the container ..

bash $ docker run --name my_container -e POSTGRES_HOST_AUTH_METHOD=trust nominatim_fdw_image

.. and then finally you're able to create and use the extension!

bash $ docker exec -u postgres my_container psql -d mydatabase -c "CREATE EXTENSION nominatim_fdw;"

For testers and developers

Deploying the latest development version straight from the source:

Dockerfile

```dockerfile FROM postgres:15

RUN apt-get update && \ apt-get install -y git make gcc postgresql-server-dev-15 libxml2-dev libcurl4-openssl-dev

WORKDIR /

RUN git clone https://github.com/jimjonesbr/nominatim_fdw.git && \ cd nominatim_fdw && \ make -j && \ make install ``` Deployment

bash $ docker build -t nominatim_fdw_image . $ docker run --name my_container -e POSTGRES_HOST_AUTH_METHOD=trust nominatim_fdw_image $ docker exec -u postgres my_container psql -d mydatabase -c "CREATE EXTENSION nominatim_fdw;"