2016-04-06 14:51:49 +00:00
|
|
|
// Copyright IBM Corp. 2014,2016. All Rights Reserved.
|
|
|
|
// Node module: loopback-datasource-juggler
|
|
|
|
// This file is licensed under the MIT License.
|
|
|
|
// License text available at https://opensource.org/licenses/MIT
|
|
|
|
|
2014-08-06 11:26:47 +00:00
|
|
|
var debug = require('debug')('loopback:mixin');
|
2014-08-08 08:20:57 +00:00
|
|
|
var assert = require('assert');
|
|
|
|
var DefaultModelBaseClass = require('./model.js');
|
2014-08-06 11:26:47 +00:00
|
|
|
|
2014-08-08 08:20:57 +00:00
|
|
|
function isModelClass(cls) {
|
|
|
|
if (!cls) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return cls.prototype instanceof DefaultModelBaseClass;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = MixinProvider;
|
2014-08-06 11:26:47 +00:00
|
|
|
|
2014-08-08 08:20:57 +00:00
|
|
|
function MixinProvider(modelBuilder) {
|
|
|
|
this.modelBuilder = modelBuilder;
|
|
|
|
this.mixins = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Apply named mixin to the model class
|
|
|
|
* @param {Model} modelClass
|
|
|
|
* @param {String} name
|
|
|
|
* @param {Object} options
|
|
|
|
*/
|
|
|
|
MixinProvider.prototype.applyMixin = function applyMixin(modelClass, name, options) {
|
|
|
|
var fn = this.mixins[name];
|
2014-08-06 11:26:47 +00:00
|
|
|
if (typeof fn === 'function') {
|
|
|
|
if (modelClass.dataSource) {
|
|
|
|
fn(modelClass, options || {});
|
|
|
|
} else {
|
|
|
|
modelClass.once('dataSourceAttached', function() {
|
|
|
|
fn(modelClass, options || {});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} else {
|
2014-08-08 08:20:57 +00:00
|
|
|
// Try model name
|
|
|
|
var model = this.modelBuilder.getModel(name);
|
2016-04-14 14:41:19 +00:00
|
|
|
if (model) {
|
2014-08-08 08:20:57 +00:00
|
|
|
debug('Mixin is resolved to a model: %s', name);
|
|
|
|
modelClass.mixin(model, options);
|
2014-08-06 11:26:47 +00:00
|
|
|
} else {
|
2014-08-08 08:20:57 +00:00
|
|
|
debug('Invalid mixin: %s', name);
|
2014-08-06 11:26:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2014-08-08 08:20:57 +00:00
|
|
|
/**
|
|
|
|
* Define a mixin with name
|
|
|
|
* @param {String} name Name of the mixin
|
|
|
|
* @param {*) mixin The mixin function or a model
|
|
|
|
*/
|
|
|
|
MixinProvider.prototype.define = function defineMixin(name, mixin) {
|
|
|
|
assert(typeof mixin === 'function', 'The mixin must be a function or model class');
|
|
|
|
if (this.mixins[name]) {
|
|
|
|
debug('Duplicate mixin: %s', name);
|
|
|
|
} else {
|
|
|
|
debug('Defining mixin: %s', name);
|
2014-08-06 11:26:47 +00:00
|
|
|
}
|
2014-08-08 08:20:57 +00:00
|
|
|
if (isModelClass(mixin)) {
|
2016-04-14 14:41:19 +00:00
|
|
|
this.mixins[name] = function(Model, options) {
|
2014-08-08 08:20:57 +00:00
|
|
|
Model.mixin(mixin, options);
|
|
|
|
};
|
|
|
|
} else if (typeof mixin === 'function') {
|
|
|
|
this.mixins[name] = mixin;
|
2014-08-06 11:26:47 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|