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.
backbone-sql
Advanced tools
PostgreSQL, MySQL, and SQLite3 storage for BackboneORM.
BackboneSQL provides an interface for BackboneORM models to persist to SQL databases.
Please checkout the website for examples, documentation, and community!
Fields are specified in the models schema
property. Each (non-relation) field corresponds to a database column.
Each field must have a type and may be provided with the additional options.
An auto-incrementing field named id
is automatically created as the primary key for each model.
To supply options the field descriptor is passed as an array, with the first item being the field type and a settings object as the second.
All types supported by Knex are available. Add column specific options along with the settings object for the field. The first letter of the type name is optionally capitalized, while the remainder must be camelCase.
These options may be applied to any field. Note that column options are currently only applied when the columns are created.
nullable
: Defaults to true
. Set to false to throw an error on null values.indexed
: Defaults to false
. Set to true to create an index on the column.unique
: Defaults to false
. Set to true to create a unique constraint on the column.SQLSync = require('backbone-sql').sync
class Project extends Backbone.Model
# Database connection and table name are specified with the urlRoot
urlRoot: 'postgres://username:password@localhost:27017/my_database/projects'
# Schema defines the fields for the model's table
schema:
created_at: 'DateTime'
type: ['Integer', nullable: false]
name: ['String', unique: true, indexed: true]
# Kick it off by setting the model's sync to an SQLSync
sync: SQLSync(Project)
var SQLSync = require('backbone-sql').sync;
var Project = Backbone.Model.extend({
// Database connection and table name are specified with the urlRoot
urlRoot: 'postgres://username:password@localhost:27017/projects',
// Schema defines the fields for the model's table
schema: {
created_at: 'DateTime',
type: ['Integer', {nullable: false}],
name: ['String', {unique: true, indexed: true}]
}
});
// Kick it off by setting the model's sync to an SQLSync
Project.prototype.sync = SQLSync(Project);
To build the library for Node.js and browsers:
$ gulp build
Please run tests before submitting a pull request:
$ gulp test --quick
and eventually all tests:
$ npm test
You can run the following fine-grained tests to resolve problems with specific application frameworks
$ gulp test-postgres
$ gulp test-mysql
$ gulp test-sqlite3
FAQs
PostgreSQL, MySQL, and SQLite3 storage for BackboneORM
The npm package backbone-sql receives a total of 4 weekly downloads. As such, backbone-sql popularity was classified as not popular.
We found that backbone-sql 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.