Browse Source

using async (parallel)

msv2
Harish Krishna 10 years ago
parent
commit
5f8c3da14e
  1. 63
      controller/suggest.js
  2. 3
      package.json

63
controller/suggest.js

@ -1,5 +1,6 @@
var geojsonify = require('../helper/geojsonify').suggest; var geojsonify = require('../helper/geojsonify').suggest;
var async = require('async');
function setup( backend, query ){ function setup( backend, query ){
@ -11,59 +12,49 @@ function setup( backend, query ){
backend = backend || require('../src/backend'); backend = backend || require('../src/backend');
var query_admin = require('../query/suggest_admin'); var query_admin = require('../query/suggest_admin');
var query_poi = require('../query/suggest_poi'); var query_poi = require('../query/suggest_poi');
// **query_poi** command
var cmd = { var cmd = {
index: 'pelias', index: 'pelias'
body: query_poi( req.clean )
}; };
var query_backend = function(cmd, callback) {
// query backend
backend().client.suggest( cmd, function( err, data ){
var docs = [];
// handle backend errors
if( err ){ return next( err ); }
// map response to a valid FeatureCollection
if( data && Array.isArray( data.pelias ) && data.pelias.length ){
docs = data['pelias'][0].options || [];
}
// **query_admin** command
var cmd = {
index: 'pelias',
body: query_admin( req.clean )
};
// query backend // query backend
backend().client.suggest( cmd, function( err, data ){ backend().client.suggest( cmd, function( err, data ){
var docs2 = []; var docs = [];
// handle backend errors // handle backend errors
if( err ){ return next( err ); } if( err ){ return next( err ); }
// map response to a valid FeatureCollection // map response to a valid FeatureCollection
if( data && Array.isArray( data.pelias ) && data.pelias.length ){ if( data && Array.isArray( data.pelias ) && data.pelias.length ){
docs2 = data['pelias'][0].options || []; docs = data['pelias'][0].options || [];
} }
/** --- combine 2 doc sets --- **/ callback(null, docs);
var combined = docs2.slice(0, 3).concat(docs); });
};
// convert docs to geojson
var geojson = geojsonify( combined );
// response envelope async.parallel({
geojson.date = new Date().getTime(); admin: function(callback){
cmd.body = query_admin( req.clean );
query_backend(cmd, callback);
},
poi: function(callback){
cmd.body = query_poi( req.clean );
query_backend(cmd, callback);
}
},
function(err, results) {
// results is now equals to: {admin: docs, poi: docs}
var combined = results.poi.slice(0, 3).concat(results.admin);
// respond // convert docs to geojson
return res.status(200).json( geojson ); var geojson = geojsonify( combined );
}); // response envelope
geojson.date = new Date().getTime();
// respond
return res.status(200).json( geojson );
}); });
} }

3
package.json

@ -36,7 +36,8 @@
"geojson": "^0.2.0", "geojson": "^0.2.0",
"geopipes-elasticsearch-backend": "0.0.8", "geopipes-elasticsearch-backend": "0.0.8",
"pelias-esclient": "0.0.25", "pelias-esclient": "0.0.25",
"toobusy": "^0.2.4" "toobusy": "^0.2.4",
"async": "^0.9.0"
}, },
"devDependencies": { "devDependencies": {
"ciao": "^0.3.4", "ciao": "^0.3.4",

Loading…
Cancel
Save