mirror of https://github.com/pelias/api.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
2.7 KiB
87 lines
2.7 KiB
var extend = require('extend'), |
|
_ = require('lodash'); |
|
|
|
function addStandardTargetsToAliases(standard, aliases) { |
|
var combined = _.extend({}, aliases); |
|
standard.forEach(function(target) { |
|
if (combined[target] === undefined) { |
|
combined[target] = [target]; |
|
} |
|
}); |
|
|
|
return combined; |
|
} |
|
|
|
/* |
|
* Sources |
|
*/ |
|
|
|
// a list of all sources |
|
var SOURCES = ['openstreetmap', 'openaddresses', 'geonames', 'whosonfirst']; |
|
|
|
/* |
|
* A list of alternate names for sources, mostly used to save typing |
|
*/ |
|
var SOURCE_ALIASES = { |
|
'osm': ['openstreetmap'], |
|
'oa': ['openaddresses'], |
|
'gn': ['geonames'], |
|
'wof': ['whosonfirst'] |
|
}; |
|
|
|
/* |
|
* Create an object that contains all sources or aliases. The key is the source or alias, |
|
* the value is either that source, or the canonical name for that alias if it's an alias. |
|
*/ |
|
var SOURCE_MAPPING = addStandardTargetsToAliases(SOURCES, SOURCE_ALIASES); |
|
|
|
/* |
|
* Layers |
|
*/ |
|
|
|
/* |
|
* A list of all layers in each source. This is used for convenience elswhere |
|
* and to determine when a combination of source and layer parameters is |
|
* not going to match any records and will return no results. |
|
*/ |
|
var LAYERS_BY_SOURCE = { |
|
openstreetmap: [ 'address', 'venue', 'street' ], |
|
openaddresses: [ 'address' ], |
|
geonames: [ 'country','macroregion', 'region', 'county','localadmin', |
|
'locality','borough', 'neighbourhood', 'venue' ], |
|
whosonfirst: [ 'continent', 'empire', 'country', 'dependency', 'macroregion', 'region', |
|
'locality', 'localadmin', 'macrocounty', 'county', 'macrohood', 'borough', |
|
'neighbourhood', 'microhood', 'disputed', 'venue', 'postalcode', |
|
'continent', 'ocean', 'marinearea'] |
|
}; |
|
|
|
/* |
|
* A list of layer aliases that can be used to support specific use cases |
|
* (like coarse geocoding) * or work around the fact that different sources |
|
* may have layers that mean the same thing but have a different name |
|
*/ |
|
var LAYER_ALIASES = { |
|
'coarse': [ 'continent', 'empire', 'country', 'dependency', 'macroregion', |
|
'region', 'locality', 'localadmin', 'macrocounty', 'county', 'macrohood', |
|
'borough', 'neighbourhood', 'microhood', 'disputed', 'postalcode', |
|
'continent', 'ocean', 'marinearea'] |
|
}; |
|
|
|
// create a list of all layers by combining each entry from LAYERS_BY_SOURCE |
|
var LAYERS = _.uniq(Object.keys(LAYERS_BY_SOURCE).reduce(function(acc, key) { |
|
return acc.concat(LAYERS_BY_SOURCE[key]); |
|
}, [])); |
|
|
|
/* |
|
* Create the an object that has a key for each possible layer or alias, |
|
* and returns either that layer, or all the layers in the alias |
|
*/ |
|
var LAYER_MAPPING = addStandardTargetsToAliases(LAYERS, LAYER_ALIASES); |
|
|
|
module.exports = { |
|
sources: SOURCES, |
|
layers: LAYERS, |
|
source_mapping: SOURCE_MAPPING, |
|
layer_mapping: LAYER_MAPPING, |
|
layers_by_source: LAYERS_BY_SOURCE |
|
};
|
|
|