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.
@knorm/postgres
Advanced tools
Postgres plugin for @knorm/knorm that enables running queries agaisnt postgres. Also, it adds postgres-specific features such as:
json
and jsonb
fields before save (insert or update)string
fields with maxLength: 255
limit
, offset
, returning
query options and ilike
where option,
via sql-bricks-postgresUPDATE FROM
, via
sql-bricks-postgresnpm install --save @knorm/knorm @knorm/postgres
@knorm/postgres has a peer dependency on @knorm/knorm
const knorm = require('@knorm/knorm');
const knormPostgres = require('@knorm/postgres');
const orm = knorm({
// knorm options
}).use(
knormPostgres({
// knormPostgres options
})
);
Option | Type | Description |
---|---|---|
name | string | the name of the plugin, defaults to 'postgres' |
connection | object or string | if set, this option is passed directly to pg. However, connections can also be configured via environment variables |
initClient | (async) function | a function called when a new client is acquired from the pool. useful for configuring the connection e.g. setting session variables. it's called with the client as the only argument |
restoreClient | (async) function | a function called before a client is released back into the pool. useful for restoring a client e.g. unsetting session variables. it's called with the client as the only argument |
NOTE that all options are optional. |
When updating json
and jsonb
fields, you may wish to only update part of the
JSON data instead of the whole object. You can partially update json fields via
the patch
option:
true
to patch all the json and jsonb fields in the
update dataFor example:
class User extends Model {}
User.fields = {
id: { type: 'integer' },
jsonb: { type: 'jsonb' },
json: { type: 'json' }
};
const data = { jsonb: { foo: 'bar' }, json: { foo: 'bar' } };
// to update whole object without patching:
User.update(data);
// to patch all fields in the update:
User.update(data, { patch: true });
// to patch a single field:
User.update(data, { patch: 'json' });
// to patch multiple fields:
User.update(data, { patch: ['json', 'jsonb'] });
Note that only basic json-patching is supported: only the first level of patching is supported. For nested objects and arrays, the whole object/array is replaced:
// before:
new User({
jsonb: { top: { foo: 'foo' } },
json: { top: { foo: 'foo' } }
});
// patch update:
User.query
.patch(['json', 'jsonb'])
.update({
jsonb: { top: { bar: 'bar' } },
json: { top: { bar: 'bar' } }
});
// result:
new User({
jsonb: { top: { bar: 'bar' } },
json: { top: { bar: 'bar' } }
});
To patch nested objects or arrays, use jsonb_set instead in a raw-sql update:
// assuming the data is currently:
new User({
jsonb: { top: { foo: 'foo' } },
json: { top: { foo: 'foo' } }
});
// to add a nested `bar` key/value:
User.query
.patch(['json', 'jsonb'])
.update({
jsonb: User.query.sql(`jsonb_set("jsonb", '{top,bar}', '"bar"')`),
// for plain json fields, you have to cast to jsonb and then cast the result
// back to json:
json: User.query.sql(`jsonb_set("json"::jsonb, '{top,bar}', '"bar"')::json`)
});
// result:
new User({
jsonb: { top: { foo: 'foo', bar: 'bar' } },
json: { top: { foo: 'foo', bar: 'bar' } }
});
FAQs
Postgres plugin for knorm
The npm package @knorm/postgres receives a total of 1,276 weekly downloads. As such, @knorm/postgres popularity was classified as popular.
We found that @knorm/postgres 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.
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.