getCalendarSelectSql(); $qb->limit('principaluri', $principalUri); $qb->limit('uri', $uri); return $this->getCalendarFromRequest($qb); } /** * @param int $calendarId * * @return CalendarShare[] */ public function getSharesByCalendarId(int $calendarId): array { $qb = $this->getCalendarShareSelectSql(); $qb->limit('type', 'calendar'); $qb->limitInt('resourceid', $calendarId); return $this->getSharesFromRequest($qb); } /** * @param string $singleId * * @return Calendar[] */ public function getCalendarAvailableToCircle(string $singleId): array { $qb = $this->getCalendarSelectSql(); $qb->innerJoin( $qb->getDefaultSelectAlias(), self::TABLE_DAV_SHARE, 'ds', $qb->expr()->eq($qb->getDefaultSelectAlias() . '.id', 'ds.resourceid') ); $qb->limit('type', 'calendar', 'ds'); $qb->limit('principaluri', 'principals/circles/' . $singleId, 'ds'); return $this->getCalendarsFromRequest($qb); } /** * @param string $groupName * * @return Calendar[] */ public function getCalendarAvailableToGroup(string $groupName): array { $qb = $this->getCalendarSelectSql(); $qb->innerJoin( $qb->getDefaultSelectAlias(), self::TABLE_DAV_SHARE, 'ds', $qb->expr()->eq($qb->getDefaultSelectAlias() . '.id', 'ds.resourceid') ); $qb->limit('type', 'calendar', 'ds'); $qb->limit('principaluri', 'principals/groups/' . $groupName, 'ds'); return $this->getCalendarsFromRequest($qb); } /** * @param string $userName * * @return Calendar[] */ public function getCalendarAvailableToUser(string $userName): array { $qb = $this->getCalendarSelectSql(); $qb->innerJoin( $qb->getDefaultSelectAlias(), self::TABLE_DAV_SHARE, 'ds', $qb->expr()->eq($qb->getDefaultSelectAlias() . '.id', 'ds.resourceid') ); $qb->limit('type', 'calendar', 'ds'); $qb->limit('principaluri', 'principals/users/' . $userName, 'ds'); return $this->getCalendarsFromRequest($qb); } }