|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
cmd can be any valid ES query command
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
var logger = require( 'pelias-logger' ).get( 'api' );
|
|
|
|
|
|
|
|
function service( esclient, cmd, cb ){
|
|
|
|
|
|
|
|
// query elasticsearch
|
|
|
|
esclient.search( cmd, function( err, data ){
|
|
|
|
|
|
|
|
// log total ms elasticsearch reported the query took to execute
|
|
|
|
if( data && data.took ){
|
|
|
|
logger.verbose( 'time elasticsearch reported:', data.took / 1000 );
|
|
|
|
}
|
|
|
|
|
|
|
|
// handle elasticsearch errors
|
|
|
|
if( err ){
|
|
|
|
logger.error( `elasticsearch error ${err}` );
|
|
|
|
return cb( err );
|
|
|
|
}
|
|
|
|
|
|
|
|
// map returned documents
|
|
|
|
var docs = [];
|
|
|
|
var meta = {
|
|
|
|
scores: []
|
|
|
|
};
|
|
|
|
|
|
|
|
if( data && data.hits && data.hits.total && Array.isArray(data.hits.hits)){
|
|
|
|
docs = data.hits.hits.map( function( hit ){
|
|
|
|
|
|
|
|
meta.scores.push(hit._score);
|
|
|
|
|
|
|
|
// map metadata in to _source so we
|
|
|
|
// can serve it up to the consumer
|
|
|
|
hit._source._id = hit._id;
|
|
|
|
hit._source._type = hit._type;
|
|
|
|
hit._source._score = hit._score;
|
|
|
|
hit._source._matched_queries = hit.matched_queries;
|
|
|
|
|
|
|
|
return hit._source;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// fire callback
|
|
|
|
return cb( null, docs, meta );
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = service;
|