mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-23 18:03:17 +00:00
267 lines
9.3 KiB
PHP
267 lines
9.3 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Phraseanet
|
|
*
|
|
* (c) 2005-2016 Alchemy
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Alchemy\Phrasea\Command\User;
|
|
|
|
use Alchemy\Phrasea\Command\Command;
|
|
use Alchemy\Phrasea\Model\Entities\User;
|
|
use Symfony\Component\Console\Helper\TableCell;
|
|
use Symfony\Component\Console\Input\InputInterface;
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
use Symfony\Component\Console\Input\InputOption;
|
|
use Alchemy\Phrasea\Utilities\NullableDateTime;
|
|
|
|
|
|
class UserListCommand extends Command
|
|
{
|
|
|
|
/**
|
|
* Constructor
|
|
*/
|
|
public function __construct($name = null)
|
|
{
|
|
parent::__construct('user:list');
|
|
|
|
$this->setDescription('List of all 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('database_id', null, InputOption::VALUE_OPTIONAL, 'Id of database.')
|
|
->addOption('collection_id', null, InputOption::VALUE_OPTIONAL, 'Id of the collection.')
|
|
->addOption('mail_lock_status', null, InputOption::VALUE_NONE, 'Status by mail locked')
|
|
->addOption('guest', null, InputOption::VALUE_NONE, 'Only guest user')
|
|
->addOption('created', null, InputOption::VALUE_OPTIONAL, 'Created at with operator,aaaa-mm-jj hh:mm:ss.')
|
|
->addOption('updated', null, InputOption::VALUE_OPTIONAL, 'Update at with operator,aaaa-mm-jj hh:mm:ss.')
|
|
->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('adress', null, InputOption::VALUE_NONE, 'Show adress information')
|
|
->setHelp('');
|
|
|
|
return $this;
|
|
}
|
|
|
|
protected function doExecute(InputInterface $input, OutputInterface $output)
|
|
{
|
|
|
|
$userId = $input->getOption('user_id');
|
|
$userEmail = $input->getOption('user_email');
|
|
$databaseId = $input->getOption('database_id');
|
|
$collectionId = $input->getOption('collection_id');
|
|
$lockStatus = $input->getOption('mail_lock_status');
|
|
$guest = $input->getOption('guest');
|
|
$application = $input->getOption('application');
|
|
$withAdress = $input->getOption('adress');
|
|
$created = $input->getOption('created');
|
|
$updated = $input->getOption('updated');
|
|
$withRight = $input->getOption('right');
|
|
|
|
$query = $this->container['phraseanet.user-query'];
|
|
|
|
if($databaseId) $query->on_base_ids([$databaseId]);
|
|
if($collectionId) $query->on_sbas_ids([$collectionId]);
|
|
if($created) $this->addFilterDate($created,'created',$query);
|
|
if($updated) $this->addFilterDate($updated,'updated',$query);
|
|
if($userId) $query->addSqlFilter('Users.id = ?' ,[$userId]);
|
|
if($userEmail) $query->addSqlFilter('Users.email = ?' ,[$userEmail]);
|
|
if($lockStatus) $query->addSqlFilter('Users.mail_locked = 1');
|
|
if($guest) $query->include_invite(true)->addSqlFilter('Users.guest = 1');
|
|
|
|
if ($application and !$userId) {
|
|
$output->writeln('<error>You must provide --user_id when using --application option</error>');
|
|
return 0;
|
|
}
|
|
|
|
$users = $query
|
|
->execute()->get_results();
|
|
|
|
$userList = [];
|
|
$showApplication = false;
|
|
foreach ($users as $key => $user) {
|
|
if ($userId and $application) {
|
|
$showApplication = true;
|
|
}
|
|
$userList[] = $this->listUser($user,$withAdress,$withRight);
|
|
}
|
|
|
|
$table = $this->getHelperSet()->get('table');
|
|
$table
|
|
->setHeaders($this->headerTable($withAdress,$withRight))
|
|
->setRows($userList)
|
|
->render($output);
|
|
;
|
|
|
|
if ($showApplication) {
|
|
$applicationTable = $this->getHelperSet()->get('table');
|
|
$applicationTable->setHeaders(array(
|
|
array(new TableCell('Applications', array('colspan' => 5))),
|
|
['name','callback','client_secret','client_id','token'],
|
|
))->setRows($this->getApplicationOfUser($users[0]))->render($output);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
/**
|
|
* @param $withAdress
|
|
* @param $withRight
|
|
* @return array
|
|
*/
|
|
private function headerTable($withAdress,$withRight)
|
|
{
|
|
$defaultHeader = ['id', 'login', 'email','last_model','first_name','last_name','gender','created','updated','status','locale'];
|
|
$adressHeader = [ 'address', 'zip_code', 'city', 'country', 'phone', 'fax', 'job','position', 'company', 'geoname_id'];
|
|
$rightHeader = [ 'admin', 'guest', 'mail_notification', 'ldap_created', 'mail_locked'];
|
|
|
|
return $this->createInformation($withAdress,$withRight,$defaultHeader,['adress' => $adressHeader,'right' =>$rightHeader]);
|
|
}
|
|
|
|
/**
|
|
* @param User $user
|
|
* @param $withAdress
|
|
* @param $withRight
|
|
* @return array
|
|
*/
|
|
private function listUser(User $user,$withAdress,$withRight)
|
|
{
|
|
switch ($user->getGender()) {
|
|
case User::GENDER_MRS:
|
|
$gender = 'Mrs';
|
|
break;
|
|
case User::GENDER_MISS:
|
|
$gender = 'Miss';
|
|
break;
|
|
case User::GENDER_MR:
|
|
default:
|
|
$gender = 'Mr';
|
|
}
|
|
|
|
$defaultInfo = [
|
|
$user->getId(),
|
|
$user->getLogin() ?: '-',
|
|
$user->getEmail() ?: '-',
|
|
$user->getLastAppliedTemplate() ? $user->getLastAppliedTemplate()->getLogin() : '-',
|
|
$user->getFirstName() ?: '-',
|
|
$user->getLastName() ?: '-',
|
|
$gender,
|
|
NullableDateTime::format($user->getCreated(),'Y-m-d H:i:s'),
|
|
NullableDateTime::format($user->getUpdated(),'Y-m-d H:i:s'),
|
|
'status',
|
|
$user->getLocale() ?: '-',
|
|
];
|
|
|
|
return $this->createInformation($withAdress,$withRight,$defaultInfo,['adress' => $this->userAdress($user),'right' => $this->userRight($user)]);
|
|
}
|
|
|
|
/**
|
|
* @param User $user
|
|
* @return array
|
|
*/
|
|
private function userAdress(User $user)
|
|
{
|
|
return [
|
|
$user->getAddress() ?: '-',
|
|
$user->getZipCode() ?: '-',
|
|
$user->getCity() ?: '-',
|
|
$user->getCountry() ?: '-',
|
|
$user->getPhone() ?: '-',
|
|
$user->getFax() ?: '-',
|
|
$user->getJob() ?: '-',
|
|
$user->getActivity() ?: '-',
|
|
$user->getCompany() ?: '-',
|
|
$user->getGeonameId() ?: '-',
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @param User $user
|
|
* @return array
|
|
*/
|
|
private function userRight(User $user)
|
|
{
|
|
return [
|
|
$user->isAdmin() ?: false,
|
|
$user->isGuest() ?: false,
|
|
$user->hasMailNotificationsActivated() ?: false,
|
|
$user->hasLdapCreated() ?: false,
|
|
$user->isMailLocked() ?: false,
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @param User $user
|
|
* @return array
|
|
*/
|
|
private function getApplicationOfUser(User $user)
|
|
{
|
|
$apiRepository = $this->container['repo.api-applications'];
|
|
$applications = $apiRepository->findByUser($user);
|
|
|
|
if (empty($applications)) {
|
|
return [];
|
|
}
|
|
|
|
$accountRepository = $this->container['repo.api-accounts'];
|
|
$apiOauthRepository = $this->container['repo.api-oauth-tokens'];
|
|
$usersApplication = [];
|
|
foreach ($applications as $application) {
|
|
$account = $accountRepository->findByUserAndApplication($user, $application);
|
|
$token = $account ? $apiOauthRepository->findDeveloperToken($account) : null;
|
|
$usersApplication[] = [
|
|
$application->getName(),
|
|
$application->getRedirectUri(),
|
|
$application->getClientSecret(),
|
|
$application->getClientId(),
|
|
($token) ? $token->getOauthToken() : '-'
|
|
];
|
|
}
|
|
|
|
return $usersApplication;
|
|
}
|
|
|
|
/**
|
|
* @param $withAdress
|
|
* @param $withRight
|
|
* @param $default
|
|
* @param $infoToMerge
|
|
* @return array
|
|
*/
|
|
private function createInformation($withAdress,$withRight,$default,$infoToMerge)
|
|
{
|
|
if ($withAdress && $withRight) {
|
|
$information = array_merge($default, $infoToMerge['adress'],$infoToMerge['right']);
|
|
} elseif ($withAdress && !$withRight) {
|
|
$information = array_merge($default, $infoToMerge['adress']);
|
|
} elseif(!$withAdress && $withRight) {
|
|
$information = array_merge($default, $infoToMerge['right']);
|
|
} else {
|
|
$information = $default;
|
|
}
|
|
|
|
return $information;
|
|
}
|
|
|
|
/**
|
|
* @param $date
|
|
* @param $type
|
|
* @param $query
|
|
*/
|
|
private function addFilterDate($date,$type,$query){
|
|
|
|
list($operator,$dateAt) = explode(',', $date);
|
|
|
|
if (!in_array($operator,['=','>=','<=','>','<'])) {
|
|
throw new \InvalidArgumentException(" '=' or '<=' or '>=' or '>' or '<'");
|
|
}
|
|
|
|
$query->addSqlFilter($type.$operator.' ?' ,[$dateAt]);
|
|
}
|
|
|
|
}
|