0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-13 22:41:32 -05:00
ghost/core/server/data/fixtures/permissions/index.js

111 lines
3.4 KiB
JavaScript
Raw Normal View History

// # Permissions Fixtures
// Sets up the permissions, and the default permissions_roles relationships
var Promise = require('bluebird'),
sequence = require('../../../utils/sequence'),
_ = require('lodash'),
errors = require('../../../errors'),
models = require('../../../models'),
fixtures = require('./permissions'),
// private
logInfo,
addAllPermissions,
addAllRolesPermissions,
addRolesPermissionsForRole,
// public
populate,
to003;
logInfo = function logInfo(message) {
errors.logInfo('Migrations', message);
};
addRolesPermissionsForRole = function (roleName) {
var fixturesForRole = fixtures.permissions_roles[roleName],
permissionsToAdd;
return models.Role.forge({name: roleName}).fetch({withRelated: ['permissions']}).then(function (role) {
return models.Permissions.forge().fetch().then(function (permissions) {
if (_.isObject(fixturesForRole)) {
permissionsToAdd = _.map(permissions.toJSON(), function (permission) {
var objectPermissions = fixturesForRole[permission.object_type];
if (objectPermissions === 'all') {
return permission.id;
} else if (_.isArray(objectPermissions) && _.contains(objectPermissions, permission.action_type)) {
return permission.id;
}
return null;
});
}
return role.permissions().attach(_.compact(permissionsToAdd));
});
});
};
addAllRolesPermissions = function () {
var roleNames = _.keys(fixtures.permissions_roles),
ops = [];
_.each(roleNames, function (roleName) {
ops.push(addRolesPermissionsForRole(roleName));
});
return Promise.all(ops);
};
addAllPermissions = function (options) {
var ops = [];
_.each(fixtures.permissions, function (permissions, objectType) {
_.each(permissions, function (permission) {
ops.push(function () {
permission.object_type = objectType;
return models.Permission.add(permission, options);
});
});
});
return sequence(ops);
};
// ## Populate
populate = function (options) {
logInfo('Populating permissions');
// ### Ensure all permissions are added
return addAllPermissions(options).then(function () {
// ### Ensure all roles_permissions are added
return addAllRolesPermissions();
});
};
// ## Update
// Update permissions to 003
// Need to rename old permissions, and then add all of the missing ones
to003 = function (options) {
var ops = [];
logInfo('Upgrading permissions');
// To safely upgrade, we need to clear up the existing permissions and permissions_roles before recreating the new
// full set of permissions defined as of version 003
return models.Permissions.forge().fetch().then(function (permissions) {
logInfo('Removing old permissions');
permissions.each(function (permission) {
ops.push(permission.related('roles').detach().then(function () {
return permission.destroy();
}));
});
// Now we can perform the normal populate
return Promise.all(ops).then(function () {
return populate(options);
});
});
};
module.exports = {
populate: populate,
to003: to003
};