Build simple SQL WHERE conditions using JSON.
Here's a few examples:
{id: 1} -> 'id = 1'
[{id: 1}, {type: 'photo'}] -> 'id = 1 OR type = "photo"'
{id: 1, type: 'photo'} -> 'id = 1 AND type = "photo"'
{type:['photo','video']} -> 'type IN ("photo","video")'
{type:{not:'text'}} -> 'type != "text"'
{type:{not:['text','video']}} -> 'type NOT IN ("text","video")'
{type:{like:'te%'}} -> 'type LIKE "te%"'
{type:{like:['te%','x']}} -> error
It's rather convenient to be able to use JSON instead of manually building the WHERE conditions. This is also node-postgres friendly and separates the values from the SQL to be able to use Parameterized Queries.
This is really all the API you need to learn. Pass in an object like the one of the examples above in How?. Then you can either use the #sql and #values array to make a parameterized query (recommended!) or use #toString to generate a complete condition.
Options:
table
(ex. 'contents') will prefix the attributes ex '"{table}.id" = 1'
The generated SQL conditions from the parsed query
.
Example: type = $1
An array of values to be used in a parameterized query.
Example: [1,'bob']
This does the magic of creating conditions from a JSON object.
This generates a non-parameterized SQL string from #sql and #values.
Example: type = "text" OR status IN ("published","pending")
NOTE The generated SQL condition is in no way guaranteed to be properly escaped. It only does very simple string escaping. And according to people way smarter than me manually escaping any queries will never be enough to counter SQL injections. So please only use this for debugging.