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.
46 lines
1.3 KiB
46 lines
1.3 KiB
var types_helper = require( '../helper/types' ); |
|
|
|
/** |
|
* Validate the types specified to be searched. |
|
* |
|
* Elasticsearch interprets an empty array of types as "search anything" rather |
|
* than "search nothing", so in the case of an empty array, return an error |
|
* message instead of searching at all. |
|
*/ |
|
function middleware(req, res, next) { |
|
req.clean = req.clean || {}; |
|
|
|
if (req.clean.hasOwnProperty('types')) { |
|
|
|
try { |
|
var types = types_helper(req.clean.types); |
|
|
|
if ((types instanceof Array) && types.length === 0) { |
|
var err = 'You have specified both the `sources` and `layers` ' + |
|
'parameters in a combination that will return no results.'; |
|
req.errors.push( err ); |
|
} |
|
|
|
else { |
|
req.clean.type = types; |
|
} |
|
|
|
} |
|
|
|
// @todo: refactor this flow, it is confusing as `types_helper()` can throw |
|
// with an error "clean_types should not be null or undefined" which is |
|
// not returned to the user yet the return value CAN trigger a user error. |
|
// I would have liked to throw for BOTH cases and then handle the users errors |
|
// inside the 'catch' but this is not possible. |
|
// also: why are we deleting things from $clean? |
|
catch (err) { |
|
// this means there were no types specified |
|
delete req.clean.types; |
|
} |
|
|
|
} |
|
|
|
next(); |
|
} |
|
|
|
module.exports = middleware;
|
|
|