Browse Source

Merge pull request #864 from pelias/master

Merge master into staging
pull/865/head
Diana Shkolnikov 8 years ago committed by GitHub
parent
commit
b4394dd45a
  1. 3
      controller/coarse_reverse.js
  2. 20
      query/search.js

3
controller/coarse_reverse.js

@ -92,6 +92,7 @@ function setup(service, should_execute) {
service(centroid, isDNT(req), (err, results) => { service(centroid, isDNT(req), (err, results) => {
// if there's an error, log it and bail // if there's an error, log it and bail
if (err) { if (err) {
logger.info(`[controller:coarse_reverse][error]`);
logger.error(err); logger.error(err);
return next(); return next();
} }
@ -101,6 +102,8 @@ function setup(service, should_execute) {
return req.clean.layers.indexOf(granularity) !== -1; return req.clean.layers.indexOf(granularity) !== -1;
}); });
logger.info(`[controller:coarse_reverse][queryType:pip][result_count:${Object.keys(results).length}]`);
// now remove everything from the response that is more granular than the // now remove everything from the response that is more granular than the
// most granular layer requested. that is, if req.clean.layers=['county'], // most granular layer requested. that is, if req.clean.layers=['county'],
// remove neighbourhoods, localities, and localadmins // remove neighbourhoods, localities, and localadmins

20
query/search.js

@ -144,6 +144,9 @@ function generateQuery( clean ){
} }
function getQuery(vs) { function getQuery(vs) {
logger.info(`[query:search] [search_input_type:${determineQueryType(vs)}]`);
if (hasStreet(vs) || if (hasStreet(vs) ||
isCityStateOnlyWithOptionalCountry(vs) || isCityStateOnlyWithOptionalCountry(vs) ||
isCityCountryOnly(vs) || isCityCountryOnly(vs) ||
@ -160,6 +163,23 @@ function getQuery(vs) {
} }
function determineQueryType(vs) {
if (vs.isset('input:housenumber') && vs.isset('input:street')) {
return 'address';
}
else if (vs.isset('input:street')) {
return 'street';
}
else if (vs.isset('input:query')) {
return 'venue';
}
else if (['neighbourhood', 'borough', 'postcode', 'county', 'region','country'].some(
(layer)=> { return vs.isset(`input:${layer}`);})) {
return 'admin';
}
return 'other';
}
function hasStreet(vs) { function hasStreet(vs) {
return vs.isset('input:street'); return vs.isset('input:street');
} }

Loading…
Cancel
Save