0
0
Fork 0
mirror of https://github.com/nextcloud/server.git synced 2025-05-20 13:10:13 +00:00
nextcloud_server/apps/dav/lib/Db/PropertyMapper.php
SebastianKrupinski 477bc4e3f1 fix: add calendar enable
Signed-off-by: SebastianKrupinski <krupinskis05@gmail.com>
2025-05-09 09:05:21 -04:00

55 lines
1.4 KiB
PHP

<?php
declare(strict_types=1);
/**
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace OCA\DAV\Db;
use OCP\AppFramework\Db\QBMapper;
use OCP\IDBConnection;
/**
* @template-extends QBMapper<Property>
*/
class PropertyMapper extends QBMapper {
private const TABLE_NAME = 'properties';
public function __construct(IDBConnection $db) {
parent::__construct($db, self::TABLE_NAME, Property::class);
}
/**
* @return Property[]
*/
public function findPropertyByPathAndName(string $userId, string $path, string $name): array {
$selectQb = $this->db->getQueryBuilder();
$selectQb->select('*')
->from(self::TABLE_NAME)
->where(
$selectQb->expr()->eq('userid', $selectQb->createNamedParameter($userId)),
$selectQb->expr()->eq('propertypath', $selectQb->createNamedParameter($path)),
$selectQb->expr()->eq('propertyname', $selectQb->createNamedParameter($name)),
);
return $this->findEntities($selectQb);
}
/**
* @return Property[]
*/
public function findPropertiesByPath(string $userId, string $path): array {
$selectQb = $this->db->getQueryBuilder();
$selectQb->select('*')
->from(self::TABLE_NAME)
->where(
$selectQb->expr()->eq('userid', $selectQb->createNamedParameter($userId)),
$selectQb->expr()->eq('propertypath', $selectQb->createNamedParameter($path)),
);
return $this->findEntities($selectQb);
}
}