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]); }
/** * @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()); }
/** * @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')))); }
/** * {@inheritdoc} */ public static function doTearDownAfterClass() { self::$st->dropSchema(array(self::$em->getClassMetadata(User::clazz()), self::$em->getClassMetadata(Group::clazz()), self::$em->getClassMetadata(Permission::clazz()))); }