Merge pull request #302 from strongloop/rename-datamodel-to-persistedmodel
[2.0] Rename DataModel to PersistedModel
This commit is contained in:
commit
71792b144c
|
@ -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,
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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();
|
|
@ -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
|
||||||
|
|
|
@ -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",
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
});
|
});
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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,
|
||||||
|
|
Loading…
Reference in New Issue