Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
rollun-rql
Advanced tools
Resource Query Language (RQL) is a query language designed for use in URIs with object style data structures. This project includes the RQL specification and provides a JavaScript implementation of query parsing and query execution implementation for JavaScript arrays. The JavaScript library supports AMD and NodeJS/CommonJS module format so it can be run in the browser or in the server. RQL can be thought as basically a set of nestable named operators which each have a set of arguments. RQL is designed to have an extremely simple, but extensible grammar that can be written in a URL friendly query string. A simple RQL query with a single operator that indicates a search for any resources with a property of "foo" that has value of 3 could be written:
eq(foo,3)
RQL is a compatible superset of standard HTML form URL encoding. The following query is identical to the query (it is sugar for the query above):
foo=3
Such that this can be used in URIs like:
http://example.org/data?foo=3
Using the JavaScript library we can construct queries using chained operator calls in JavaScript. We could execute the query above like this:
var Query = require("rql/query").Query;
var fooEq3Query = new Query().eq("foo",3);
The RQL grammar is based around standard URI delimiters. The standard rules for encoding strings with URL encoding (%xx) are observed. RQL also supersets FIQL. Therefore we can write a query that finds resources with a "price" property below 10 with a "lt" operator using FIQL syntax:
price=lt=10
Which is identical (and sugar for call operator syntax known as the normalized form):
lt(price,10)
One can combine conditions with multiple operators with "&":
foo=3&price=lt=10
Is the same as:
eq(foo,3)<(price,10)
Which is also the same as:
and(eq(foo,3),lt(price,10))
We can execute a query against a JavaScript array:
require("rql/js-array").executeQuery("foo=3&price=lt=10", {}, data)...
The | operator can be used to indicate an "or" operation. We can also use paranthesis to group expressions. For example:
(foo=3|foo=bar)&price=lt=10
Which is the same as:
and(or(eq(foo,3),eq(foo,bar)),lt(price,10))
Values in queries can be strings (using URL encoding), numbers, booleans, null, undefined, and dates (in ISO UTC format without colon encoding). We can also denote arrays with paranthesis enclosed, comma separated values. For example to find the objects where foo can be the number 3, the string bar, the boolean true, or the date for the first day of the century we could write an array with the "in" operator:
foo=in=(3,bar,true,2000-01-01T00:00:00Z)
We can also explicitly specify primitive types in queries. To explicitly specify a string "3", we can do:
foo=string:3
Any property can be nested by using an array of properties. To search by the bar property of the object in the foo property we can do:
(foo,bar)=3
We can also use slashes as shorthand for arrays, so we could equivalently write the nested query:
foo/bar=3
Another common operator is sort. We can use the sort operator to sort by a specified property. To sort by foo in ascending order:
price=lt=10&sort(+foo)
We can also do multiple property sorts. To sort by price in ascending order and rating in descending order:
sort(+price,-rating)
The aggregate function can be used for aggregation. To calculate the sum of sales for each department:
aggregate(departmentId,sum(sales))
Here is a definition of the common operators (individual stores may have support for more less operators):
?
stands for any single character, *
stands for any number of characters); is case-sensitive?
stands for any single character, *
stands for any number of characters); is NOT case-sensitivevar newQuery = require("rql/query").Query();
This module allows us to construct queries. With the query object, we could execute RQL operators as methods against the query object. For example:
var Query = require("rql/query").Query;
var fooBetween3And10Query = new Query().lt("foo",3).gt("foo",10);
var parsedQueryObject = require("rql/parser").parseQuery(rqlString);
If you are writing an implementation of RQL for a database or other storage endpoint, or want to introspect queries, you can use the parsed query data structures. You can parse string queries with parser module's parseQuery function. Query objects have a "name" property and an "args" with an array of the arguments. For example:
require("rql/parser").parseQuery("(foo=3|foo=bar)&price=lt=10") ->
{
name: "and",
args: [
{
name:"or",
args:[
{
name:"eq",
args:["foo",3]
},
{
name:"eq",
args:["foo","bar"]
}
]
},
{
name:"lt",
args:["price",10]
}
]
}
RQL can be installed using any standard package manager, for example with NPM:
npm install rql
or CPM:
cpm install rql
or RingoJS:
ringo-admin install persvr/rql
The RQL implementation is part of the Persevere project, and therefore is licensed under the AFL or BSD license. The Persevere project is administered under the Dojo foundation, and all contributions require a Dojo CLA.
See the main Persevere project for more information:
FAQs
Query language for the web, NoSQL
The npm package rollun-rql receives a total of 13 weekly downloads. As such, rollun-rql popularity was classified as not popular.
We found that rollun-rql demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.