eZ content repository uses the concept of Roles and Policies in order to authorize a user to do something (e.g. read content).
content/read
, content
being the module and read
being the function).It is possible for any bundle to expose available Policies via a PolicyProvider
which can be added to EzPublishCoreBundle's DIC extension.
A PolicyProvider
is an object providing a hash containing declared modules, functions and limitations.
Policies configuration hash contains declared these modules, functions and Limitations.
First level key is the module name, value is a hash of available functions, with function name as key.
Function value is an array of available Limitations, identified by the alias declared in LimitationType service tag.
If no Limitation is provided, value can be null
or an empty array.
[ "content" => [ "read" => ["Class", "ParentClass", "Node", "Language"], "edit" => ["Class", "ParentClass", "Language"] ], "custom_module" => [ "custom_function_1" => null, "custom_function_2" => ["CustomLimitation"] ], ] |
Limitations need to be implemented as limitation types and declared as services identified with |
namespace Acme\FooBundle\AcmeFooBundle\Security; use eZ\Bundle\EzPublishCoreBundle\DependencyInjection\Configuration\ConfigBuilderInterface; use eZ\Bundle\EzPublishCoreBundle\DependencyInjection\Security\PolicyProvider\PolicyProviderInterface; class MyPolicyProvider implements PolicyProviderInterface { public function addPolicies(ConfigBuilderInterface $configBuilder) { $configBuilder->addConfig([ "custom_module" => [ "custom_function_1" => null, "custom_function_2" => ["CustomLimitation"], ], ]); } } |
An abstract class based on YAML is provided: eZ\Bundle\EzPublishCoreBundle\DependencyInjection\Security\PolicyProvider\YamlPolicyProvider
.
It defines an abstract getFiles()
method.
Extend YamlPolicyProvider
and implement getFiles()
to return absolute paths to your YAML files.
namespace Acme\FooBundle\AcmeFooBundle\Security; use eZ\Bundle\EzPublishCoreBundle\DependencyInjection\Security\PolicyProvider\YamlPolicyProvider; class MyPolicyProvider extends YamlPolicyProvider { protected function getFiles() { return [ __DIR__ . '/../Resources/config/policies.yml', ]; } } |
custom_module: custom_function_1: ~ custom_function_2: [CustomLimitation] |
A PolicyProvider
may provide new functions to a module, and additional Limitations to an existing function.
It is however strongly encouraged to add functions to your own Policy modules.
It is not possible to remove an existing module, function or limitation from a Policy. |
For a PolicyProvider to be active, it must be properly declared in EzPublishCoreBundle.
A bundle just has to retrieve CoreBundle's DIC extension and call addPolicyProvider()
. This must be done in the bundle's build()
method.
namespace Acme\FooBundle\AcmeFooBundle; use Symfony\Component\HttpKernel\Bundle\Bundle; class AcmeFooBundle extends Bundle { public function build(ContainerBuilder $container) { parent::build($container); // ... // Retrieve "ezpublish" container extension. $eZExtension = $container->getExtension('ezpublish'); // Add the policy provider. $eZExtension->addPolicyProvider(new MyPolicyProvider()); } } |
Policies used internally in repository services are defined in EzPublishCoreBundle/Resources/config/policies.yml
.