Change: permissions must always be an array

This allows us to set different configs per model. I should have thought
of this usecase when I first did permissions.
This commit is contained in:
Joey Baker
2016-07-22 11:24:08 -07:00
parent fb8275abca
commit 79b9fc1242
2 changed files with 35 additions and 27 deletions

View File

@ -36,29 +36,33 @@ export default (server, model, { prefix, defaultConfig: config, models: permissi
if (!permissions) {
createAll({ server, model, prefix, config });
} else if (Array.isArray(permissions) && permissions.includes(modelName)) {
} else if (!Array.isArray(permissions)) {
throw new Error('hapi-sequelize-crud: `models` property must be an array');
} else if (permissions.includes(modelName)) {
createAll({ server, model, prefix, config });
} else if (_.isPlainObject(permissions)) {
const permittedModels = Object.keys(permissions);
} else {
const permissionOptions = permissions.filter((permission) => {
return permission.model === modelName;
});
if (permissions[modelName] === true) {
createAll({ server, model, prefix, config });
} else if (permittedModels.includes(modelName)) {
if (Array.isArray(permissions[modelName])) {
permissions[modelName].forEach((method) => {
methods[method]({ server, model, prefix, config });
});
} else if (_.isPlainObject(permissions[modelName])) {
permissions[modelName].methods.forEach((method) => {
methods[method]({
server,
model,
prefix,
config: permissions[modelName].config || config,
permissionOptions.forEach((permissionOption) => {
if (_.isPlainObject(permissionOption)) {
const permissionConfig = permissionOption.config || config;
if (permissionOption.methods) {
permissionOption.methods.forEach((method) => {
methods[method]({
server,
model,
prefix,
config: permissionConfig,
});
});
});
} else {
createAll({ server, model, prefix, config: permissionConfig });
}
}
}
});
}
};