PLATFORM >= 2015.09
eZ content repository uses the concept of roles and policies in order to authorize a user to do something (e.g. read content).
- A role is composed of policies and can be assigned to a user or a user group.
- A policy is composed of a combination of module and function (e.g.
contentbeing the module and
readbeing the function).
- Depending on module and function combination, a policy can also be composed of limitations.
It is possible for any bundle to expose available policies via a
PolicyProvider which can be added to EzPublishCoreBundle's DIC extension.
PolicyProvider is an object providing a hash containing declared modules, functions and limitations.
- Each policy provider provides a collection of permission modules.
- Each module can provide functions (e.g. "content/read": "content" is the module, "read" is the function)
- Each function can provide a collection of 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.
Limitations need to be implemented as limitation types and declared as services identified with
ezpublish.limitationType tag. Name provided in the hash for each limitation is the same value set in
alias attribute in the service tag.
An abstract class based on YAML is provided:
It defines an abstract
YamlPolicyProvider and implement
getFiles() to return absolute paths to your YAML files.
Extending existing policies
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.
Integrating the PolicyProvider into EzPublishCoreBundle
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 bundle's
Policies used internally in repository services are defined in