feat: Add app version to the deck app export

Signed-off-by: Julius Härtl <jus@bitgrid.net>
This commit is contained in:
Julius Härtl
2023-07-17 20:07:53 +02:00
parent 56e16b2d3f
commit 894c415bfd

View File

@@ -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;
} }
} }