Merge pull request #302 from strongloop/rename-datamodel-to-persistedmodel

[2.0] Rename DataModel to PersistedModel
This commit is contained in:
Miroslav Bajtoš 2014-06-05 20:36:08 +02:00
commit 71792b144c
19 changed files with 154 additions and 129 deletions

View File

@ -1,6 +1,6 @@
var loopback = require('../../'); var loopback = require('../../');
var CartItem = exports.CartItem = loopback.DataModel.extend('CartItem', { var CartItem = exports.CartItem = loopback.PersistedModel.extend('CartItem', {
tax: {type: Number, default: 0.1}, tax: {type: Number, default: 0.1},
price: Number, price: Number,
item: String, item: String,

View File

@ -178,10 +178,22 @@ loopback.createModel = function (name, properties, options) {
var BaseModel = options.base || options.super; var BaseModel = options.base || options.super;
if(typeof BaseModel === 'string') { if(typeof BaseModel === 'string') {
var baseName = BaseModel;
BaseModel = loopback.getModel(BaseModel); BaseModel = loopback.getModel(BaseModel);
if (BaseModel === undefined) {
if (baseName === 'DataModel') {
console.warn('Model `%s` is extending deprecated `DataModel. ' +
'Use `PeristedModel` instead.', name);
BaseModel = loopback.PersistedModel;
} else {
console.warn('Model `%s` is extending an unknown model `%s`. ' +
'Using `PersistedModel` as the base.', name, baseName);
}
}
} }
BaseModel = BaseModel || loopback.DataModel; BaseModel = BaseModel || loopback.PersistedModel;
var model = BaseModel.extend(name, properties, options); var model = BaseModel.extend(name, properties, options);
@ -337,7 +349,20 @@ loopback.autoAttachModel = function(ModelCtor) {
*/ */
loopback.Model = require('./models/model'); loopback.Model = require('./models/model');
loopback.DataModel = require('./models/data-model'); loopback.PersistedModel = require('./models/persisted-model');
// temporary alias to simplify migration of code based on <=2.0.0-beta3
Object.defineProperty(loopback, 'DataModel', {
get: function() {
var stackLines = new Error().stack.split('\n');
console.warn('loopback.DataModel is deprecated, ' +
'use loopback.PersistedModel instead.');
// Log the location where loopback.DataModel was called
console.warn(stackLines[2]);
return loopback.PersistedModel;
}
});
loopback.Email = require('./models/email'); loopback.Email = require('./models/email');
loopback.User = require('./models/user'); loopback.User = require('./models/user');
loopback.Application = require('./models/application'); loopback.Application = require('./models/application');
@ -358,7 +383,7 @@ var dataSourceTypes = {
}; };
loopback.Email.autoAttach = dataSourceTypes.MAIL; loopback.Email.autoAttach = dataSourceTypes.MAIL;
loopback.DataModel.autoAttach = dataSourceTypes.DB; loopback.PersistedModel.autoAttach = dataSourceTypes.DB;
loopback.User.autoAttach = dataSourceTypes.DB; loopback.User.autoAttach = dataSourceTypes.DB;
loopback.AccessToken.autoAttach = dataSourceTypes.DB; loopback.AccessToken.autoAttach = dataSourceTypes.DB;
loopback.Role.autoAttach = dataSourceTypes.DB; loopback.Role.autoAttach = dataSourceTypes.DB;

View File

@ -91,7 +91,7 @@ var ACLSchema = {
* @inherits Model * @inherits Model
*/ */
var ACL = loopback.DataModel.extend('ACL', ACLSchema); var ACL = loopback.PersistedModel.extend('ACL', ACLSchema);
ACL.ALL = AccessContext.ALL; ACL.ALL = AccessContext.ALL;

View File

@ -113,7 +113,7 @@ function generateKey(hmacKey, algorithm, encoding) {
* @inherits {Model} * @inherits {Model}
*/ */
var Application = loopback.DataModel.extend('Application', ApplicationSchema); var Application = loopback.PersistedModel.extend('Application', ApplicationSchema);
/*! /*!
* A hook to generate keys before creation * A hook to generate keys before creation

View File

@ -2,7 +2,7 @@
* Module Dependencies. * Module Dependencies.
*/ */
var DataModel = require('./data-model') var PersistedModel = require('./persisted-model')
, loopback = require('../loopback') , loopback = require('../loopback')
, crypto = require('crypto') , crypto = require('crypto')
, CJSON = {stringify: require('canonical-json')} , CJSON = {stringify: require('canonical-json')}
@ -45,7 +45,7 @@ var options = {
* @inherits {Model} * @inherits {Model}
*/ */
var Change = module.exports = DataModel.extend('Change', properties, options); var Change = module.exports = PersistedModel.extend('Change', properties, options);
/*! /*!
* Constants * Constants
@ -67,7 +67,7 @@ Change.Conflict = Conflict;
*/ */
Change.setup = function() { Change.setup = function() {
DataModel.setup.call(this); PersistedModel.setup.call(this);
var Change = this; var Change = this;
Change.getter.id = function() { Change.getter.id = function() {
@ -497,8 +497,8 @@ Change.prototype.getModel = function(callback) {
* **Note: call `conflict.fetch()` to get the `target` and `source` models. * **Note: call `conflict.fetch()` to get the `target` and `source` models.
* *
* @param {*} modelId * @param {*} modelId
* @param {DataModel} SourceModel * @param {PersistedModel} SourceModel
* @param {DataModel} TargetModel * @param {PersistedModel} TargetModel
* @property {ModelClass} source The source model instance * @property {ModelClass} source The source model instance
* @property {ModelClass} target The target model instance * @property {ModelClass} target The target model instance
*/ */
@ -516,8 +516,8 @@ function Conflict(modelId, SourceModel, TargetModel) {
* *
* @callback {Function} callback * @callback {Function} callback
* @param {Error} * @param {Error}
* @param {DataModel} source * @param {PersistedModel} source
* @param {DataModel} target * @param {PersistedModel} target
*/ */
Conflict.prototype.models = function(cb) { Conflict.prototype.models = function(cb) {

View File

@ -2,7 +2,7 @@
* Module Dependencies. * Module Dependencies.
*/ */
var DataModel = require('../loopback').DataModel var PersistedModel = require('../loopback').PersistedModel
, loopback = require('../loopback') , loopback = require('../loopback')
, assert = require('assert'); , assert = require('assert');
@ -32,10 +32,10 @@ var options = {
* @property sourceId {String} the source identifier * @property sourceId {String} the source identifier
* *
* @class * @class
* @inherits {DataModel} * @inherits {PersistedModel}
*/ */
var Checkpoint = module.exports = DataModel.extend('Checkpoint', properties, options); var Checkpoint = module.exports = PersistedModel.extend('Checkpoint', properties, options);
/** /**
* Get the current checkpoint id * Get the current checkpoint id

View File

@ -16,43 +16,43 @@ var async = require('async');
* Listen for model changes using the `change` event. * Listen for model changes using the `change` event.
* *
* ```js * ```js
* MyDataModel.on('changed', function(obj) { * MyPersistedModel.on('changed', function(obj) {
* console.log(obj) // => the changed model * console.log(obj) // => the changed model
* }); * });
* ``` * ```
* *
* @class DataModel * @class PersistedModel
* @param {Object} data * @param {Object} data
* @param {Number} data.id The default id property * @param {Number} data.id The default id property
*/ */
var DataModel = module.exports = Model.extend('DataModel'); var PersistedModel = module.exports = Model.extend('PersistedModel');
/*! /*!
* Setup the `DataModel` constructor. * Setup the `PersistedModel` constructor.
*/ */
DataModel.setup = function setupDataModel() { PersistedModel.setup = function setupPersistedModel() {
// call Model.setup first // call Model.setup first
Model.setup.call(this); Model.setup.call(this);
var DataModel = this; var PersistedModel = this;
var typeName = this.modelName; var typeName = this.modelName;
// setup a remoting type converter for this model // setup a remoting type converter for this model
RemoteObjects.convert(typeName, function(val) { RemoteObjects.convert(typeName, function(val) {
return val ? new DataModel(val) : val; return val ? new PersistedModel(val) : val;
}); });
// enable change tracking (usually for replication) // enable change tracking (usually for replication)
if(this.settings.trackChanges) { if(this.settings.trackChanges) {
DataModel._defineChangeModel(); PersistedModel._defineChangeModel();
DataModel.once('dataSourceAttached', function() { PersistedModel.once('dataSourceAttached', function() {
DataModel.enableChangeTracking(); PersistedModel.enableChangeTracking();
}); });
} }
DataModel.setupRemoting(); PersistedModel.setupRemoting();
} }
/*! /*!
@ -63,7 +63,7 @@ function throwNotAttached(modelName, methodName) {
throw new Error( throw new Error(
'Cannot call ' + modelName + '.'+ methodName + '().' 'Cannot call ' + modelName + '.'+ methodName + '().'
+ ' The ' + methodName + ' method has not been setup.' + ' The ' + methodName + ' method has not been setup.'
+ ' The DataModel has not been correctly attached to a DataSource!' + ' The PersistedModel has not been correctly attached to a DataSource!'
); );
} }
@ -95,7 +95,7 @@ function convertNullToNotFoundError(ctx, cb) {
* - instance (null or Model) * - instance (null or Model)
*/ */
DataModel.create = function (data, callback) { PersistedModel.create = function (data, callback) {
throwNotAttached(this.modelName, 'create'); throwNotAttached(this.modelName, 'create');
}; };
@ -105,7 +105,7 @@ DataModel.create = function (data, callback) {
* @param {Function} [callback] The callback function * @param {Function} [callback] The callback function
*/ */
DataModel.upsert = DataModel.updateOrCreate = function upsert(data, callback) { PersistedModel.upsert = PersistedModel.updateOrCreate = function upsert(data, callback) {
throwNotAttached(this.modelName, 'upsert'); throwNotAttached(this.modelName, 'upsert');
}; };
@ -118,7 +118,7 @@ DataModel.upsert = DataModel.updateOrCreate = function upsert(data, callback) {
* @param {Function} cb - callback called with (err, instance) * @param {Function} cb - callback called with (err, instance)
*/ */
DataModel.findOrCreate = function findOrCreate(query, data, callback) { PersistedModel.findOrCreate = function findOrCreate(query, data, callback) {
throwNotAttached(this.modelName, 'findOrCreate'); throwNotAttached(this.modelName, 'findOrCreate');
}; };
@ -129,7 +129,7 @@ DataModel.findOrCreate = function findOrCreate(query, data, callback) {
* @param {Function} cb - callbacl called with (err, exists: Bool) * @param {Function} cb - callbacl called with (err, exists: Bool)
*/ */
DataModel.exists = function exists(id, cb) { PersistedModel.exists = function exists(id, cb) {
throwNotAttached(this.modelName, 'exists'); throwNotAttached(this.modelName, 'exists');
}; };
@ -140,7 +140,7 @@ DataModel.exists = function exists(id, cb) {
* @param {Function} cb - callback called with (err, instance) * @param {Function} cb - callback called with (err, instance)
*/ */
DataModel.findById = function find(id, cb) { PersistedModel.findById = function find(id, cb) {
throwNotAttached(this.modelName, 'findById'); throwNotAttached(this.modelName, 'findById');
}; };
@ -151,7 +151,7 @@ DataModel.findById = function find(id, cb) {
* @param {Object} params (optional) * @param {Object} params (optional)
* *
* - where: Object `{ key: val, key2: {gt: 'val2'}}` * - where: Object `{ key: val, key2: {gt: 'val2'}}`
* - include: String, Object or Array. See DataModel.include documentation. * - include: String, Object or Array. See PersistedModel.include documentation.
* - order: String * - order: String
* - limit: Number * - limit: Number
* - skip: Number * - skip: Number
@ -162,7 +162,7 @@ DataModel.findById = function find(id, cb) {
* - Array of instances * - Array of instances
*/ */
DataModel.find = function find(params, cb) { PersistedModel.find = function find(params, cb) {
throwNotAttached(this.modelName, 'find'); throwNotAttached(this.modelName, 'find');
}; };
@ -173,7 +173,7 @@ DataModel.find = function find(params, cb) {
* @param {Function} cb - callback called with (err, instance) * @param {Function} cb - callback called with (err, instance)
*/ */
DataModel.findOne = function findOne(params, cb) { PersistedModel.findOne = function findOne(params, cb) {
throwNotAttached(this.modelName, 'findOne'); throwNotAttached(this.modelName, 'findOne');
}; };
@ -183,9 +183,9 @@ DataModel.findOne = function findOne(params, cb) {
* @param {Function} [cb] - callback called with (err) * @param {Function} [cb] - callback called with (err)
*/ */
DataModel.remove = PersistedModel.remove =
DataModel.deleteAll = PersistedModel.deleteAll =
DataModel.destroyAll = function destroyAll(where, cb) { PersistedModel.destroyAll = function destroyAll(where, cb) {
throwNotAttached(this.modelName, 'destroyAll'); throwNotAttached(this.modelName, 'destroyAll');
}; };
@ -195,9 +195,9 @@ DataModel.destroyAll = function destroyAll(where, cb) {
* @param {Function} cb - callback called with (err) * @param {Function} cb - callback called with (err)
*/ */
DataModel.removeById = PersistedModel.removeById =
DataModel.deleteById = PersistedModel.deleteById =
DataModel.destroyById = function deleteById(id, cb) { PersistedModel.destroyById = function deleteById(id, cb) {
throwNotAttached(this.modelName, 'deleteById'); throwNotAttached(this.modelName, 'deleteById');
}; };
@ -208,7 +208,7 @@ DataModel.destroyById = function deleteById(id, cb) {
* @param {Function} cb - callback, called with (err, count) * @param {Function} cb - callback, called with (err, count)
*/ */
DataModel.count = function (where, cb) { PersistedModel.count = function (where, cb) {
throwNotAttached(this.modelName, 'count'); throwNotAttached(this.modelName, 'count');
}; };
@ -219,7 +219,7 @@ DataModel.count = function (where, cb) {
* @param callback(err, obj) * @param callback(err, obj)
*/ */
DataModel.prototype.save = function (options, callback) { PersistedModel.prototype.save = function (options, callback) {
var Model = this.constructor; var Model = this.constructor;
if (typeof options == 'function') { if (typeof options == 'function') {
@ -286,7 +286,7 @@ DataModel.prototype.save = function (options, callback) {
* @returns {Boolean} * @returns {Boolean}
*/ */
DataModel.prototype.isNewRecord = function () { PersistedModel.prototype.isNewRecord = function () {
throwNotAttached(this.constructor.modelName, 'isNewRecord'); throwNotAttached(this.constructor.modelName, 'isNewRecord');
}; };
@ -296,13 +296,13 @@ DataModel.prototype.isNewRecord = function () {
* @triggers `destroy` hook (async) before and after destroying object * @triggers `destroy` hook (async) before and after destroying object
*/ */
DataModel.prototype.remove = PersistedModel.prototype.remove =
DataModel.prototype.delete = PersistedModel.prototype.delete =
DataModel.prototype.destroy = function (cb) { PersistedModel.prototype.destroy = function (cb) {
throwNotAttached(this.constructor.modelName, 'destroy'); throwNotAttached(this.constructor.modelName, 'destroy');
}; };
DataModel.prototype.destroy._delegate = true; PersistedModel.prototype.destroy._delegate = true;
/** /**
* Update single attribute * Update single attribute
@ -314,7 +314,7 @@ DataModel.prototype.destroy._delegate = true;
* @param {Function} callback - callback called with (err, instance) * @param {Function} callback - callback called with (err, instance)
*/ */
DataModel.prototype.updateAttribute = function updateAttribute(name, value, callback) { PersistedModel.prototype.updateAttribute = function updateAttribute(name, value, callback) {
throwNotAttached(this.constructor.modelName, 'updateAttribute'); throwNotAttached(this.constructor.modelName, 'updateAttribute');
}; };
@ -328,7 +328,7 @@ DataModel.prototype.updateAttribute = function updateAttribute(name, value, call
* @param {Function} callback - callback called with (err, instance) * @param {Function} callback - callback called with (err, instance)
*/ */
DataModel.prototype.updateAttributes = function updateAttributes(data, cb) { PersistedModel.prototype.updateAttributes = function updateAttributes(data, cb) {
throwNotAttached(this.modelName, 'updateAttributes'); throwNotAttached(this.modelName, 'updateAttributes');
}; };
@ -339,12 +339,12 @@ DataModel.prototype.updateAttributes = function updateAttributes(data, cb) {
* @param {Function} callback - called with (err, instance) arguments * @param {Function} callback - called with (err, instance) arguments
*/ */
DataModel.prototype.reload = function reload(callback) { PersistedModel.prototype.reload = function reload(callback) {
throwNotAttached(this.constructor.modelName, 'reload'); throwNotAttached(this.constructor.modelName, 'reload');
}; };
/** /**
* Set the correct `id` property for the `DataModel`. If a `Connector` defines * Set the correct `id` property for the `PersistedModel`. If a `Connector` defines
* a `setId` method it will be used. Otherwise the default lookup is used. You * a `setId` method it will be used. Otherwise the default lookup is used. You
* should override this method to handle complex ids. * should override this method to handle complex ids.
* *
@ -352,18 +352,18 @@ DataModel.prototype.reload = function reload(callback) {
* specifies. * specifies.
*/ */
DataModel.prototype.setId = function(val) { PersistedModel.prototype.setId = function(val) {
var ds = this.getDataSource(); var ds = this.getDataSource();
this[this.getIdName()] = val; this[this.getIdName()] = val;
} }
/** /**
* Get the `id` value for the `DataModel`. * Get the `id` value for the `PersistedModel`.
* *
* @returns {*} The `id` value * @returns {*} The `id` value
*/ */
DataModel.prototype.getId = function() { PersistedModel.prototype.getId = function() {
var data = this.toObject(); var data = this.toObject();
if(!data) return; if(!data) return;
return data[this.getIdName()]; return data[this.getIdName()];
@ -375,7 +375,7 @@ DataModel.prototype.getId = function() {
* @returns {String} The `id` property name * @returns {String} The `id` property name
*/ */
DataModel.prototype.getIdName = function() { PersistedModel.prototype.getIdName = function() {
return this.constructor.getIdName(); return this.constructor.getIdName();
} }
@ -385,7 +385,7 @@ DataModel.prototype.getIdName = function() {
* @returns {String} The `id` property name * @returns {String} The `id` property name
*/ */
DataModel.getIdName = function() { PersistedModel.getIdName = function() {
var Model = this; var Model = this;
var ds = Model.getDataSource(); var ds = Model.getDataSource();
@ -396,40 +396,40 @@ DataModel.getIdName = function() {
} }
} }
DataModel.setupRemoting = function() { PersistedModel.setupRemoting = function() {
var DataModel = this; var PersistedModel = this;
var typeName = DataModel.modelName; var typeName = PersistedModel.modelName;
var options = DataModel.settings; var options = PersistedModel.settings;
function setRemoting(scope, name, options) { function setRemoting(scope, name, options) {
var fn = scope[name]; var fn = scope[name];
fn._delegate = true; fn._delegate = true;
options.isStatic = scope === DataModel; options.isStatic = scope === PersistedModel;
DataModel.remoteMethod(name, options); PersistedModel.remoteMethod(name, options);
} }
setRemoting(DataModel, 'create', { setRemoting(PersistedModel, 'create', {
description: 'Create a new instance of the model and persist it into the data source', description: 'Create a new instance of the model and persist it into the data source',
accepts: {arg: 'data', type: 'object', description: 'Model instance data', http: {source: 'body'}}, accepts: {arg: 'data', type: 'object', description: 'Model instance data', http: {source: 'body'}},
returns: {arg: 'data', type: typeName, root: true}, returns: {arg: 'data', type: typeName, root: true},
http: {verb: 'post', path: '/'} http: {verb: 'post', path: '/'}
}); });
setRemoting(DataModel, 'upsert', { setRemoting(PersistedModel, 'upsert', {
description: 'Update an existing model instance or insert a new one into the data source', description: 'Update an existing model instance or insert a new one into the data source',
accepts: {arg: 'data', type: 'object', description: 'Model instance data', http: {source: 'body'}}, accepts: {arg: 'data', type: 'object', description: 'Model instance data', http: {source: 'body'}},
returns: {arg: 'data', type: typeName, root: true}, returns: {arg: 'data', type: typeName, root: true},
http: {verb: 'put', path: '/'} http: {verb: 'put', path: '/'}
}); });
setRemoting(DataModel, 'exists', { setRemoting(PersistedModel, 'exists', {
description: 'Check whether a model instance exists in the data source', description: 'Check whether a model instance exists in the data source',
accepts: {arg: 'id', type: 'any', description: 'Model id', required: true}, accepts: {arg: 'id', type: 'any', description: 'Model id', required: true},
returns: {arg: 'exists', type: 'boolean'}, returns: {arg: 'exists', type: 'boolean'},
http: {verb: 'get', path: '/:id/exists'} http: {verb: 'get', path: '/:id/exists'}
}); });
setRemoting(DataModel, 'findById', { setRemoting(PersistedModel, 'findById', {
description: 'Find a model instance by id from the data source', description: 'Find a model instance by id from the data source',
accepts: { accepts: {
arg: 'id', type: 'any', description: 'Model id', required: true, arg: 'id', type: 'any', description: 'Model id', required: true,
@ -440,42 +440,42 @@ DataModel.setupRemoting = function() {
rest: {after: convertNullToNotFoundError} rest: {after: convertNullToNotFoundError}
}); });
setRemoting(DataModel, 'find', { setRemoting(PersistedModel, 'find', {
description: 'Find all instances of the model matched by filter from the data source', description: 'Find all instances of the model matched by filter from the data source',
accepts: {arg: 'filter', type: 'object', description: 'Filter defining fields, where, orderBy, offset, and limit'}, accepts: {arg: 'filter', type: 'object', description: 'Filter defining fields, where, orderBy, offset, and limit'},
returns: {arg: 'data', type: [typeName], root: true}, returns: {arg: 'data', type: [typeName], root: true},
http: {verb: 'get', path: '/'} http: {verb: 'get', path: '/'}
}); });
setRemoting(DataModel, 'findOne', { setRemoting(PersistedModel, 'findOne', {
description: 'Find first instance of the model matched by filter from the data source', description: 'Find first instance of the model matched by filter from the data source',
accepts: {arg: 'filter', type: 'object', description: 'Filter defining fields, where, orderBy, offset, and limit'}, accepts: {arg: 'filter', type: 'object', description: 'Filter defining fields, where, orderBy, offset, and limit'},
returns: {arg: 'data', type: typeName, root: true}, returns: {arg: 'data', type: typeName, root: true},
http: {verb: 'get', path: '/findOne'} http: {verb: 'get', path: '/findOne'}
}); });
setRemoting(DataModel, 'destroyAll', { setRemoting(PersistedModel, 'destroyAll', {
description: 'Delete all matching records', description: 'Delete all matching records',
accepts: {arg: 'where', type: 'object', description: 'filter.where object'}, accepts: {arg: 'where', type: 'object', description: 'filter.where object'},
http: {verb: 'del', path: '/'}, http: {verb: 'del', path: '/'},
shared: false shared: false
}); });
setRemoting(DataModel, 'removeById', { setRemoting(PersistedModel, 'removeById', {
description: 'Delete a model instance by id from the data source', description: 'Delete a model instance by id from the data source',
accepts: {arg: 'id', type: 'any', description: 'Model id', required: true, accepts: {arg: 'id', type: 'any', description: 'Model id', required: true,
http: {source: 'path'}}, http: {source: 'path'}},
http: {verb: 'del', path: '/:id'} http: {verb: 'del', path: '/:id'}
}); });
setRemoting(DataModel, 'count', { setRemoting(PersistedModel, 'count', {
description: 'Count instances of the model matched by where from the data source', description: 'Count instances of the model matched by where from the data source',
accepts: {arg: 'where', type: 'object', description: 'Criteria to match model instances'}, accepts: {arg: 'where', type: 'object', description: 'Criteria to match model instances'},
returns: {arg: 'count', type: 'number'}, returns: {arg: 'count', type: 'number'},
http: {verb: 'get', path: '/count'} http: {verb: 'get', path: '/count'}
}); });
setRemoting(DataModel.prototype, 'updateAttributes', { setRemoting(PersistedModel.prototype, 'updateAttributes', {
description: 'Update attributes for a model instance and persist it into the data source', description: 'Update attributes for a model instance and persist it into the data source',
accepts: {arg: 'data', type: 'object', http: {source: 'body'}, description: 'An object of model property name/value pairs'}, accepts: {arg: 'data', type: 'object', http: {source: 'body'}, description: 'An object of model property name/value pairs'},
returns: {arg: 'data', type: typeName, root: true}, returns: {arg: 'data', type: typeName, root: true},
@ -483,7 +483,7 @@ DataModel.setupRemoting = function() {
}); });
if(options.trackChanges) { if(options.trackChanges) {
setRemoting(DataModel, 'diff', { setRemoting(PersistedModel, 'diff', {
description: 'Get a set of deltas and conflicts since the given checkpoint', description: 'Get a set of deltas and conflicts since the given checkpoint',
accepts: [ accepts: [
{arg: 'since', type: 'number', description: 'Find deltas since this checkpoint'}, {arg: 'since', type: 'number', description: 'Find deltas since this checkpoint'},
@ -494,7 +494,7 @@ DataModel.setupRemoting = function() {
http: {verb: 'post', path: '/diff'} http: {verb: 'post', path: '/diff'}
}); });
setRemoting(DataModel, 'changes', { setRemoting(PersistedModel, 'changes', {
description: 'Get the changes to a model since a given checkpoint.' description: 'Get the changes to a model since a given checkpoint.'
+ 'Provide a filter object to reduce the number of results returned.', + 'Provide a filter object to reduce the number of results returned.',
accepts: [ accepts: [
@ -505,37 +505,37 @@ DataModel.setupRemoting = function() {
http: {verb: 'get', path: '/changes'} http: {verb: 'get', path: '/changes'}
}); });
setRemoting(DataModel, 'checkpoint', { setRemoting(PersistedModel, 'checkpoint', {
description: 'Create a checkpoint.', description: 'Create a checkpoint.',
returns: {arg: 'checkpoint', type: 'object', root: true}, returns: {arg: 'checkpoint', type: 'object', root: true},
http: {verb: 'post', path: '/checkpoint'} http: {verb: 'post', path: '/checkpoint'}
}); });
setRemoting(DataModel, 'currentCheckpoint', { setRemoting(PersistedModel, 'currentCheckpoint', {
description: 'Get the current checkpoint.', description: 'Get the current checkpoint.',
returns: {arg: 'checkpoint', type: 'object', root: true}, returns: {arg: 'checkpoint', type: 'object', root: true},
http: {verb: 'get', path: '/checkpoint'} http: {verb: 'get', path: '/checkpoint'}
}); });
setRemoting(DataModel, 'createUpdates', { setRemoting(PersistedModel, 'createUpdates', {
description: 'Create an update list from a delta list', description: 'Create an update list from a delta list',
accepts: {arg: 'deltas', type: 'array', http: {source: 'body'}}, accepts: {arg: 'deltas', type: 'array', http: {source: 'body'}},
returns: {arg: 'updates', type: 'array', root: true}, returns: {arg: 'updates', type: 'array', root: true},
http: {verb: 'post', path: '/create-updates'} http: {verb: 'post', path: '/create-updates'}
}); });
setRemoting(DataModel, 'bulkUpdate', { setRemoting(PersistedModel, 'bulkUpdate', {
description: 'Run multiple updates at once. Note: this is not atomic.', description: 'Run multiple updates at once. Note: this is not atomic.',
accepts: {arg: 'updates', type: 'array'}, accepts: {arg: 'updates', type: 'array'},
http: {verb: 'post', path: '/bulk-update'} http: {verb: 'post', path: '/bulk-update'}
}); });
setRemoting(DataModel, 'rectifyAllChanges', { setRemoting(PersistedModel, 'rectifyAllChanges', {
description: 'Rectify all Model changes.', description: 'Rectify all Model changes.',
http: {verb: 'post', path: '/rectify-all'} http: {verb: 'post', path: '/rectify-all'}
}); });
setRemoting(DataModel, 'rectifyChange', { setRemoting(PersistedModel, 'rectifyChange', {
description: 'Tell loopback that a change to the model with the given id has occurred.', description: 'Tell loopback that a change to the model with the given id has occurred.',
accepts: {arg: 'id', type: 'any', http: {source: 'path'}}, accepts: {arg: 'id', type: 'any', http: {source: 'path'}},
http: {verb: 'post', path: '/:id/rectify-change'} http: {verb: 'post', path: '/:id/rectify-change'}
@ -553,7 +553,7 @@ DataModel.setupRemoting = function() {
* @param {Function} callback * @param {Function} callback
*/ */
DataModel.diff = function(since, remoteChanges, callback) { PersistedModel.diff = function(since, remoteChanges, callback) {
var Change = this.getChangeModel(); var Change = this.getChangeModel();
Change.diff(this.modelName, since, remoteChanges, callback); Change.diff(this.modelName, since, remoteChanges, callback);
} }
@ -570,7 +570,7 @@ DataModel.diff = function(since, remoteChanges, callback) {
* @end * @end
*/ */
DataModel.changes = function(since, filter, callback) { PersistedModel.changes = function(since, filter, callback) {
if(typeof since === 'function') { if(typeof since === 'function') {
filter = {}; filter = {};
callback = since; callback = since;
@ -620,7 +620,7 @@ DataModel.changes = function(since, filter, callback) {
* @param {Function} callback * @param {Function} callback
*/ */
DataModel.checkpoint = function(cb) { PersistedModel.checkpoint = function(cb) {
var Checkpoint = this.getChangeModel().getCheckpointModel(); var Checkpoint = this.getChangeModel().getCheckpointModel();
this.getSourceId(function(err, sourceId) { this.getSourceId(function(err, sourceId) {
if(err) return cb(err); if(err) return cb(err);
@ -639,7 +639,7 @@ DataModel.checkpoint = function(cb) {
* @end * @end
*/ */
DataModel.currentCheckpoint = function(cb) { PersistedModel.currentCheckpoint = function(cb) {
var Checkpoint = this.getChangeModel().getCheckpointModel(); var Checkpoint = this.getChangeModel().getCheckpointModel();
Checkpoint.current(cb); Checkpoint.current(cb);
} }
@ -657,7 +657,7 @@ DataModel.currentCheckpoint = function(cb) {
* due to conflicts. * due to conflicts.
*/ */
DataModel.replicate = function(since, targetModel, options, callback) { PersistedModel.replicate = function(since, targetModel, options, callback) {
var lastArg = arguments[arguments.length - 1]; var lastArg = arguments[arguments.length - 1];
if(typeof lastArg === 'function' && arguments.length > 1) { if(typeof lastArg === 'function' && arguments.length > 1) {
@ -750,7 +750,7 @@ DataModel.replicate = function(since, targetModel, options, callback) {
* @param {Function} callback * @param {Function} callback
*/ */
DataModel.createUpdates = function(deltas, cb) { PersistedModel.createUpdates = function(deltas, cb) {
var Change = this.getChangeModel(); var Change = this.getChangeModel();
var updates = []; var updates = [];
var Model = this; var Model = this;
@ -802,7 +802,7 @@ DataModel.createUpdates = function(deltas, cb) {
* @param {Function} callback * @param {Function} callback
*/ */
DataModel.bulkUpdate = function(updates, callback) { PersistedModel.bulkUpdate = function(updates, callback) {
var tasks = []; var tasks = [];
var Model = this; var Model = this;
var idName = this.dataSource.idName(this.modelName); var idName = this.dataSource.idName(this.modelName);
@ -838,7 +838,7 @@ DataModel.bulkUpdate = function(updates, callback) {
* @return {Change} * @return {Change}
*/ */
DataModel.getChangeModel = function() { PersistedModel.getChangeModel = function() {
var changeModel = this.Change; var changeModel = this.Change;
var isSetup = changeModel && changeModel.dataSource; var isSetup = changeModel && changeModel.dataSource;
@ -855,7 +855,7 @@ DataModel.getChangeModel = function() {
* @param {String} sourceId * @param {String} sourceId
*/ */
DataModel.getSourceId = function(cb) { PersistedModel.getSourceId = function(cb) {
var dataSource = this.dataSource; var dataSource = this.dataSource;
if(!dataSource) { if(!dataSource) {
this.once('dataSourceAttached', this.getSourceId.bind(this, cb)); this.once('dataSourceAttached', this.getSourceId.bind(this, cb));
@ -872,7 +872,7 @@ DataModel.getSourceId = function(cb) {
* Enable the tracking of changes made to the model. Usually for replication. * Enable the tracking of changes made to the model. Usually for replication.
*/ */
DataModel.enableChangeTracking = function() { PersistedModel.enableChangeTracking = function() {
var Model = this; var Model = this;
var Change = this.Change || this._defineChangeModel(); var Change = this.Change || this._defineChangeModel();
var cleanupInterval = Model.settings.changeCleanupInterval || 30000; var cleanupInterval = Model.settings.changeCleanupInterval || 30000;
@ -911,7 +911,7 @@ DataModel.enableChangeTracking = function() {
} }
} }
DataModel._defineChangeModel = function() { PersistedModel._defineChangeModel = function() {
var BaseChangeModel = require('./change'); var BaseChangeModel = require('./change');
return this.Change = BaseChangeModel.extend(this.modelName + '-change', return this.Change = BaseChangeModel.extend(this.modelName + '-change',
{}, {},
@ -921,7 +921,7 @@ DataModel._defineChangeModel = function() {
); );
} }
DataModel.rectifyAllChanges = function(callback) { PersistedModel.rectifyAllChanges = function(callback) {
this.getChangeModel().rectifyAll(callback); this.getChangeModel().rectifyAll(callback);
} }
@ -932,7 +932,7 @@ DataModel.rectifyAllChanges = function(callback) {
* @param {Error} err * @param {Error} err
*/ */
DataModel.handleChangeError = function(err) { PersistedModel.handleChangeError = function(err) {
if(err) { if(err) {
console.error(Model.modelName + ' Change Tracking Error:'); console.error(Model.modelName + ' Change Tracking Error:');
console.error(err); console.error(err);
@ -947,9 +947,9 @@ DataModel.handleChangeError = function(err) {
* @param {Error} err * @param {Error} err
*/ */
DataModel.rectifyChange = function(id, callback) { PersistedModel.rectifyChange = function(id, callback) {
var Change = this.getChangeModel(); var Change = this.getChangeModel();
Change.rectifyModelChanges(this.modelName, [id], callback); Change.rectifyModelChanges(this.modelName, [id], callback);
} }
DataModel.setup(); PersistedModel.setup();

View File

@ -2,7 +2,7 @@
* Module Dependencies. * Module Dependencies.
*/ */
var DataModel = require('../loopback').DataModel var PersistedModel = require('../loopback').PersistedModel
, loopback = require('../loopback') , loopback = require('../loopback')
, path = require('path') , path = require('path')
, SALT_WORK_FACTOR = 10 , SALT_WORK_FACTOR = 10
@ -126,7 +126,7 @@ var options = {
* @inherits {Model} * @inherits {Model}
*/ */
var User = module.exports = DataModel.extend('User', properties, options); var User = module.exports = PersistedModel.extend('User', properties, options);
/** /**
* Login a user by with the given `credentials`. * Login a user by with the given `credentials`.
@ -415,7 +415,7 @@ User.resetPassword = function(options, cb) {
User.setup = function () { User.setup = function () {
// We need to call the base class's setup method // We need to call the base class's setup method
DataModel.setup.call(this); PersistedModel.setup.call(this);
var UserModel = this; var UserModel = this;
// max ttl // max ttl

View File

@ -125,7 +125,7 @@ function createTestApp(testToken, done) {
app.use(loopback.rest()); app.use(loopback.rest());
app.enableAuth(); app.enableAuth();
var TestModel = loopback.DataModel.extend('test', {}, { var TestModel = loopback.PersistedModel.extend('test', {}, {
acls: [ acls: [
{ {
principalType: "ROLE", principalType: "ROLE",

View File

@ -22,7 +22,7 @@ before(function() {
describe('security scopes', function () { describe('security scopes', function () {
beforeEach(function() { beforeEach(function() {
var ds = this.ds = loopback.createDataSource({connector: loopback.Memory}); var ds = this.ds = loopback.createDataSource({connector: loopback.Memory});
testModel = loopback.DataModel.extend('testModel'); testModel = loopback.PersistedModel.extend('testModel');
ACL.attachTo(ds); ACL.attachTo(ds);
Role.attachTo(ds); Role.attachTo(ds);
RoleMapping.attachTo(ds); RoleMapping.attachTo(ds);

View File

@ -1,7 +1,7 @@
var path = require('path'); var path = require('path');
var SIMPLE_APP = path.join(__dirname, 'fixtures', 'simple-app'); var SIMPLE_APP = path.join(__dirname, 'fixtures', 'simple-app');
var loopback = require('../'); var loopback = require('../');
var DataModel = loopback.DataModel; var PersistedModel = loopback.PersistedModel;
var describe = require('./util/describe'); var describe = require('./util/describe');
var it = require('./util/it'); var it = require('./util/it');
@ -16,7 +16,7 @@ describe('app', function() {
}); });
it("Expose a `Model` to remote clients", function() { it("Expose a `Model` to remote clients", function() {
var Color = DataModel.extend('color', {name: String}); var Color = PersistedModel.extend('color', {name: String});
app.model(Color); app.model(Color);
Color.attachTo(db); Color.attachTo(db);
@ -24,14 +24,14 @@ describe('app', function() {
}); });
it('uses singlar name as app.remoteObjects() key', function() { it('uses singlar name as app.remoteObjects() key', function() {
var Color = DataModel.extend('color', {name: String}); var Color = PersistedModel.extend('color', {name: String});
app.model(Color); app.model(Color);
Color.attachTo(db); Color.attachTo(db);
expect(app.remoteObjects()).to.eql({ color: Color }); expect(app.remoteObjects()).to.eql({ color: Color });
}); });
it('uses singular name as shared class name', function() { it('uses singular name as shared class name', function() {
var Color = DataModel.extend('color', {name: String}); var Color = PersistedModel.extend('color', {name: String});
app.model(Color); app.model(Color);
Color.attachTo(db); Color.attachTo(db);
var classes = app.remotes().classes().map(function(c) {return c.name}); var classes = app.remotes().classes().map(function(c) {return c.name});
@ -42,7 +42,7 @@ describe('app', function() {
app.use(loopback.rest()); app.use(loopback.rest());
request(app).get('/colors').expect(404, function(err, res) { request(app).get('/colors').expect(404, function(err, res) {
if (err) return done(err); if (err) return done(err);
var Color = DataModel.extend('color', {name: String}); var Color = PersistedModel.extend('color', {name: String});
app.model(Color); app.model(Color);
Color.attachTo(db); Color.attachTo(db);
request(app).get('/colors').expect(200, done); request(app).get('/colors').expect(200, done);

View File

@ -6,7 +6,7 @@ describe('Change', function(){
var memory = loopback.createDataSource({ var memory = loopback.createDataSource({
connector: loopback.Memory connector: loopback.Memory
}); });
TestModel = loopback.DataModel.extend('chtest', {}, { TestModel = loopback.PersistedModel.extend('chtest', {}, {
trackChanges: true trackChanges: true
}); });
this.modelName = TestModel.modelName; this.modelName = TestModel.modelName;

View File

@ -36,9 +36,9 @@ describe('DataSource', function() {
}); });
}); });
describe.skip('DataModel Methods', function() { describe.skip('PersistedModel Methods', function() {
it("List the enabled and disabled methods", function() { it("List the enabled and disabled methods", function() {
var TestModel = loopback.DataModel.extend('TestDataModel'); var TestModel = loopback.PersistedModel.extend('TestPersistedModel');
TestModel.attachTo(loopback.memory()); TestModel.attachTo(loopback.memory());
// assert the defaults // assert the defaults

View File

@ -1,6 +1,6 @@
var loopback = require('../../../'); var loopback = require('../../../');
var DataModel = loopback.DataModel; var PersistedModel = loopback.PersistedModel;
exports.TestModel = DataModel.extend('TestModel', {}, { exports.TestModel = PersistedModel.extend('TestModel', {}, {
trackChanges: true trackChanges: true
}); });

View File

@ -3,13 +3,13 @@ var loopback = require('../');
describe('hidden properties', function () { describe('hidden properties', function () {
beforeEach(function (done) { beforeEach(function (done) {
var app = this.app = loopback(); var app = this.app = loopback();
var Product = this.Product = loopback.DataModel.extend('product', var Product = this.Product = loopback.PersistedModel.extend('product',
{}, {},
{hidden: ['secret']} {hidden: ['secret']}
); );
Product.attachTo(loopback.memory()); Product.attachTo(loopback.memory());
var Category = this.Category = loopback.DataModel.extend('category'); var Category = this.Category = loopback.PersistedModel.extend('category');
Category.attachTo(loopback.memory()); Category.attachTo(loopback.memory());
Category.hasMany(Product); Category.hasMany(Product);

View File

@ -3,11 +3,11 @@ var loopback = require('../');
var ACL = loopback.ACL; var ACL = loopback.ACL;
var Change = loopback.Change; var Change = loopback.Change;
var defineModelTestsWithDataSource = require('./util/model-tests'); var defineModelTestsWithDataSource = require('./util/model-tests');
var DataModel = loopback.DataModel; var PersistedModel = loopback.PersistedModel;
var describe = require('./util/describe'); var describe = require('./util/describe');
describe('Model / DataModel', function() { describe('Model / PersistedModel', function() {
defineModelTestsWithDataSource({ defineModelTestsWithDataSource({
dataSource: { dataSource: {
connector: loopback.Memory connector: loopback.Memory
@ -16,7 +16,7 @@ describe('Model / DataModel', function() {
describe('Model.validatesUniquenessOf(property, options)', function() { describe('Model.validatesUniquenessOf(property, options)', function() {
it("Ensure the value for `property` is unique", function(done) { it("Ensure the value for `property` is unique", function(done) {
var User = DataModel.extend('user', { var User = PersistedModel.extend('user', {
'first': String, 'first': String,
'last': String, 'last': String,
'age': Number, 'age': Number,
@ -71,7 +71,7 @@ describe.onServer('Remote Methods', function(){
var app; var app;
beforeEach(function () { beforeEach(function () {
User = DataModel.extend('user', { User = PersistedModel.extend('user', {
'first': String, 'first': String,
'last': String, 'last': String,
'age': Number, 'age': Number,
@ -362,7 +362,7 @@ describe.onServer('Remote Methods', function(){
describe('Model.extend()', function(){ describe('Model.extend()', function(){
it('Create a new model by extending an existing model', function() { it('Create a new model by extending an existing model', function() {
var User = loopback.DataModel.extend('test-user', { var User = loopback.PersistedModel.extend('test-user', {
email: String email: String
}); });

View File

@ -32,7 +32,7 @@ describe('RemoteConnector', function() {
var test = this; var test = this;
remoteApp = this.remoteApp = loopback(); remoteApp = this.remoteApp = loopback();
remoteApp.use(loopback.rest()); remoteApp.use(loopback.rest());
var ServerModel = this.ServerModel = loopback.DataModel.extend('TestModel'); var ServerModel = this.ServerModel = loopback.PersistedModel.extend('TestModel');
remoteApp.model(ServerModel); remoteApp.model(ServerModel);
@ -48,7 +48,7 @@ describe('RemoteConnector', function() {
it('should support the save method', function (done) { it('should support the save method', function (done) {
var calledServerCreate = false; var calledServerCreate = false;
var RemoteModel = loopback.DataModel.extend('TestModel'); var RemoteModel = loopback.PersistedModel.extend('TestModel');
RemoteModel.attachTo(this.remote); RemoteModel.attachTo(this.remote);
var ServerModel = this.ServerModel; var ServerModel = this.ServerModel;

View File

@ -3,7 +3,7 @@ var loopback = require('../');
var ACL = loopback.ACL; var ACL = loopback.ACL;
var Change = loopback.Change; var Change = loopback.Change;
var defineModelTestsWithDataSource = require('./util/model-tests'); var defineModelTestsWithDataSource = require('./util/model-tests');
var DataModel = loopback.DataModel; var PersistedModel = loopback.PersistedModel;
describe('Replication / Change APIs', function() { describe('Replication / Change APIs', function() {
beforeEach(function() { beforeEach(function() {
@ -11,12 +11,12 @@ describe('Replication / Change APIs', function() {
var dataSource = this.dataSource = loopback.createDataSource({ var dataSource = this.dataSource = loopback.createDataSource({
connector: loopback.Memory connector: loopback.Memory
}); });
var SourceModel = this.SourceModel = DataModel.extend('SourceModel', {}, { var SourceModel = this.SourceModel = PersistedModel.extend('SourceModel', {}, {
trackChanges: true trackChanges: true
}); });
SourceModel.attachTo(dataSource); SourceModel.attachTo(dataSource);
var TargetModel = this.TargetModel = DataModel.extend('TargetModel', {}, { var TargetModel = this.TargetModel = PersistedModel.extend('TargetModel', {}, {
trackChanges: true trackChanges: true
}); });
TargetModel.attachTo(dataSource); TargetModel.attachTo(dataSource);

View File

@ -3,7 +3,7 @@ var describe = require('./describe');
var loopback = require('../../'); var loopback = require('../../');
var ACL = loopback.ACL; var ACL = loopback.ACL;
var Change = loopback.Change; var Change = loopback.Change;
var DataModel = loopback.DataModel; var PersistedModel = loopback.PersistedModel;
var RemoteObjects = require('strong-remoting'); var RemoteObjects = require('strong-remoting');
module.exports = function defineModelTestsWithDataSource(options) { module.exports = function defineModelTestsWithDataSource(options) {
@ -22,11 +22,11 @@ describe('Model Tests', function() {
// setup a model / datasource // setup a model / datasource
dataSource = this.dataSource || loopback.createDataSource(options.dataSource); dataSource = this.dataSource || loopback.createDataSource(options.dataSource);
var extend = DataModel.extend; var extend = PersistedModel.extend;
// create model hook // create model hook
DataModel.extend = function() { PersistedModel.extend = function() {
var extendedModel = extend.apply(DataModel, arguments); var extendedModel = extend.apply(PersistedModel, arguments);
if(options.onDefine) { if(options.onDefine) {
options.onDefine.call(test, extendedModel); options.onDefine.call(test, extendedModel);
@ -35,7 +35,7 @@ describe('Model Tests', function() {
return extendedModel; return extendedModel;
} }
User = DataModel.extend('user', { User = PersistedModel.extend('user', {
'first': String, 'first': String,
'last': String, 'last': String,
'age': Number, 'age': Number,