示例#1
0
 /**
  * @depends testCreateResource
  */
 public function testCreateRelatedModels()
 {
     //        $this->markTestSkipped('Db table field types has to be resolved with model field types');
     $resourceModel = AclResource::findFirstByName('CreatedResource');
     $roleModel = new AclRole();
     $roleModel->create(['name' => 'guest', 'description' => '', 'removable' => 1]);
     $this->assertEquals(AclRole::DIRTY_STATE_PERSISTENT, $roleModel->getDirtyState());
     $accessModel = new AclResourceAccess();
     $accessModel->create(['acl_resource_id' => $resourceModel->id, 'name' => 'index', 'description' => '', 'inherit' => '']);
     $this->assertEquals(AclResourceAccess::DIRTY_STATE_PERSISTENT, $accessModel->getDirtyState());
     $aclModel = new AclAccessList();
     $aclModel->create(['acl_role_id' => $roleModel->id, 'acl_resource_id' => $resourceModel->id, 'acl_resource_access_id' => $accessModel->id, 'allowed' => Acl::ALLOW]);
     $this->assertEquals(AclAccessList::DIRTY_STATE_PERSISTENT, $aclModel->getDirtyState());
 }
示例#2
0
 public function testToAccessArray()
 {
     $resourceModel = new AclResource();
     $result = $resourceModel->save(['name' => 'toAccessArrayResource', 'description' => 'foo bar baz', 'scope' => '']);
     $this->assertTrue($result);
     $roleModel = new AclRole();
     $roleModel->create(['name' => 'toAccessArrayRole', 'description' => '', 'removable' => true]);
     $accessModel = new AclResourceAccess();
     $accessModel->create(['acl_resource_id' => $resourceModel->id, 'name' => 'index', 'description' => '', 'inherit' => null]);
     $aclModel = new AclAccessList();
     $aclModel->create(['acl_role_id' => $roleModel->id, 'acl_resource_id' => $resourceModel->id, 'acl_resource_access_id' => $accessModel->id, 'allowed' => false]);
     $accessArray = ['access_name' => (string) $accessModel, 'resources_name' => (string) $resourceModel, 'allowed' => false];
     $toAccessArray = $aclModel->toAccessArray();
     $this->assertSame($toAccessArray, $accessArray);
 }
示例#3
0
 public function testGetAccessLists()
 {
     $resourceModel = new AclResource();
     $result = $resourceModel->save(['name' => 'getAccessListsResource', 'description' => 'sna fu bar', 'scope' => '']);
     $this->assertTrue($result);
     $this->assertEquals(AclResource::DIRTY_STATE_PERSISTENT, $resourceModel->getDirtyState());
     $accessModel = new AclResourceAccess();
     $accessModel->initialize();
     $result = $accessModel->create(['acl_resource_id' => $resourceModel->id, 'name' => 'index', 'description' => '', 'inherit' => '']);
     $this->assertTrue($result);
     $this->assertEquals(AclResourceAccess::DIRTY_STATE_PERSISTENT, $accessModel->getDirtyState());
     $roleModel = new AclRole();
     $status = $roleModel->create(['name' => 'getAccessListsRole', 'description' => '', 'removable' => 1]);
     $this->assertTrue($result);
     $this->assertEquals(AclRole::DIRTY_STATE_PERSISTENT, $roleModel->getDirtyState());
     $aclModel = new AclAccessList();
     $result = $aclModel->create(['acl_role_id' => $roleModel->id, 'acl_resource_id' => $resourceModel->id, 'acl_resource_access_id' => $accessModel->id, 'allowed' => Acl::ALLOW]);
     $this->assertTrue($result);
     $this->assertEquals(AclAccessList::DIRTY_STATE_PERSISTENT, $aclModel->getDirtyState());
     $list = $accessModel->getAccessLists();
     $this->assertCount(1, $list);
     $this->assertArrayHasKey(0, $list);
     $this->assertSame($list[0]->id, $aclModel->id);
 }
示例#4
0
文件: Mysql.php 项目: vegas-cmf/acl
 /**
  * Retrieves existing ACL models with string names for non-existing.
  * @param string $roleName
  * @param string $resourceName
  * @param mixed $access array or string
  * @return AclAccessList[] array with AclAccessList models or string names on non-existing ACLs
  * @throws Exception
  */
 protected function getValidatedAclModels($roleName, $resourceName, $access)
 {
     if (($resourceName === Resource::WILDCARD || $access === Resource::ACCESS_WILDCARD) && !($resourceName === Resource::WILDCARD && $access === Resource::ACCESS_WILDCARD)) {
         throw new Exception("Cannot create access to '{$access}' in '{$resourceName}' for role {$roleName}");
     }
     $accesses = is_array($access) ? $access : [$access];
     $sanitizedResourceName = $this->filterResourceName($resourceName);
     return array_map(function ($accessName) use($roleName, $sanitizedResourceName) {
         $acl = AclAccessList::findFirstByRoleResourceAndAccess($roleName, $sanitizedResourceName, $accessName);
         return $acl ? $acl : $accessName;
     }, $accesses);
 }