contextualcode / ezplatform-role-inheritance-bundle
eZ Platform bundle which provides user role inheritance.
v1.0.3
2019-04-14 04:46 UTC
Requires
- doctrine/orm: ^2.6.3
- ezsystems/ezpublish-kernel: ^7.0
This package is not auto-updated.
Last update: 2025-01-14 08:17:33 UTC
README
This is an eZ Platform bundle which provides user role inheritance.
This is different from the built-in User Group inheritance because it allows for fine-grained, easy management of user roles that doesn't depend on groups.
(This is an eZ Platform port of permissions-inheritance-bundle.)
Installation
- Run
composer require
:
$ composer require contextualcode/ezplatform-role-inheritance-bundle
- Enable this bundle in
app/AppKernel.php
file by adding next line inregisterBundles
method:
public function registerBundles()
{
$bundles = array(
...
new ContextualCode\EzPlatformRoleInheritanceBundle\ContextualCodeEzPlatformRoleInheritanceBundle(),
);
- Add the routes to your
app/config/routing.yml
:contextual_code_ez_platform_role_inheritance: resource: "@ContextualCodeEzPlatformRoleInheritanceBundle/Resources/config/routing.yml" prefix: /
- Create new custom database tables:
$ cat vendor/contextualcode/ezplatform-role-inheritance-bundle/src/ContextualCode/EzPlatformRoleInheritanceBundle/SQL/MySQL/schema.sql | mysql -u <username -p<password> <database_name>
Note: If you are upgrading from an eZ 5.x install that was using contextualcode/permissions-inheritance-bundle, please instead run the upgrade SQL to retain your old role inheritances:
$ cat vendor/contextualcode/ezplatform-role-inheritance-bundle/src/ContextualCode/EzPlatformRoleInheritanceBundle/SQL/MySQL/upgrade.sql | mysql -u <username -p<password> <database_name>
- Done.
Usage
- Just open the role view page in the admin UI. There will be new functionality to add parent/child roles, in the "Role Inheritances" tab.
- Additional code needs to be executed to assign inherited roles to the user: you must call the function
handleUserChildRoles($userId)
of RoleInheritanceService. You can use a custom login handler/event listener or any other way to call that code. For example, you can createAppBundle\Security\User\Provider.php
that extendseZ\Publish\Core\MVC\Symfony\Security\User\Provider
. Add the RoleInheritanceService to the constructor, and override therefreshUser
function to add these lines to load the inherited roles:$userId = $user->getAPIUser()->contentInfo->id; $this->roleInheritanceService->handleUserChildRoles($userId);
Then you must set
security.providers.ezpublish.id
to use the id of this new Provider. Now users will inherit roles set in the admin UI.