feat: Add app version to the deck app export
Signed-off-by: Julius Härtl <jus@bitgrid.net>
This commit is contained in:
@@ -29,39 +29,23 @@ use OCA\Deck\Db\CardMapper;
|
|||||||
use OCA\Deck\Db\StackMapper;
|
use OCA\Deck\Db\StackMapper;
|
||||||
use OCA\Deck\Model\CardDetails;
|
use OCA\Deck\Model\CardDetails;
|
||||||
use OCA\Deck\Service\BoardService;
|
use OCA\Deck\Service\BoardService;
|
||||||
use OCP\AppFramework\Db\DoesNotExistException;
|
use OCP\App\IAppManager;
|
||||||
use OCP\AppFramework\Db\MultipleObjectsReturnedException;
|
use OCP\DB\Exception;
|
||||||
use OCP\IGroupManager;
|
|
||||||
use OCP\IUserManager;
|
|
||||||
use Symfony\Component\Console\Command\Command;
|
use Symfony\Component\Console\Command\Command;
|
||||||
use Symfony\Component\Console\Input\InputArgument;
|
use Symfony\Component\Console\Input\InputArgument;
|
||||||
use Symfony\Component\Console\Input\InputInterface;
|
use Symfony\Component\Console\Input\InputInterface;
|
||||||
use Symfony\Component\Console\Output\OutputInterface;
|
use Symfony\Component\Console\Output\OutputInterface;
|
||||||
|
|
||||||
class UserExport extends Command {
|
class UserExport extends Command {
|
||||||
protected $boardService;
|
public function __construct(
|
||||||
protected $cardMapper;
|
private IAppManager $appManager,
|
||||||
private $userManager;
|
private BoardMapper $boardMapper,
|
||||||
private $groupManager;
|
private BoardService $boardService,
|
||||||
private $assignedUsersMapper;
|
private StackMapper $stackMapper,
|
||||||
|
private CardMapper $cardMapper,
|
||||||
public function __construct(BoardMapper $boardMapper,
|
private AssignmentMapper $assignedUsersMapper,
|
||||||
BoardService $boardService,
|
) {
|
||||||
StackMapper $stackMapper,
|
|
||||||
CardMapper $cardMapper,
|
|
||||||
AssignmentMapper $assignedUsersMapper,
|
|
||||||
IUserManager $userManager,
|
|
||||||
IGroupManager $groupManager) {
|
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
|
|
||||||
$this->cardMapper = $cardMapper;
|
|
||||||
$this->boardService = $boardService;
|
|
||||||
$this->stackMapper = $stackMapper;
|
|
||||||
$this->assignedUsersMapper = $assignedUsersMapper;
|
|
||||||
$this->boardMapper = $boardMapper;
|
|
||||||
|
|
||||||
$this->userManager = $userManager;
|
|
||||||
$this->groupManager = $groupManager;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function configure() {
|
protected function configure() {
|
||||||
@@ -73,19 +57,16 @@ class UserExport extends Command {
|
|||||||
InputArgument::REQUIRED,
|
InputArgument::REQUIRED,
|
||||||
'User ID of the user'
|
'User ID of the user'
|
||||||
)
|
)
|
||||||
|
->addOption('legacy-format', 'l')
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param InputInterface $input
|
* @throws Exception
|
||||||
* @param OutputInterface $output
|
|
||||||
* @return int
|
|
||||||
* @throws DoesNotExistException
|
|
||||||
* @throws MultipleObjectsReturnedException
|
|
||||||
* @throws \ReflectionException
|
|
||||||
*/
|
*/
|
||||||
protected function execute(InputInterface $input, OutputInterface $output): int {
|
protected function execute(InputInterface $input, OutputInterface $output): int {
|
||||||
$userId = $input->getArgument('user-id');
|
$userId = $input->getArgument('user-id');
|
||||||
|
$legacyFormat = $input->getOption('legacy-format');
|
||||||
|
|
||||||
$this->boardService->setUserId($userId);
|
$this->boardService->setUserId($userId);
|
||||||
$boards = $this->boardService->findAll();
|
$boards = $this->boardService->findAll();
|
||||||
@@ -93,10 +74,10 @@ class UserExport extends Command {
|
|||||||
$data = [];
|
$data = [];
|
||||||
foreach ($boards as $board) {
|
foreach ($boards as $board) {
|
||||||
$fullBoard = $this->boardMapper->find($board->getId(), true, true);
|
$fullBoard = $this->boardMapper->find($board->getId(), true, true);
|
||||||
$data[$board->getId()] = (array)$fullBoard->jsonSerialize();
|
$data[$board->getId()] = $fullBoard->jsonSerialize();
|
||||||
$stacks = $this->stackMapper->findAll($board->getId());
|
$stacks = $this->stackMapper->findAll($board->getId());
|
||||||
foreach ($stacks as $stack) {
|
foreach ($stacks as $stack) {
|
||||||
$data[$board->getId()]['stacks'][$stack->getId()] = (array)$stack->jsonSerialize();
|
$data[$board->getId()]['stacks'][$stack->getId()] = $stack->jsonSerialize();
|
||||||
$cards = $this->cardMapper->findAllByStack($stack->getId());
|
$cards = $this->cardMapper->findAllByStack($stack->getId());
|
||||||
foreach ($cards as $card) {
|
foreach ($cards as $card) {
|
||||||
$fullCard = $this->cardMapper->find($card->getId());
|
$fullCard = $this->cardMapper->find($card->getId());
|
||||||
@@ -108,7 +89,12 @@ class UserExport extends Command {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$output->writeln(json_encode($data, JSON_PRETTY_PRINT));
|
$output->writeln(json_encode(
|
||||||
|
$legacyFormat ? $data : [
|
||||||
|
'version' => $this->appManager->getAppVersion('deck'),
|
||||||
|
'boards' => $data
|
||||||
|
],
|
||||||
|
JSON_PRETTY_PRINT));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user