Merge branch 'master' into PHRAS-2741-worker-service-part1

This commit is contained in:
Nicolas Maillat
2020-02-26 20:15:15 +01:00
committed by GitHub
3 changed files with 28 additions and 8 deletions

View File

@@ -30,7 +30,7 @@ class UserListCommand extends Command
{ {
parent::__construct('user:list'); parent::__construct('user:list');
$this->setDescription('List of all user') $this->setDescription('List of all user (experimental)')
->addOption('user_id', null, InputOption::VALUE_OPTIONAL, ' The id of user export only info this user ') ->addOption('user_id', null, InputOption::VALUE_OPTIONAL, ' The id of user export only info this user ')
->addOption('user_email', null, InputOption::VALUE_OPTIONAL, 'The mail of user export only info this user .') ->addOption('user_email', null, InputOption::VALUE_OPTIONAL, 'The mail of user export only info this user .')
->addOption('database_id', null, InputOption::VALUE_OPTIONAL, 'Id of database.') ->addOption('database_id', null, InputOption::VALUE_OPTIONAL, 'Id of database.')
@@ -42,6 +42,7 @@ class UserListCommand extends Command
->addOption('application', null, InputOption::VALUE_NONE, 'List application of user work only if --user_id is set') ->addOption('application', null, InputOption::VALUE_NONE, 'List application of user work only if --user_id is set')
->addOption('right', null, InputOption::VALUE_NONE, 'Show right information') ->addOption('right', null, InputOption::VALUE_NONE, 'Show right information')
->addOption('adress', null, InputOption::VALUE_NONE, 'Show adress information') ->addOption('adress', null, InputOption::VALUE_NONE, 'Show adress information')
->addOption('models', null, InputOption::VALUE_NONE, "Show only defined models, if --user_id is set with --models it's the template owner")
->addOption('jsonformat', null, InputOption::VALUE_NONE, 'Output in json format') ->addOption('jsonformat', null, InputOption::VALUE_NONE, 'Output in json format')
->setHelp(''); ->setHelp('');
@@ -62,6 +63,7 @@ class UserListCommand extends Command
$created = $input->getOption('created'); $created = $input->getOption('created');
$updated = $input->getOption('updated'); $updated = $input->getOption('updated');
$withRight = $input->getOption('right'); $withRight = $input->getOption('right');
$models = $input->getOption('models');
$jsonformat = $input->getOption('jsonformat'); $jsonformat = $input->getOption('jsonformat');
$query = $this->container['phraseanet.user-query']; $query = $this->container['phraseanet.user-query'];
@@ -70,18 +72,26 @@ class UserListCommand extends Command
if($collectionId) $query->on_sbas_ids([$collectionId]); if($collectionId) $query->on_sbas_ids([$collectionId]);
if($created) $this->addFilterDate($created,'created',$query); if($created) $this->addFilterDate($created,'created',$query);
if($updated) $this->addFilterDate($updated,'updated',$query); if($updated) $this->addFilterDate($updated,'updated',$query);
if($userId) $query->addSqlFilter('Users.id = ?' ,[$userId]); if($userId && !$models) $query->addSqlFilter('Users.id = ?' ,[$userId]);
if($userEmail) $query->addSqlFilter('Users.email = ?' ,[$userEmail]); if($userEmail && !$models) $query->addSqlFilter('Users.email = ?' ,[$userEmail]);
if($lockStatus) $query->addSqlFilter('Users.mail_locked = 1'); if($lockStatus && !$models) $query->addSqlFilter('Users.mail_locked = 1');
if($guest) $query->include_invite(true)->addSqlFilter('Users.guest = 1'); if($guest && !$models) $query->include_invite(true)->addSqlFilter('Users.guest = 1');
if ($application and !$userId) { if ($application and !$userId) {
$output->writeln('<error>You must provide --user_id when using --application option</error>'); $output->writeln('<error>You must provide --user_id when using --application option</error>');
return 0; return 0;
} }
$users = $query /** @var UserRepository $userRepository */
->execute()->get_results(); $userRepository = $this->container['repo.users'];
if ($models && $userId) {
$users = $userRepository->findBy(['templateOwner' => $userId]);
} elseif ($models) {
$users = $userRepository->findTemplate();
} else {
$users = $query->execute()->get_results();
}
$userList = []; $userList = [];
$showApplication = false; $showApplication = false;

View File

@@ -122,4 +122,15 @@ class UserRepository extends EntityRepository
{ {
return $this->findBy(['templateOwner' => $user->getId()]); return $this->findBy(['templateOwner' => $user->getId()]);
} }
/**
* Finds all templates
*/
public function findTemplate()
{
$qb = $this->createQueryBuilder('u');
$qb->where('u.templateOwner is NOT NULL');
return $qb->getQuery()->getResult();
}
} }

View File

@@ -39,7 +39,6 @@ class eventsmanager_broker
], ],
'notify' => [ 'notify' => [
'eventsmanager_notify_autoregister', 'eventsmanager_notify_autoregister',
'eventsmanager_notify_bridgeuploadfail',
'eventsmanager_notify_downloadmailfail', 'eventsmanager_notify_downloadmailfail',
'eventsmanager_notify_feed', 'eventsmanager_notify_feed',
'eventsmanager_notify_order', 'eventsmanager_notify_order',