154 lines
4.6 KiB
JavaScript
Raw Normal View History

'use strict';
2017-11-17 14:22:59 +01:00
const fs = require('fs')
const path = require('path');
const stringify = JSON.stringify;
2017-11-16 17:59:41 +01:00
const _ = require('lodash');
2017-11-17 16:36:57 +01:00
// const Service = strapi.plugins['users-permissions'].services;
/**
* UsersPermissions.js service
*
* @description: A set of functions similar to controller's actions to avoid code duplication.
*/
module.exports = {
2017-11-27 16:49:56 +01:00
createRole: (role) => {
const Service = strapi.plugins['users-permissions'].services.userspermissions;
const roleConfigPath = Service.getRoleConfigPath();
const currentRoles = require(Service.getRoleConfigPath());
const highestId = _.last(Object.keys(currentRoles).reduce((acc, key) => {
acc.push(_.toNumber(key));
return acc;
}, []).sort()) + 1;
const newRole = _.pick(role, ['name', 'description', 'permissions']);
_.set(currentRoles, highestId.toString(), newRole);
Service.writePermissions(currentRoles);
},
2017-11-16 17:59:41 +01:00
getActions: () => {
2017-11-17 14:22:59 +01:00
const generateActions = (data) => (
Object.keys(data).reduce((acc, key) => {
acc[key] = { enabled: false, policy: '' };
2017-11-17 14:22:59 +01:00
return acc;
}, {}));
const appControllers = Object.keys(strapi.api || {}).reduce((acc, key) => {
2017-11-17 14:22:59 +01:00
acc.controllers[key] = generateActions(strapi.api[key].controllers[key]);
2017-11-16 17:59:41 +01:00
return acc;
}, { controllers: {} });
const pluginsPermissions = Object.keys(strapi.plugins).reduce((acc, key) => {
2017-11-20 14:35:24 +01:00
acc[key] = Object.keys(strapi.plugins[key].controllers).reduce((obj, k) => {
2017-11-17 14:22:59 +01:00
obj.controllers[k] = generateActions(strapi.plugins[key].controllers[k]);
return obj;
2017-11-20 14:35:24 +01:00
}, { controllers: {} });
return acc;
}, {});
2017-11-16 17:59:41 +01:00
const permissions = {
application: {
controllers: appControllers.controllers,
},
2017-11-16 17:59:41 +01:00
};
const allPermissions = _.merge(permissions, pluginsPermissions);
2017-11-17 16:36:57 +01:00
return allPermissions;
},
2017-11-17 14:22:59 +01:00
2017-11-27 16:04:57 +01:00
getRoles: () => {
const Service = strapi.plugins['users-permissions'].services.userspermissions;
const roles = require(Service.getRoleConfigPath());
const formattedRoles = Object.keys(roles).reduce((acc, key) => {
const role = _.pick(roles[key], ['name', 'description']);
_.set(role, 'id', key);
// TODO get number_users
_.set(role, 'nb_users', 0);
acc.push(role);
return acc;
}, []);
return formattedRoles;
},
2017-11-17 16:36:57 +01:00
getRoleConfigPath: () => (
path.join(
strapi.config.appPath,
'plugins',
'users-permissions',
'config',
'roles.json',
)
),
updateData: (data, diff = 'unset') => {
const dataToCompare = strapi.plugins['users-permissions'].services.userspermissions.getActions();
_.forEach(data, (roleData, roleId) => {
const obj = diff === 'unset' ? roleData.permissions : dataToCompare;
_.forEach(obj, (pluginData, pluginName) => {
_.forEach(pluginData.controllers, (controllerActions, controllerName) => {
_.forEach(controllerActions, (actionData, actionName) => {
if (diff === 'unset') {
if (!_.get(dataToCompare, [pluginName, 'controllers', controllerName])) {
_.unset(data, [roleId, 'permissions', pluginName, 'controllers', controllerName]);
return;
}
if (!_.get(dataToCompare, [pluginName, 'controllers', controllerName, actionName])) {
_.unset(data, [roleId, 'permissions', pluginName, 'controllers', controllerName, actionName]);
}
} else {
if (!_.get(data, [roleId, 'permissions', pluginName, 'controllers', controllerName, actionName])) {
_.set(data, [roleId, 'permissions', pluginName, 'controllers', controllerName, actionName], { enabled: false, policy: '' })
}
}
});
});
});
});
return data;
},
2017-11-20 14:35:24 +01:00
updatePermissions: async (cb) => {
const Service = strapi.plugins['users-permissions'].services.userspermissions;
2017-11-17 16:36:57 +01:00
const appActions = Service.getActions();
const roleConfigPath = Service.getRoleConfigPath();
const writePermissions = Service.writePermissions;
const currentRoles = require(roleConfigPath);
const remove = await Service.updateData(_.cloneDeep(currentRoles));
const added = await Service.updateData(_.cloneDeep(remove), 'set');
if (!_.isEqual(currentRoles, added)) {
writePermissions(added);
2017-11-17 14:22:59 +01:00
}
2017-11-20 14:35:24 +01:00
if (cb) {
cb();
}
2017-11-17 16:36:57 +01:00
},
2017-11-17 14:22:59 +01:00
2017-11-17 16:36:57 +01:00
writePermissions: (data) => {
const roleConfigPath = strapi.plugins['users-permissions'].services.userspermissions.getRoleConfigPath();
try {
fs.writeFileSync(roleConfigPath, stringify(data, null, 2), 'utf8');
} catch(err) {
strapi.log.error(err);
}
}
};