%PDF- %PDF-
Direktori : /www/varak.net/nextcloud.varak.net/apps_old/apps/related_resources/lib/Db/ |
Current File : //www/varak.net/nextcloud.varak.net/apps_old/apps/related_resources/lib/Db/DeckRequest.php |
<?php declare(strict_types=1); /** * SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud 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); } }