JSPM

openrecord

1.10.10
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 21
  • Score
    100M100P100Q78851F

Active record like ORM for nodejs

Package Exports

  • openrecord

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (openrecord) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

OpenRecord

Build Status Coverage Status npm package version Dependency Status

A hackable, ActiveRecord-like ORM for nodejs

There are currently a hand full of nodejs ORMs available - but there is no one with a nice syntax similar to ActiveRecord (Ruby). OpenRecord has a nice syntax, a ton of features, over 1000 unit tests and could be extended easily!

Installation

npm install openrecord

Documentation

Features

  • SQLite3, MySQL, Postgres, REST and LDAP (+ ActiveDirectory) support
  • Async schema definition: You could even change your model definition temporarily
  • Optional Fibers support
  • Automatic field definition loading (SQL): You don't need to define your database fields twice! OpenRerecord will automatically load your schema definition
  • Relations (hasMany, hasOne, belongsTo with through, polymorph, cross-store)
  • Nested Cascade delete
  • Nested Eager Loading
  • Nested Creates
  • Nested Updates
  • Nested Joins
  • Validations
  • Scopes: Makro like methods
  • Before and After Hooks: For validation, find, create, update, destroy and some more...
  • Events
  • Chaining: Everything is chainable!
  • Promises
  • Migrations: SQL Migrations are build in
  • Plugin support: In fact 99% of OpenRecord is a plugin
  • Build-In SQL plugins:
    • stampable: automatically set created_at, updated_at, updater_id or creator_id
    • paranoid: Soft delete of records
    • nested set: Build trees easily
    • sorted list: Don't worry about lists
  • ... with more than 1200 tests

Usage

var OpenRecord = require('openrecord');

var sqlite = new OpenRecord({
  type: 'sqlite3',
  file: 'test.sqlite'
});


sqlite.Model('User', function(){
  this.hasMany('posts');
    
  this.scope('active', function(){
    this.where({active: true});
  });
});


sqlite.Model('Post', function(){
  this.belongsTo('user');
});


sqlite.ready(function(){
  var User = sqlite.Model('User');

  User.active().where({posts: {title_like:'openrecord' }}).include('posts').exec(function(records){
    console.log(records);
  });
});

Examples

Hooks:

sqlite.Model('User', function(){
  this.hasMany('posts');
    
  this.afterCreate(function(record, transaction, next){
    //send email
    next();
  })
});

Synchronous (via fibers)

sqlite.sync(function(){
  var user = User.find(1).exec();
  user.active = false;
  user.save();
})

Cross store relations

var sqlite = new OpenRecord({
  type: 'sqlite3',
  file: 'test.sqlite',
  global: true, //expose all Models as globals (default: false)
  name: 'sqlite'
});

rest = new OpenRecord({
  type: 'rest',
  url: 'http://api.yourservice.com',
  name: 'rest'
});

sqlite.Model('Book', function(){
  this.belongsTo('author', {store: 'rest'});
})

rest.Model('Author', function(){
  this.hasMany('books', {store: 'sqlite'});
});

sqlite.ready(function(){
  Book.include('author').where({created_at_lt:'1990-01-01'}).exec(function(books){
    //books[0].author
  })
});

Contributing

If you've found a bug please report it via the issues page. Please make sure to add a unit test with the bug report! Before submit pull request make sure all tests still passed.