0.0.3 • Published 3 years ago

@comodinx/query-filters v0.0.3

Weekly downloads
-
License
ISC
Repository
gitlab
Last release
3 years ago

Query Filters

@comodinx/query-filters is a module for parsing filters in string to object.

Index

Download & Install

NPM

$ npm install @comodinx/query-filters

Source code

$ git clone https://github.com/comodinx/query-filters.git
$ cd query-filters
$ npm install

How is it used?

Simple usage

const { Parser } = require('@comodinx/query-filters');
const parser = new Parser();

parser.parse('active eq 1,description li %casa');
// { "active": { "eq": "1" }, "description": { "li": "%casa" } }

parser.parse('active eq 1,description li %casa,description eq depto');
// { "active": { "eq": "1" }, "description": { "li": "%casa", "eq": "depto" } }

Operators

NameExampleDescription
eqid eq 1Check equality. id = 1
nename ne nicoCheck inequality. name != 'nico'
gtid gt 1Check greater than. id > 1
geid ge 10Check greater than or equal. id >= 10
ltid lt 1Check less than. id < 1
leid le 10Check less than or equal. id <= 10
liname li nico%Check matches with nico*. name like nico%
nlname nl nico%Check not matches with nico*. name not like nico%
inid in 1;2;3Check if included on 1,2,3. id in (1,2,3)
niid ni 1;2;3Check if not included on 1,2,3. id not in (1,2,3)
beid be 1;10Check if it is between a and b. id between (1 and 10)
nbid nb 1;10Check if it is not between a and b. id not between (1 and 10)
isdeleted_at is nullCheck if it is null.
nodeleted_at is not nullCheck if it is not null.

Configurations

NameTypeDefaultDescription
separatorstring","Filter separator.
keystring"A-Za-z0-9_+"String with RegExp format for match key on filters.
valuestring".+"String with RegExp format for match value on filters.
operatorsarray'eq','ne','gt','ge','lt','le','li','nl','in','ni','be','nb','is','ns'Operators known to the parser.
operatorPrefixstring" "Operator prefix in the string filter.
operatorSuffixstring" "Operator suffix in the string filter.
operatorFlagsstring"i"Operator regexp flag.
mapOperatorobject or functionnullMapper used to replace operators.
mapValuefunctionnullMapper used to replace values.
mapValueFormatfunctionnullMapper used to replace values only on format method.
mapValueParsefunctionnullMapper used to replace values only on parse method.
mapKeyobject or functionnullMapper used to replace keys.
mapKeyFormatobject or functionnullMapper used to replace keys only on format method.
mapKeyParseobject or functionnullMapper used to replace keys only on parse method.
separatorGroupsstring";"Filter group separator. Example "id in 1;2;3"

Configuration examples

const parser = new Parser({
  separator: '---'
});

parser.parse('active eq 1---description li %casa');
// { "active": { "eq": "1" }, "description": { "li": "%casa" } }
const parser = new Parser({
  operators: Parser.defaults.operators.concat(['my-operator'])
});

parser.parse('active eq 1,description my-operator casa');
// { "active": { "eq": "1" }, "description": { "my-operator": "casa" } }

Configuration mapper

Inspired to use in combination with @comodinx/sequelize

const { Parser, Mappers } = require('@comodinx/query-filters');
const parser = new Parser({
  mapper: Mappers.SQL
});

parser.parse('active eq 1,description li %casa');
// { "active": { "=": "1" }, "description": { "LIKE": "%casa" } }

Complete example with @comodinx/sequelize

const { Database, Query } = require('@comodinx/sequelize');
const { Parser, Mappers } = require('@comodinx/query-filters');
const db = new Database({
  host: 'localhost',
  user: 'myuser',
  password: 'mypass',
  database: 'mydbname'
});
const parser = new Parser({
  mapper: Mappers.SQL
});

const where = parser.parse('active eq 1,description li %nicolas');
const query = Query.select('users', { where });
// "SELECT * FROM users WHERE active = '1' AND description LIKE '%nicolas'"

db.query(query);
// array<user models>

Format

const parser = new Parser();

parser.format({
  active: {
    eq: "1"
  },
  description: {
    li: "%casa"
  }
});
// "active eq 1,description li %casa"

Tests

In order to see more concrete examples, I INVITE YOU TO LOOK AT THE TESTS :)

Run the unit tests

npm install
npm test
0.0.3

3 years ago

0.0.2

5 years ago

0.0.1

5 years ago