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]', cmd ); // query backend service.search( backend, cmd, function( err, docs, meta ){ // error handler if( err ){ req.errors.push( err ); } // set response data else { res.data = docs; res.meta = meta; } logger.debug('[ES response]', docs); next(); }); } return controller; } module.exports = setup;