Esempio n. 1
0
 public function testEnforce()
 {
     $countries = (include 'tests/fixtures/countries.php');
     $visas = (include 'tests/fixtures/visas.php');
     $users = (include 'tests/fixtures/users.php');
     $vehicles = (include 'tests/fixtures/vehicles.php');
     $this->assertTrue($this->abac->enforce('nationality-access', $users[3]));
     $this->assertEquals(['japd'], $this->abac->enforce('nationality-access', $users[1]));
     // getenv() don't work in CLI scripts without putenv()
     putenv('SERVICE_STATE=OPEN');
     $this->assertTrue($this->abac->enforce('vehicle-homologation', $users[0], $vehicles[0]));
     $this->assertEquals(['derniere-revision-technique'], $this->abac->enforce('vehicle-homologation', $users[2], $vehicles[1]));
     $this->assertEquals(['permis-de-conduire'], $this->abac->enforce('vehicle-homologation', $users[3], $vehicles[3]));
     $this->assertEquals(['visas'], $this->abac->enforce('travel-to-foreign-country', $users[0], null, ['dynamic_attributes' => ['code-pays' => 'US']]));
     $this->assertTrue($this->abac->enforce('travel-to-foreign-country', $users[1], null, ['dynamic_attributes' => ['code-pays' => 'US']]));
 }
Esempio n. 2
0
 /**
  * @param string $rule
  * @param int $userId
  * @param int $objectId
  * @param array $dynamicAttributes
  * @return boolean
  */
 public function isEnforced($rule, $userId, $objectId = null, $dynamicAttributes = [])
 {
     return $this->abac->enforce($rule, $userId, $objectId, $dynamicAttributes) === true;
 }
Esempio n. 3
0
<?php

require_once 'vendor/autoload.php';
use PhpAbac\Abac;
$countries = (include 'tests/fixtures/countries.php');
$visas = (include 'tests/fixtures/visas.php');
$users = (include 'tests/fixtures/users.php');
$vehicles = (include 'tests/fixtures/vehicles.php');
$abac = new Abac([__DIR__ . '/tests/fixtures/policy_rules.yml']);
putenv('SERVICE_STATE=OPEN');
$user1Nationality = $abac->enforce('nationality-access', $users[3], null, ['cache_result' => true, 'cache_lifetime' => 100, 'cache_driver' => 'memory']);
if ($user1Nationality === true) {
    echo "GRANTED : The user 1 is able to be nationalized\n";
} else {
    echo "FAIL : The system didn't grant access\n";
}
$user2Nationality = $abac->enforce('nationality-access', $users[0]);
if ($user2Nationality !== true) {
    echo "DENIED : The user 2 is not able to be nationalized because he hasn't done his JAPD\n";
} else {
    echo "FAIL : The system didn't deny access\n";
}
$user1Vehicle = $abac->enforce('vehicle-homologation', $users[0], $vehicles[0], ['dynamic_attributes' => ['proprietaire' => 1]]);
if ($user1Vehicle === true) {
    echo "GRANTED : The vehicle 1 is able to be approved for the user 1\n";
} else {
    echo "FAIL : The system didn't grant access\n";
}
$user3Vehicle = $abac->enforce('vehicle-homologation', $users[2], $vehicles[1], ['dynamic_attributes' => ['proprietaire' => 3]]);
if (!$user3Vehicle !== true) {
    echo "DENIED : The vehicle 2 is not approved for the user 3 because its last technical review is too old\n";