103 lines
2.3 KiB
PHP
103 lines
2.3 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
|
/**
|
|
* SPDX-FileCopyrightText: 2022 F7cloud GmbH and F7cloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
|
|
namespace OCA\RelatedResources\Db;
|
|
|
|
use OCA\RelatedResources\Exceptions\DeckDataNotFoundException;
|
|
use OCA\RelatedResources\Model\DeckBoard;
|
|
use OCA\RelatedResources\Model\DeckShare;
|
|
use OCP\Share\IShare;
|
|
|
|
class DeckRequest extends DeckRequestBuilder {
|
|
/**
|
|
* @param int $itemId
|
|
*
|
|
* @return DeckBoard
|
|
* @throws DeckDataNotFoundException
|
|
*/
|
|
public function getBoardById(int $itemId): DeckBoard {
|
|
$qb = $this->getDeckBoardSelectSql();
|
|
$qb->limitInt('id', $itemId);
|
|
|
|
return $this->getDeckFromRequest($qb);
|
|
}
|
|
|
|
|
|
/**
|
|
* @param int $boardId
|
|
*
|
|
* @return DeckShare[]
|
|
*/
|
|
public function getSharesByBoardId(int $boardId): array {
|
|
$qb = $this->getDeckShareSelectSql();
|
|
$qb->limitInt('board_id', $boardId);
|
|
|
|
return $this->getSharesFromRequest($qb);
|
|
}
|
|
|
|
|
|
/**
|
|
* @param string $singleId
|
|
*
|
|
* @return DeckBoard[]
|
|
*/
|
|
public function getDeckAvailableToCircle(string $singleId): array {
|
|
$qb = $this->getDeckBoardSelectSql();
|
|
$qb->innerJoin(
|
|
$qb->getDefaultSelectAlias(), self::TABLE_DECK_SHARE, 'ds',
|
|
$qb->expr()->eq($qb->getDefaultSelectAlias() . '.id', 'ds.board_id')
|
|
);
|
|
|
|
$qb->limitInt('type', IShare::TYPE_CIRCLE, 'ds');
|
|
$qb->limit('participant', $singleId, 'ds');
|
|
|
|
return $this->getDecksFromRequest($qb);
|
|
}
|
|
|
|
|
|
/**
|
|
* @param string $groupName
|
|
*
|
|
* @return DeckBoard[]
|
|
*/
|
|
public function getDeckAvailableToGroup(string $groupName): array {
|
|
$qb = $this->getDeckBoardSelectSql();
|
|
$qb->innerJoin(
|
|
$qb->getDefaultSelectAlias(), self::TABLE_DECK_SHARE, 'ds',
|
|
$qb->expr()->eq($qb->getDefaultSelectAlias() . '.id', 'ds.board_id')
|
|
);
|
|
|
|
$qb->limitInt('type', IShare::TYPE_GROUP, 'ds');
|
|
$qb->limit('participant', $groupName, 'ds');
|
|
|
|
return $this->getDecksFromRequest($qb);
|
|
}
|
|
|
|
|
|
/**
|
|
* @param string $userName
|
|
*
|
|
* @return DeckBoard[]
|
|
*/
|
|
public function getDeckAvailableToUser(string $userName): array {
|
|
$qb = $this->getDeckBoardSelectSql();
|
|
$qb->innerJoin(
|
|
$qb->getDefaultSelectAlias(), self::TABLE_DECK_SHARE, 'ds',
|
|
$qb->expr()->eq($qb->getDefaultSelectAlias() . '.id', 'ds.board_id')
|
|
);
|
|
|
|
$qb->limitInt('type', IShare::TYPE_USER, 'ds');
|
|
$qb->limit('participant', $userName, 'ds');
|
|
|
|
return $this->getDecksFromRequest($qb);
|
|
}
|
|
}
|