Research
Security News
Malicious npm Packages Inject SSH Backdoors via Typosquatted Libraries
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
@imatic/pgqb
Advanced tools
This library allows you to create dynamic sql queries.
In case of simple queries, you could just use template literals:
const sql = `
SELECT *
FROM "table"
`
In case you have lots of parameters, you could use sql-template-strings:
import {SQL} from 'sql-template-strings';
const sqlStatement = `
INSERT INTO "table"
("col1", "col2")
VALUES
(${val1}, ${val2})
`;
But what if you want to create queries dynamically? Splitting queries into several string parts, modifying several parts separately and then concatenating them togheter? There is better way - building queries as javascript data structures, which can be then easilly manipulated, merged, ...
Let's see previous query built using this library:
import * as qb from '@imatic/pgqb';
const sqlMap = qb.merge(
qb.insertInto('table'),
qb.columns(['col1', 'col2']),
qb.values([
[
qb.val.inlineParam(val1),
qb.val.inlineParam(val2),
]
])
);
const sqlStatement = qb.toSql(sqlMap);
Query above automatically escapes identifiers (tables, colums). For now, building the query using this library seems more verbose than using just sql-template-strings. Imagine you would want to modify the query though. If you wanted to add additional column, you could do it like so:
import * as qb from '@imatic/pgqb';
const sqlMap = qb.merge(
qb.insertInto('table'),
qb.columns(['col1', 'col2']),
qb.values([
[
qb.val.inlineParam(val1),
qb.val.inlineParam(val2),
]
])
);
const additionalColumn = qb.merge(
qb.columns(['col3']),
qb.values([
[
qb.val.inlineParam(val3),
]
])
)
const sqlStatement = qb.toSql(qb.append(sqlMap, additionalColumn));
Your query now inserts 3 columns instead of original 2. You can append other clauses (like where
) too.
This library was inspired by honeysql.
FAQs
Functional PostgreSQL query builder
The npm package @imatic/pgqb receives a total of 145 weekly downloads. As such, @imatic/pgqb popularity was classified as not popular.
We found that @imatic/pgqb demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers 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.
Research
Security News
Socket’s threat research team has detected six malicious npm packages typosquatting popular libraries to insert SSH backdoors.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.