This repository is part of the Pelias project. Pelias is an open-source, open-data geocoder built by Mapzen that also powers Mapzen Search. Our official user documentation is here.
Pelias Document Service
data:image/s3,"s3://crabby-images/fff11/fff1182450f08542a865d79cd176b725d9ddac02" alt="Gitter Chat"
Overview
Module that provides a web service to aid language-agnostic importers in creating documents for insertion into an Elasticsearch index queryable by the Pelias API. Who's on First data is required in order to populate the documents' administrative hierarchy.
Installation
$ git clone git@github.com:pelias/document-service.git
$ cd document-service
$ npm install
$ npm start /path/to/whos/on/first/data
For ease of use, Who's on First data can be downloaded using scripts provided by the Pelias Who's on First module.
data:image/s3,"s3://crabby-images/dcb50/dcb50df1082260c9a615ed73e0db3ce6c8ed82af" alt="NPM"
NPM Module
The pelias-document-service
npm module can be found here:
https://npmjs.org/package/pelias-document-service
Usage
To start the document service, type: npm start <path to Who's on First data>
. By default, the service starts on port 5000 but can be overridden in the PORT
environmental variable.
Requests are made to the endpoint using the GET
method in the format: http://localhost:5000/synthesize/<source>/<layer>
.
source
is the name of the source of the data that can be used to filter. For example, data imported from OpenAddresses would use openaddresses
for source
.
Currently, the only valid values for layer
are address
, street
, and venue
.
For example: http://localhost:5000/synthesize/openaddresses/address?id=6364a510f0268d6f&lon=-73.9904095&lat=40.74427&name=30+W+26th+St&house_number=30&street=W+26th+St&postcode=10010
Parameters
The following parameters are supported for the service:
name | required | description |
---|
id | yes | a unique identifier for reference in Elasticsearch |
lon | yes | longitude of the record |
lat | yes | latitude of the record |
name | yes | a textual of the record such as a business name (for venues) or house number + street (for addresses, typically) |
house_number | yes with address layer, no otherwise | house number of an address or venue |
street | yes with address or street layer, no otherwise | street of an address or venue |
postcode | no | postcode of an address or venue |
Error Conditions
A status 400 is returned with an error message under any of the following conditions:
lat
value is not parseable as a finite numberlon
value is not parseable as a finite numberid
value is emptyname
value is emptylayer=address
-specific:
house_number
value is emptystreet
value is empty
layer=street
-specific:
house_number
value is non-empty
layer=venue
-specific:
house_number
value is non-empty and street
value is empty