Browse Source

added comments, made code conciser

pull/850/head
Stephen Hess 8 years ago
parent
commit
c3be7844cb
  1. 23
      controller/placeholder.js

23
controller/placeholder.js

@ -6,10 +6,14 @@ const logger = require('pelias-logger').get('api');
const logging = require( '../helper/logging' ); const logging = require( '../helper/logging' );
const Document = require('pelias-model').Document; const Document = require('pelias-model').Document;
const boundingBoxRegex = /^-?\d+\.\d+,-?\d+\.\d+,-?\d+\.\d+,-?\d+\.\d+$/; // returns true if all 4 ,-delimited (max) substrings are parseable as numbers
// '12.12,21.21,13.13,31.31' returns true
// '12.12,21.21,13.13,blah' returns false
function validBoundingBox(bbox) { function validBoundingBox(bbox) {
return boundingBoxRegex.test(bbox); return bbox.
split(',', 4).
map(_.toNumber).
every(_.isFinite);
} }
function synthesizeDocs(result) { function synthesizeDocs(result) {
@ -23,7 +27,7 @@ function synthesizeDocs(result) {
// lodash conformsTo verifies that an object has a property with a certain format // lodash conformsTo verifies that an object has a property with a certain format
if (_.conformsTo(result.geom, { 'bbox': validBoundingBox } )) { if (_.conformsTo(result.geom, { 'bbox': validBoundingBox } )) {
const parsedBoundingBox = result.geom.bbox.split(',').map(parseFloat); const parsedBoundingBox = result.geom.bbox.split(',').map(_.toNumber);
doc.setBoundingBox({ doc.setBoundingBox({
upperLeft: { upperLeft: {
lat: parsedBoundingBox[3], lat: parsedBoundingBox[3],
@ -78,12 +82,14 @@ function synthesizeDocs(result) {
function setup(placeholderService, should_execute) { function setup(placeholderService, should_execute) {
function controller( req, res, next ){ function controller( req, res, next ){
// bail early if req/res don't pass conditions for execution
if (!should_execute(req, res)) { if (!should_execute(req, res)) {
return next(); return next();
} }
placeholderService.search(req.clean.text, req.clean.lang.iso6393, logging.isDNT(req), (err, results) => { placeholderService.search(req.clean.text, req.clean.lang.iso6393, logging.isDNT(req), (err, results) => {
if (err) { if (err) {
// bubble up an error if one occurred
if (_.isObject(err) && err.message) { if (_.isObject(err) && err.message) {
req.errors.push( err.message ); req.errors.push( err.message );
} else { } else {
@ -91,14 +97,9 @@ function setup(placeholderService, should_execute) {
} }
} else { } else {
// otherwise convert results to ES docs
res.meta = {}; res.meta = {};
res.data = _.flatten(results.map((result) => { res.data = _.flatten(results.map(synthesizeDocs));
if (_.isEmpty(result.lineage)) {
return synthesizeDocs(result);
}
return synthesizeDocs(result);
}));
} }
return next(); return next();

Loading…
Cancel
Save