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.
 
 

63 lines
1.1 KiB

/**
query must be an array of hashes, structured like so:
{
_index: 'myindex',
_type: 'mytype',
_id: 'myid'
}
**/
var logger = require( 'pelias-logger' ).get( 'api' );
function service( esclient, query, cb ){
// elasticsearch command
var cmd = {
body: {
docs: query
}
};
// query elasticsearch
const startTime = new Date();
esclient.mget( cmd, function( err, data ){
if (data) {
data.response_time = new Date() - startTime;
}
// handle elasticsearch errors
if( err ){
logger.error( `elasticsearch error ${err}`);
return cb( err );
}
// map returned documents
var docs = [];
if( data && Array.isArray(data.docs) ){
docs = data.docs.filter( function( doc ){
// remove docs not actually found
return doc.found;
}).map( function( doc ){
// map metadata in to _source so we
// can serve it up to the consumer
doc._source._id = doc._id;
doc._source._type = doc._type;
return doc._source;
});
}
// fire callback
return cb( null, docs, data );
});
}
module.exports = service;