Add lookback.getModelByType() and use it resolve model deps
This commit is contained in:
parent
86a85291ac
commit
bcc7e68e0e
|
@ -203,6 +203,23 @@ loopback.getModel = function(modelName) {
|
||||||
return loopback.Model.modelBuilder.models[modelName];
|
return loopback.Model.modelBuilder.models[modelName];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Look up a model class by the base model class. The method can be used by LoopBack
|
||||||
|
* to find configured models in models.json over the base model.
|
||||||
|
* @param {Model} The base model class
|
||||||
|
* @return {Model} The subclass if found or the base class
|
||||||
|
*/
|
||||||
|
loopback.getModelByType = function(modelType) {
|
||||||
|
assert(typeof modelType === 'function', 'The model type must be a constructor');
|
||||||
|
var models = loopback.Model.modelBuilder.models;
|
||||||
|
for(var m in models) {
|
||||||
|
if(models[m].prototype instanceof modelType) {
|
||||||
|
return models[m];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return modelType;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the default `dataSource` for a given `type`.
|
* Set the default `dataSource` for a given `type`.
|
||||||
* @param {String} type The datasource type
|
* @param {String} type The datasource type
|
||||||
|
|
|
@ -365,6 +365,7 @@ ACL.checkAccess = function (context, callback) {
|
||||||
var staticACLs = this.getStaticACLs(model.modelName, property);
|
var staticACLs = this.getStaticACLs(model.modelName, property);
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
|
var roleModel = loopback.getModelByType(Role);
|
||||||
this.find({where: {model: model.modelName, property: propertyQuery,
|
this.find({where: {model: model.modelName, property: propertyQuery,
|
||||||
accessType: accessTypeQuery}}, function (err, acls) {
|
accessType: accessTypeQuery}}, function (err, acls) {
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -389,7 +390,7 @@ ACL.checkAccess = function (context, callback) {
|
||||||
// Check role matches
|
// Check role matches
|
||||||
if (acl.principalType === ACL.ROLE) {
|
if (acl.principalType === ACL.ROLE) {
|
||||||
inRoleTasks.push(function (done) {
|
inRoleTasks.push(function (done) {
|
||||||
Role.isInRole(acl.principalId, context,
|
roleModel.isInRole(acl.principalId, context,
|
||||||
function (err, inRole) {
|
function (err, inRole) {
|
||||||
if (!err && inRole) {
|
if (!err && inRole) {
|
||||||
effectiveACLs.push(acl);
|
effectiveACLs.push(acl);
|
||||||
|
|
|
@ -53,7 +53,8 @@ RoleMapping.ROLE = 'ROLE';
|
||||||
*/
|
*/
|
||||||
RoleMapping.prototype.application = function (callback) {
|
RoleMapping.prototype.application = function (callback) {
|
||||||
if (this.principalType === RoleMapping.APPLICATION) {
|
if (this.principalType === RoleMapping.APPLICATION) {
|
||||||
var applicationModel = this.constructor.Application || loopback.Application;
|
var applicationModel = this.constructor.Application
|
||||||
|
|| loopback.getModelByType(loopback.Application);
|
||||||
applicationModel.findById(this.principalId, callback);
|
applicationModel.findById(this.principalId, callback);
|
||||||
} else {
|
} else {
|
||||||
process.nextTick(function () {
|
process.nextTick(function () {
|
||||||
|
@ -70,8 +71,9 @@ RoleMapping.prototype.application = function (callback) {
|
||||||
*/
|
*/
|
||||||
RoleMapping.prototype.user = function (callback) {
|
RoleMapping.prototype.user = function (callback) {
|
||||||
if (this.principalType === RoleMapping.USER) {
|
if (this.principalType === RoleMapping.USER) {
|
||||||
var userModel = this.constructor.User || loopback.User;
|
var userModel = this.constructor.User
|
||||||
loopback.User.findById(this.principalId, callback);
|
|| loopback.getModelByType(loopback.User);
|
||||||
|
userModel.findById(this.principalId, callback);
|
||||||
} else {
|
} else {
|
||||||
process.nextTick(function () {
|
process.nextTick(function () {
|
||||||
callback && callback(null, null);
|
callback && callback(null, null);
|
||||||
|
@ -87,7 +89,7 @@ RoleMapping.prototype.user = function (callback) {
|
||||||
*/
|
*/
|
||||||
RoleMapping.prototype.childRole = function (callback) {
|
RoleMapping.prototype.childRole = function (callback) {
|
||||||
if (this.principalType === RoleMapping.ROLE) {
|
if (this.principalType === RoleMapping.ROLE) {
|
||||||
var roleModel = this.constructor.Role || Role;
|
var roleModel = this.constructor.Role || loopback.getModelByType(Role);
|
||||||
roleModel.findById(this.principalId, callback);
|
roleModel.findById(this.principalId, callback);
|
||||||
} else {
|
} else {
|
||||||
process.nextTick(function () {
|
process.nextTick(function () {
|
||||||
|
@ -114,7 +116,7 @@ Role.RoleMapping = RoleMapping;
|
||||||
|
|
||||||
// Set up the connection to users/applications/roles once the model
|
// Set up the connection to users/applications/roles once the model
|
||||||
Role.once('dataSourceAttached', function () {
|
Role.once('dataSourceAttached', function () {
|
||||||
var roleMappingModel = this.RoleMapping || RoleMapping;
|
var roleMappingModel = this.RoleMapping || loopback.getModelByType(RoleMapping);
|
||||||
Role.prototype.users = function (callback) {
|
Role.prototype.users = function (callback) {
|
||||||
roleMappingModel.find({where: {roleId: this.id,
|
roleMappingModel.find({where: {roleId: this.id,
|
||||||
principalType: RoleMapping.USER}}, function (err, mappings) {
|
principalType: RoleMapping.USER}}, function (err, mappings) {
|
||||||
|
@ -411,7 +413,7 @@ Role.getRoles = function (context, callback) {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
var roleMappingModel = this.RoleMapping || RoleMapping;
|
var roleMappingModel = this.RoleMapping || loopback.getModelByType(RoleMapping);
|
||||||
context.principals.forEach(function (p) {
|
context.principals.forEach(function (p) {
|
||||||
// Check against the role mappings
|
// Check against the role mappings
|
||||||
var principalType = p.type || undefined;
|
var principalType = p.type || undefined;
|
||||||
|
|
|
@ -58,5 +58,39 @@ describe('loopback', function() {
|
||||||
assert(MyCustomModel.super_.modelName === MyModel.modelName);
|
assert(MyCustomModel.super_.modelName === MyModel.modelName);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('loopback.getModel and getModelByType', function () {
|
||||||
|
it('should be able to get model by name', function () {
|
||||||
|
var MyModel = loopback.createModel('MyModel', {}, {
|
||||||
|
foo: {
|
||||||
|
bar: 'bat'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var MyCustomModel = loopback.createModel('MyCustomModel', {}, {
|
||||||
|
base: 'MyModel',
|
||||||
|
foo: {
|
||||||
|
bat: 'baz'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
assert(loopback.getModel('MyModel') === MyModel);
|
||||||
|
assert(loopback.getModel('MyCustomModel') === MyCustomModel);
|
||||||
|
assert(loopback.getModel('Invalid') === undefined);
|
||||||
|
});
|
||||||
|
it('should be able to get model by type', function () {
|
||||||
|
var MyModel = loopback.createModel('MyModel', {}, {
|
||||||
|
foo: {
|
||||||
|
bar: 'bat'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var MyCustomModel = loopback.createModel('MyCustomModel', {}, {
|
||||||
|
base: 'MyModel',
|
||||||
|
foo: {
|
||||||
|
bat: 'baz'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
assert(loopback.getModelByType(MyModel) === MyCustomModel);
|
||||||
|
assert(loopback.getModelByType(MyCustomModel) === MyCustomModel);
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -12,6 +12,14 @@ function checkResult(err, result) {
|
||||||
}
|
}
|
||||||
|
|
||||||
describe('role model', function () {
|
describe('role model', function () {
|
||||||
|
var ds;
|
||||||
|
|
||||||
|
beforeEach(function() {
|
||||||
|
ds = loopback.createDataSource({connector: 'memory'});
|
||||||
|
User.attachTo(ds);
|
||||||
|
Role.attachTo(ds);
|
||||||
|
RoleMapping.attachTo(ds);
|
||||||
|
});
|
||||||
|
|
||||||
it("should define role/role relations", function () {
|
it("should define role/role relations", function () {
|
||||||
Role.create({name: 'user'}, function (err, userRole) {
|
Role.create({name: 'user'}, function (err, userRole) {
|
||||||
|
@ -38,6 +46,7 @@ describe('role model', function () {
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should define role/user relations", function () {
|
it("should define role/user relations", function () {
|
||||||
|
|
||||||
User.create({name: 'Raymond', email: 'x@y.com', password: 'foobar'}, function (err, user) {
|
User.create({name: 'Raymond', email: 'x@y.com', password: 'foobar'}, function (err, user) {
|
||||||
// console.log('User: ', user.id);
|
// console.log('User: ', user.id);
|
||||||
Role.create({name: 'userRole'}, function (err, role) {
|
Role.create({name: 'userRole'}, function (err, role) {
|
||||||
|
@ -113,10 +122,6 @@ describe('role model', function () {
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should support owner role resolver", function () {
|
it("should support owner role resolver", function () {
|
||||||
var ds = loopback.createDataSource({connector: 'memory'});
|
|
||||||
User.attachTo(ds);
|
|
||||||
Role.attachTo(ds);
|
|
||||||
RoleMapping.attachTo(ds);
|
|
||||||
|
|
||||||
var Album = ds.createModel('Album', {
|
var Album = ds.createModel('Album', {
|
||||||
name: String,
|
name: String,
|
||||||
|
|
Loading…
Reference in New Issue