mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 18:33:13 +00:00
Merge branch 'master' into PHRAS-1629-collection-list-jsonformat
This commit is contained in:
@@ -13,6 +13,7 @@ namespace Alchemy\Phrasea\Command\Databox;
|
|||||||
|
|
||||||
use Alchemy\Phrasea\Command\Command;
|
use Alchemy\Phrasea\Command\Command;
|
||||||
use Symfony\Component\Console\Input\InputInterface;
|
use Symfony\Component\Console\Input\InputInterface;
|
||||||
|
use Symfony\Component\Console\Input\InputOption;
|
||||||
use Symfony\Component\Console\Output\OutputInterface;
|
use Symfony\Component\Console\Output\OutputInterface;
|
||||||
|
|
||||||
class ListDataboxCommand extends Command
|
class ListDataboxCommand extends Command
|
||||||
@@ -25,6 +26,7 @@ class ListDataboxCommand extends Command
|
|||||||
parent::__construct('databox:list');
|
parent::__construct('databox:list');
|
||||||
|
|
||||||
$this->setDescription('List all databox in Phraseanet')
|
$this->setDescription('List all databox in Phraseanet')
|
||||||
|
->addOption('jsonformat', null, InputOption::VALUE_NONE, 'Output in json format')
|
||||||
->setHelp('');
|
->setHelp('');
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
@@ -33,15 +35,23 @@ class ListDataboxCommand extends Command
|
|||||||
protected function doExecute(InputInterface $input, OutputInterface $output)
|
protected function doExecute(InputInterface $input, OutputInterface $output)
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
|
$jsonformat = $input->getOption('jsonformat');
|
||||||
$databoxes = array_map(function (\databox $databox) {
|
$databoxes = array_map(function (\databox $databox) {
|
||||||
return $this->listDatabox($databox);
|
return $this->listDatabox($databox);
|
||||||
}, $this->container->getApplicationBox()->get_databoxes());
|
}, $this->container->getApplicationBox()->get_databoxes());
|
||||||
|
|
||||||
$table = $this->getHelperSet()->get('table');
|
if ($jsonformat) {
|
||||||
$table
|
foreach ($databoxes as $databox) {
|
||||||
->setHeaders(['id', 'name', 'alias'])
|
$databoxList[] = array_combine(['id', 'name', 'alias'], $databox);
|
||||||
->setRows($databoxes)
|
}
|
||||||
->render($output);
|
echo json_encode($databoxList);
|
||||||
|
} else {
|
||||||
|
$table = $this->getHelperSet()->get('table');
|
||||||
|
$table
|
||||||
|
->setHeaders(['id', 'name', 'alias'])
|
||||||
|
->setRows($databoxes)
|
||||||
|
->render($output);
|
||||||
|
}
|
||||||
|
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
$output->writeln('<error>Listing databox failed : '.$e->getMessage().'</error>');
|
$output->writeln('<error>Listing databox failed : '.$e->getMessage().'</error>');
|
||||||
|
@@ -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('jsonformat', null, InputOption::VALUE_NONE, 'Output in json format')
|
||||||
->setHelp('');
|
->setHelp('');
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
@@ -61,6 +62,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');
|
||||||
|
$jsonformat = $input->getOption('jsonformat');
|
||||||
|
|
||||||
$query = $this->container['phraseanet.user-query'];
|
$query = $this->container['phraseanet.user-query'];
|
||||||
|
|
||||||
@@ -87,24 +89,33 @@ class UserListCommand extends Command
|
|||||||
if ($userId and $application) {
|
if ($userId and $application) {
|
||||||
$showApplication = true;
|
$showApplication = true;
|
||||||
}
|
}
|
||||||
$userList[] = $this->listUser($user,$withAdress,$withRight);
|
$userList[] = $this->listUser($user, $withAdress, $withRight);
|
||||||
|
|
||||||
|
$userListRaw[] = array_combine($this->headerTable($withAdress, $withRight), $this->listUser($user, $withAdress, $withRight));
|
||||||
}
|
}
|
||||||
|
|
||||||
$table = $this->getHelperSet()->get('table');
|
if ($jsonformat) {
|
||||||
$table
|
echo json_encode($userListRaw);
|
||||||
->setHeaders($this->headerTable($withAdress,$withRight))
|
} else {
|
||||||
->setRows($userList)
|
$table = $this->getHelperSet()->get('table');
|
||||||
->render($output);
|
$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);
|
||||||
|
}
|
||||||
|
|
||||||
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;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user