56 lines
1.3 KiB

10 years ago
var service = { search: require('../service/search') };
var logger = require('pelias-logger').get('api:controller:search');
function setup( backend, query ){
// allow overriding of dependencies
backend = backend || require('../src/backend');
query = query || require('../query/search');
function controller( req, res, next ){
// do not run controller when a request
// validation error has occurred.
if( req.errors && req.errors.length ){
return next();
}
// log clean parameters for stats
logger.info('[req]', 'endpoint=' + req.path, req.clean);
// backend command
var cmd = {
index: 'pelias',
searchType: 'dfs_query_then_fetch',
body: query( req.clean )
};
// use layers field for filtering by type
if( req.clean.hasOwnProperty('layers') ){
cmd.type = req.clean.layers;
}
logger.debug( '[ES req]', JSON.stringify(cmd) );
10 years ago
// query backend
service.search( backend, cmd, function( err, docs, meta ){
10 years ago
// error handler
9 years ago
if( err ){
req.errors.push( err );
9 years ago
}
// set response data
9 years ago
else {
res.data = docs;
res.meta = meta;
9 years ago
}
logger.debug('[ES response]', JSON.stringify(docs));
next();
});
}
return controller;
}
module.exports = setup;