Lucene-inspired string-based mongodb query language for humans (and ferrets). And implemention in Mongoose
$ npm install humanquery
- Nicer UX for the odd search / log filtering
- Writing JSON queries is a PITA
var mongoose = require('mongoose');
require('humanquery')( mongoose );
Query
model.findOne().query('level:error OR type:upload', function(err, doc){
// More Code..
});
model.query('level:error OR type:upload').count(function(err, doc){
// More Code..
});
Specify field names with optional values:
level:error
yields
{ level: 'error' }
Omit value to imply true:
failed
yields
{ failed: true }
Or specify a boolean-ish value (true, false, yes, no):
failed: no
yields
{ failed: false }
Currently supports AND / OR, which may be nested:
(level:error AND type:"upload failed") OR user.name.first:Tobi
yields
{ '$or':
[ { '$and': [ { level: 'error' }, { type: 'upload failed' } ] },
{ 'user.name.first': 'Tobi' } ] }
Regexps may be used with the //
syntax:
level:info AND name:/^To/
yields
{ '$and': [ { level: 'info' }, { name: /^To/ } ] }
Wildcards may be used to generate regular expressions:
level:error AND hostname:api-*
yields
{ '$and': [ { level: 'error' }, { hostname: /^api-.*$/ } ] }
MIT