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.

83 lines
2.3 KiB

var _ = require('lodash');
10 years ago
var service = { search: require('../service/search') };
var logger = require('pelias-logger').get('api:controller:search');
var logging = require( '../helper/logging' );
function setup( config, backend, query ){
// allow overriding of dependencies
backend = backend || require('../src/backend');
query = query || require('../query/search');
// verify that we don't let an old style query object slip through the cracks here
if (typeof query !== 'object' || !query.hasOwnProperty('query_type')) {
throw new Error('Search queries must return an object with query and query_type');
}
function controller( req, res, next ){
// do not run controller when a request
// validation error has occurred.
if( req.errors && req.errors.length ){
return next();
}
// do not run controller if there are already results
// this was added during libpostal integration. if the libpostal parse/query
// doesn't return anything then fallback to old search-engine-y behavior
if (res && res.hasOwnProperty('data') && res.data.length > 0) {
return next();
}
var cleanOutput = _.cloneDeep(req.clean);
if (logging.isDNT(req)) {
cleanOutput = logging.removeFields(cleanOutput);
}
// log clean parameters for stats
logger.info('[req]', 'endpoint=' + req.path, cleanOutput);
var query_body = query.query(req.clean);
// if there's no query to call ES with, skip the service
if (_.isUndefined(query_body)) {
return next();
}
// backend command
var cmd = {
index: config.indexName,
searchType: 'dfs_query_then_fetch',
body: query_body
};
logger.debug( '[ES req]', cmd );
10 years ago
// query backend
service.search( backend, cmd, function( err, docs, meta ){
10 years ago
// error handler
9 years ago
if( err ){
if (_.isObject(err) && err.message) {
req.errors.push( err.message );
} else {
req.errors.push( err );
}
9 years ago
}
// set response data
9 years ago
else {
res.data = docs;
res.meta = meta || {};
// store the query_type for subsequent middleware
res.meta.query_type = query.query_type;
9 years ago
}
logger.debug('[ES response]', docs);
next();
});
}
return controller;
}
module.exports = setup;