madlines / security-resolver-bundle
1.0
2016-02-28 10:08 UTC
Requires
- php: >=5.5
- madlines/common-security-resolver: ^1.1
- symfony/symfony: ^2.7 | ^3.0
This package is not auto-updated.
Last update: 2025-01-04 21:08:34 UTC
README
This is a bridge between Symfony2 or Symfony3 and Madlines Security Resolver.
Installation
composer require madlines/security-resolver-bundle
then update your AppKernel.php
public function registerBundles() { $bundles = [ // ... new Madlines\SecurityResolverBundle\MadlinesSecurityResolverBundle(), // ... ]; // ... return $bundles; }
Configuration
Prepare your voters like that:
<?php class PostEditVoter { public function isGranted($user, $task) { // if (!($task instanceof PostEditTask)) { if ($task !== 'post_edit') { return null; // null means 'ignore' // returning integer 0 means the same } if ($user->hasRole('ROLE_ADMIN')) { return true; // agree // returning integer 1 means the same } return false; // disagree // returning integer -1 means the same } }
Then connect each voter as a tagged service:
voter.post_edit: class: PostEditVoter public: false tags: - { name: madlines.security_resolver.voter }
Optionally you can change a voter's method name by adding a method
attribute to a tag.
Usage
Execute isGranted
method on security resolver's service which is registered as madlines.security_resolver.access_resolver
.
For example:
$isGranted = $this->get('madlines.security_resolver.access_resolver')->isGranted( $this->getUser(), 'post_edit' ); if (!$isGranted) { throw new Symfony\Component\Security\Core\Exception\InsufficientAuthenticationException(); }