Download the PHP package kinulab/efficient-vote-bundle without Composer
On this page you can find all versions of the php package kinulab/efficient-vote-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download kinulab/efficient-vote-bundle
More information about kinulab/efficient-vote-bundle
Files in kinulab/efficient-vote-bundle
Package efficient-vote-bundle
Short Description Provide a system to enhance performances of the security by voters
License MIT
Informations about the package efficient-vote-bundle
Efficient Vote Bundle
With Symfony you can install access management either with ACLs or with voters. ACLs are hard to implements and voters have performances issues. This bundle provides a way to enjoy the simplicity of voters without the drawback of performances.
Backgroup
The performance issue of voters comes from the AccessDecisionManager
service.
His role is to ask every voter to know if the current user is allowed to perform
a given action (e.g. ROLE_SUPER_ADMIN
). The problem is that this service is not
aware that most of the voters will abstain as they don't support the attribute.
So, if your application has 10 voters and your template uses 10 times the
is_granted()
function, it makes 100 calls. If your application grows, this will
become a bottleneck.
To solve that, this bundle overwrites the default AccessDecisionManager
service.
With the new service, you can register your voters and specify which attributes
are supported. The access decision manager will so not call your voter if he's not
competent for the attribute.
Installation
Then add in you app/config/AppKernel.php
:
Usage
The new access decision manager will assume that you organize your voter by types and by domains.
Your must then name your roles with this forms:
Your voters class remain exaclty like the standards symfony voters. The only difference is on the registration of your voter service.
With a standard vorter, your service is registered like that:
With this bundle you should now register your service like that :
With this configuration, the voter above, will be called only for the
ROLE_HOUSE_*
attributes.
Note
The new access decision manager remains compatible with the original. So if you have some voters that are registered the old way, they will still work as expected (but called tons of time).
All versions of efficient-vote-bundle with dependencies
symfony/config Version ^3.0||^4.0
symfony/security-bundle Version ^3.0||^4.0