Browse Source

added query-for-venue-when-single-admin-analysis support

query-for-venues-on-admin-only
Stephen Hess 7 years ago
parent
commit
97e46009b0
  1. 17
      routes/v1.js

17
routes/v1.js

@ -34,6 +34,7 @@ var controllers = {
placeholder: require('../controller/placeholder'), placeholder: require('../controller/placeholder'),
search: require('../controller/search'), search: require('../controller/search'),
search_with_ids: require('../controller/search_with_ids'), search_with_ids: require('../controller/search_with_ids'),
search_with_appending_results: require('../controller/search_with_appending_results'),
status: require('../controller/status') status: require('../controller/status')
}; };
@ -43,7 +44,8 @@ var queries = {
structured_geocoding: require('../query/structured_geocoding'), structured_geocoding: require('../query/structured_geocoding'),
reverse: require('../query/reverse'), reverse: require('../query/reverse'),
autocomplete: require('../query/autocomplete'), autocomplete: require('../query/autocomplete'),
address_using_ids: require('../query/address_search_using_ids') address_using_ids: require('../query/address_search_using_ids'),
venues: require('../query/venues')
}; };
/** ----------------------- controllers ----------------------- **/ /** ----------------------- controllers ----------------------- **/
@ -82,10 +84,11 @@ const isOnlyNonAdminLayers = require('../controller/predicates/is_only_non_admin
const isRequestSourcesOnlyWhosOnFirst = require('../controller/predicates/is_request_sources_only_whosonfirst'); const isRequestSourcesOnlyWhosOnFirst = require('../controller/predicates/is_request_sources_only_whosonfirst');
const hasRequestParameter = require('../controller/predicates/has_request_parameter'); const hasRequestParameter = require('../controller/predicates/has_request_parameter');
const hasParsedTextProperties = require('../controller/predicates/has_parsed_text_properties'); const hasParsedTextProperties = require('../controller/predicates/has_parsed_text_properties');
const isSingleFieldAnalysis = require('../controller/predicates/is_single_field_analysis');
// shorthand for standard early-exit conditions // shorthand for standard early-exit conditions
const hasResponseDataOrRequestErrors = any(hasResponseData, hasRequestErrors); const hasResponseDataOrRequestErrors = any(hasResponseData, hasRequestErrors);
const hasAdminOnlyResults = not(hasResultsAtLayers(['venue', 'address', 'street'])); const hasAdminOnlyResults = not(hasResultsAtLayers.any(['venue', 'address', 'street']));
const hasNumberButNotStreet = all( const hasNumberButNotStreet = all(
hasParsedTextProperties.any('number'), hasParsedTextProperties.any('number'),
@ -243,7 +246,7 @@ function addRoutes(app, peliasConfig) {
not(hasRequestErrors), not(hasRequestErrors),
isInterpolationEnabled, isInterpolationEnabled,
hasParsedTextProperties.all('number', 'street'), hasParsedTextProperties.all('number', 'street'),
hasResultsAtLayers('street') hasResultsAtLayers.any('street')
); );
// execute under the following conditions: // execute under the following conditions:
@ -257,6 +260,13 @@ function addRoutes(app, peliasConfig) {
) )
); );
const venuesSearchShouldExecute = all(
not(hasRequestErrors),
isAdminOnlyAnalysis,
isSingleFieldAnalysis,
hasResultsAtLayers.all('neighbourhood')
);
// helpers to replace vague booleans // helpers to replace vague booleans
const geometricFiltersApply = true; const geometricFiltersApply = true;
const geometricFiltersDontApply = false; const geometricFiltersDontApply = false;
@ -280,6 +290,7 @@ function addRoutes(app, peliasConfig) {
controllers.placeholder(placeholderService, geometricFiltersApply, placeholderGeodisambiguationShouldExecute), controllers.placeholder(placeholderService, geometricFiltersApply, placeholderGeodisambiguationShouldExecute),
controllers.placeholder(placeholderService, geometricFiltersDontApply, placeholderIdsLookupShouldExecute), controllers.placeholder(placeholderService, geometricFiltersDontApply, placeholderIdsLookupShouldExecute),
controllers.search_with_ids(peliasConfig.api, esclient, queries.address_using_ids, searchWithIdsShouldExecute), controllers.search_with_ids(peliasConfig.api, esclient, queries.address_using_ids, searchWithIdsShouldExecute),
controllers.search_with_appending_results(peliasConfig.api, esclient, queries.venues, venuesSearchShouldExecute),
// 3rd parameter is which query module to use, use fallback first, then // 3rd parameter is which query module to use, use fallback first, then
// use original search strategy if first query didn't return anything // use original search strategy if first query didn't return anything
controllers.search(peliasConfig.api, esclient, queries.cascading_fallback, fallbackQueryShouldExecute), controllers.search(peliasConfig.api, esclient, queries.cascading_fallback, fallbackQueryShouldExecute),

Loading…
Cancel
Save