Beispiel #1
0
 public function testGetRawRoles()
 {
     $user = new User();
     $this->assertEquals(0, count($user->getRawRoles()));
     // ---
     $groupPermission = \Phake::mock(Permission::clazz());
     $userPermission = \Phake::mock(Permission::clazz());
     $group = \Phake::mock(Group::clazz());
     \Phake::when($group)->getPermissions()->thenReturn([$groupPermission]);
     $user->addPermission($userPermission);
     $user->setGroups([$group]);
     $userRoles = $user->getRawRoles();
     $this->assertEquals(2, count($userRoles));
     $this->assertSame($groupPermission, $userRoles[0]);
     $this->assertSame($userPermission, $userRoles[1]);
 }
Beispiel #2
0
 /**
  * @return array
  */
 public function getConfig()
 {
     $em = $this->getDoctrine();
     $groupEntityValidator = function (array $params, Group $group, DefaultEntityValidator $defaultValidator, array $config, ContainerInterface $container) use($em) {
         $validationResult = $defaultValidator->validate($group, $config);
         if (!$group->getRefName()) {
             return $validationResult;
         }
         /** @var Group[] $groupWithSuchRefNameList */
         $groupWithSuchRefNameList = $em->getRepository(Group::clazz())->findByRefName($group->getRefName());
         if (count($groupWithSuchRefNameList) > 0) {
             $groupWithSuchRefName = $groupWithSuchRefNameList[0];
             if ($groupWithSuchRefName->getId() != $group->getId()) {
                 $validationResult->addFieldError('refName', T::trans('This refName is taken. Consider use \'%groupName%\' group or change current reference name.', array('%groupName%' => $groupWithSuchRefName->getName())));
             }
         }
         return $validationResult;
     };
     $mapEntity = function (array $params, Group $group, DataMapperInterface $defaultMapper, ContainerInterface $container) {
         $defaultMapper->mapData($params, $group);
         /*
          * Because of unique constrain we cannot save '' value as refName.
          * Only one time can, actually. :) So, to allow user use groups without
          * refName we have to set null by force because of ExtJs empty form value
          * is ''.
          */
         $refName = $group->getRefName();
         if ($refName === '') {
             $group->setRefName(null);
         } else {
             /*
              * To help users avoid duplicates group we use normalizing for refName
              */
             $group->setRefName(Group::normalizeRefNameString($refName));
         }
     };
     return array('entity' => Group::clazz(), 'security' => array('role' => ModeraBackendSecurityBundle::ROLE_ACCESS_BACKEND_TOOLS_SECURITY_SECTION, 'actions' => array('create' => ModeraBackendSecurityBundle::ROLE_MANAGE_PERMISSIONS, 'update' => ModeraBackendSecurityBundle::ROLE_MANAGE_PERMISSIONS, 'remove' => ModeraBackendSecurityBundle::ROLE_MANAGE_PERMISSIONS)), 'hydration' => array('groups' => array('list' => function (Group $group) {
         return array('id' => $group->getId(), 'name' => $group->getName(), 'usersCount' => count($group->getUsers()));
     }, 'delete-group' => ['name'], 'main-form' => ['id', 'name', 'refName'], 'compact-list' => ['id', 'name']), 'profiles' => array('list', 'compact-list', 'delete-group', 'edit-group' => array('main-form'))), 'format_new_entity_values' => function (array $params, array $config, NewValuesFactoryInterface $defaultImpl, ContainerInterface $container) {
         return array('refName' => null);
     }, 'new_entity_validator' => $groupEntityValidator, 'updated_entity_validator' => $groupEntityValidator, 'map_data_on_create' => $mapEntity, 'map_data_on_update' => $mapEntity);
 }
 /**
  * Db Tables used in test.
  *
  * @return array
  */
 private static function getTableClasses()
 {
     return array(Group::clazz());
 }
Beispiel #4
0
 /**
  * @param $roleName
  *
  * @return array
  */
 public function getIdsByRole($roleName)
 {
     $ids = array();
     $qb = $this->em->createQueryBuilder();
     $qb->select('p, u, g')->from(Permission::clazz(), 'p')->leftJoin('p.users', 'u')->leftJoin('p.groups', 'g')->where($qb->expr()->eq('p.roleName', ':roleName'))->setParameter('roleName', $roleName);
     $query = $qb->getQuery();
     $permission = $query->getOneOrNullResult($query::HYDRATE_ARRAY);
     if ($permission) {
         foreach ($permission['users'] as $u) {
             $ids[] = $u['id'];
         }
         $groupIds = array();
         foreach ($permission['groups'] as $g) {
             $groupIds[] = $g['id'];
         }
         if (count($groupIds)) {
             $qb = $this->em->createQueryBuilder();
             $qb->select('g, u')->from(Group::clazz(), 'g')->leftJoin('g.users', 'u')->where($qb->expr()->in('g.id', $groupIds));
             $groups = $qb->getQuery()->getArrayResult();
             foreach ($groups as $g) {
                 foreach ($g['users'] as $u) {
                     $ids[] = $u['id'];
                 }
             }
         }
     }
     return array_keys(array_flip($ids));
 }
 /**
  * @return array
  */
 private static function getTablesClasses()
 {
     return array(Permission::clazz(), PermissionCategory::clazz(), User::clazz(), Group::clazz(), Activity::clazz());
 }
 /**
  * @return array
  */
 public function getConfig()
 {
     return array('entity' => Group::clazz(), 'security' => array('role' => ModeraBackendSecurityBundle::ROLE_ACCESS_BACKEND_TOOLS_SECURITY_SECTION, 'actions' => array('create' => ModeraBackendSecurityBundle::ROLE_MANAGE_PERMISSIONS, 'update' => ModeraBackendSecurityBundle::ROLE_MANAGE_PERMISSIONS, 'remove' => ModeraBackendSecurityBundle::ROLE_MANAGE_PERMISSIONS)), 'hydration' => array('groups' => array('list' => function (Group $group) {
         return array('id' => $group->getId(), 'name' => $group->getName(), 'usersCount' => count($group->getUsers()));
     }, 'delete-group' => ['name'], 'main-form' => ['id', 'name'], 'compact-list' => ['id', 'name']), 'profiles' => array('list', 'compact-list', 'delete-group', 'edit-group' => array('main-form'))));
 }
Beispiel #7
0
 /**
  * {@inheritdoc}
  */
 public static function doTearDownAfterClass()
 {
     self::$st->dropSchema(array(self::$em->getClassMetadata(User::clazz()), self::$em->getClassMetadata(Group::clazz()), self::$em->getClassMetadata(Permission::clazz())));
 }