1.0.2 • Published 4 years ago

@quenk/facets-mongodb v1.0.2

Weekly downloads
12
License
Apache-2.0
Repository
-
Last release
4 years ago

Search Filters MongoDB

search-filters compiler for mongodb targets

Installation

npm install --save @quenk/search-filters-mongodb

Usage

This module provides a @quenk/search-filters compiler for generating mongodb query operators. It targets the Node.js Driver API particularly the Collection#find method.

To compile a source string, create an instance of MongoDBFilterCompiler and apply the compile() method giving it an EnabledPolicies and a valid source string.

Available Policies

This module ships with the following Available Policies :

Policy NameTypeOperatorsNotes
numbernumber= < > >= <= !=
booleanboolean= < > >= <= !=
stringstring= !=Tests equality.
matchstring=Converts value to regex.
matchcistring=Case-insensitive "match".
datedate= < > >= <= !=Actual value instanceof Date

You can specify a policy name instead of a definition in EnabledPolicies and it will be subsitituted at compile time. Consult the search-filters docs for more information.

You can add additional AvailablePolicies by overriding the policies argument of the MongoDBFilterCompiler.

Example

import {Value} from '@quenk/noni/lib/data/jsonx';
import {MongoDBFilterCompiler} from '@quenk/search-filters-mongodb';
import {FilterTerm} from '@quenk/search-filters-mongodb/lib/term';

const policies = {

 name: 'matchci',

 age: 'number'

 status: {

   type: 'number',
   operators: ['='],
   term: (field:string, op:string, value:Value ) => 
       new FilterTerm(field, op, value)

 }

}

const qry = '(name:"sana" or name:="Murr") and age:>20 and status:1';

let mfc = new MongoDBFilterCompiler();

let eResult = mfc.compile(qry);

/* Logs the below or throws if an error occured. 
  {"$and":
    [
       {
         "$or":[
            {"name":{"$regex":"sana", $options:"i"}},
            {"name":{"$regex":"Murr", $options:"i"}}
          ]
        },
        {"age":{"$gt":20}},
        {"status":{"$eq":1}}
    ]
   }
*/
console.log(eResult.takeRight());

License

Apache 2.0 (SEE LICENSE) file. (c) Quenk Technologies Limited.

1.0.2

4 years ago

1.0.1

4 years ago

0.3.6

4 years ago

0.3.5

4 years ago

0.3.4

4 years ago

0.3.3

5 years ago

0.3.2

5 years ago

0.3.1

5 years ago

0.3.0

5 years ago

0.2.0

5 years ago

0.1.0

5 years ago