summaryrefslogtreecommitdiffstats
path: root/apps/dav
diff options
context:
space:
mode:
authorChristoph Wurst <ChristophWurst@users.noreply.github.com>2021-12-03 13:18:04 +0100
committerGitHub <noreply@github.com>2021-12-03 13:18:04 +0100
commit82fc20f9d2225886a07200275e5b9d432e81772e (patch)
tree9dad8f355fd30997e4442d3b3aaddcbf38b53b52 /apps/dav
parentb067ae78c5a8044e8066fe742d61c712387e7aa5 (diff)
parent7b2fb9295ed2310af81adb38b79380d5ebb93b68 (diff)
downloadnextcloud-server-82fc20f9d2225886a07200275e5b9d432e81772e.tar.gz
nextcloud-server-82fc20f9d2225886a07200275e5b9d432e81772e.zip
Merge pull request #30054 from nextcloud/refactor/cleaner-dav-background-resource-job
✨ Clean up the DAV resource background job
Diffstat (limited to 'apps/dav')
-rw-r--r--apps/dav/lib/BackgroundJob/UpdateCalendarResourcesRoomsBackgroundJob.php79
1 files changed, 43 insertions, 36 deletions
diff --git a/apps/dav/lib/BackgroundJob/UpdateCalendarResourcesRoomsBackgroundJob.php b/apps/dav/lib/BackgroundJob/UpdateCalendarResourcesRoomsBackgroundJob.php
index e9326309c7d..9b3aeac5904 100644
--- a/apps/dav/lib/BackgroundJob/UpdateCalendarResourcesRoomsBackgroundJob.php
+++ b/apps/dav/lib/BackgroundJob/UpdateCalendarResourcesRoomsBackgroundJob.php
@@ -1,4 +1,7 @@
<?php
+
+declare(strict_types=1);
+
/**
* @copyright 2019, Georg Ehrke <oc.list@georgehrke.com>
*
@@ -22,6 +25,7 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
+
namespace OCA\DAV\BackgroundJob;
use OC\BackgroundJob\TimedJob;
@@ -49,14 +53,6 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
/** @var CalDavBackend */
private $calDavBackend;
- /**
- * UpdateCalendarResourcesRoomsBackgroundJob constructor.
- *
- * @param IResourceManager $resourceManager
- * @param IRoomManager $roomManager
- * @param IDBConnection $dbConnection
- * @param CalDavBackend $calDavBackend
- */
public function __construct(IResourceManager $resourceManager,
IRoomManager $roomManager,
IDBConnection $dbConnection,
@@ -73,7 +69,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
/**
* @param $argument
*/
- public function run($argument):void {
+ public function run($argument): void {
$this->runForBackend(
$this->resourceManager,
'calendar_resources',
@@ -104,7 +100,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
string $dbTable,
string $dbTableMetadata,
string $foreignKey,
- string $principalPrefix):void {
+ string $principalPrefix): void {
$backends = $backendManager->getBackends();
foreach ($backends as $backend) {
@@ -190,11 +186,12 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
* @param string $table
* @param string $backendId
* @param IResource|IRoom $remote
+ *
* @return int Insert id
*/
private function addToCache(string $table,
string $backendId,
- $remote):int {
+ $remote): int {
$query = $this->dbConnection->getQueryBuilder();
$query->insert($table)
->values([
@@ -207,7 +204,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
$remote->getGroupRestrictions()
))
])
- ->execute();
+ ->executeStatement();
return $query->getLastInsertId();
}
@@ -220,7 +217,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
private function addMetadataToCache(string $table,
string $foreignKey,
int $foreignId,
- array $metadata):void {
+ array $metadata): void {
foreach ($metadata as $key => $value) {
$query = $this->dbConnection->getQueryBuilder();
$query->insert($table)
@@ -229,7 +226,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
'key' => $query->createNamedParameter($key),
'value' => $query->createNamedParameter($value),
])
- ->execute();
+ ->executeStatement();
}
}
@@ -240,11 +237,11 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
* @param int $id
*/
private function deleteFromCache(string $table,
- int $id):void {
+ int $id): void {
$query = $this->dbConnection->getQueryBuilder();
$query->delete($table)
->where($query->expr()->eq('id', $query->createNamedParameter($id)))
- ->execute();
+ ->executeStatement();
}
/**
@@ -254,11 +251,11 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
*/
private function deleteMetadataFromCache(string $table,
string $foreignKey,
- int $id):void {
+ int $id): void {
$query = $this->dbConnection->getQueryBuilder();
$query->delete($table)
->where($query->expr()->eq($foreignKey, $query->createNamedParameter($id)))
- ->execute();
+ ->executeStatement();
}
/**
@@ -270,7 +267,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
*/
private function updateCache(string $table,
int $id,
- $remote):void {
+ $remote): void {
$query = $this->dbConnection->getQueryBuilder();
$query->update($table)
->set('email', $query->createNamedParameter($remote->getEMail()))
@@ -280,7 +277,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
$remote->getGroupRestrictions()
)))
->where($query->expr()->eq('id', $query->createNamedParameter($id)))
- ->execute();
+ ->executeStatement();
}
/**
@@ -294,7 +291,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
string $foreignKey,
int $id,
array $metadata,
- array $cachedMetadata):void {
+ array $cachedMetadata): void {
$newMetadata = array_diff_key($metadata, $cachedMetadata);
$deletedMetadata = array_diff_key($cachedMetadata, $metadata);
@@ -306,7 +303,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
'key' => $query->createNamedParameter($key),
'value' => $query->createNamedParameter($value),
])
- ->execute();
+ ->executeStatement();
}
foreach ($deletedMetadata as $key => $value) {
@@ -314,7 +311,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
$query->delete($dbTable)
->where($query->expr()->eq($foreignKey, $query->createNamedParameter($id)))
->andWhere($query->expr()->eq('key', $query->createNamedParameter($key)))
- ->execute();
+ ->executeStatement();
}
$existingKeys = array_keys(array_intersect_key($metadata, $cachedMetadata));
@@ -325,7 +322,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
->set('value', $query->createNamedParameter($metadata[$existingKey]))
->where($query->expr()->eq($foreignKey, $query->createNamedParameter($id)))
->andWhere($query->expr()->eq('key', $query->createNamedParameter($existingKey)))
- ->execute();
+ ->executeStatement();
}
}
}
@@ -334,9 +331,10 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
* serialize array of group restrictions to store them in database
*
* @param array $groups
+ *
* @return string
*/
- private function serializeGroupRestrictions(array $groups):string {
+ private function serializeGroupRestrictions(array $groups): string {
return \json_encode($groups);
}
@@ -344,9 +342,10 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
* Gets all metadata of a backend
*
* @param IResource|IRoom $resource
+ *
* @return array
*/
- private function getAllMetadataOfBackend($resource):array {
+ private function getAllMetadataOfBackend($resource): array {
if (!($resource instanceof IMetadataProvider)) {
return [];
}
@@ -364,17 +363,19 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
* @param string $table
* @param string $foreignKey
* @param int $id
+ *
* @return array
*/
private function getAllMetadataOfCache(string $table,
string $foreignKey,
- int $id):array {
+ int $id): array {
$query = $this->dbConnection->getQueryBuilder();
$query->select(['key', 'value'])
->from($table)
->where($query->expr()->eq($foreignKey, $query->createNamedParameter($id)));
- $stmt = $query->execute();
- $rows = $stmt->fetchAll(\PDO::FETCH_ASSOC);
+ $result = $query->executeQuery();
+ $rows = $result->fetchAll();
+ $result->closeCursor();
$metadata = [];
foreach ($rows as $row) {
@@ -389,19 +390,22 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
*
* @param $tableName
* @param $backendId
+ *
* @return array
*/
private function getAllCachedByBackend(string $tableName,
- string $backendId):array {
+ string $backendId): array {
$query = $this->dbConnection->getQueryBuilder();
$query->select('resource_id')
->from($tableName)
->where($query->expr()->eq('backend_id', $query->createNamedParameter($backendId)));
- $stmt = $query->execute();
+ $result = $query->executeQuery();
+ $rows = $result->fetchAll();
+ $result->closeCursor();
return array_map(function ($row): string {
return $row['resource_id'];
- }, $stmt->fetchAll());
+ }, $rows);
}
/**
@@ -409,7 +413,7 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
* @param $principalUri
*/
private function deleteCalendarDataForResource(string $principalPrefix,
- string $principalUri):void {
+ string $principalUri): void {
$calendar = $this->calDavBackend->getCalendarByUri(
implode('/', [$principalPrefix, $principalUri]),
CalDavBackend::RESOURCE_BOOKING_CALENDAR_URI);
@@ -426,18 +430,21 @@ class UpdateCalendarResourcesRoomsBackgroundJob extends TimedJob {
* @param $table
* @param $backendId
* @param $resourceId
+ *
* @return int
*/
private function getIdForBackendAndResource(string $table,
string $backendId,
- string $resourceId):int {
+ string $resourceId): int {
$query = $this->dbConnection->getQueryBuilder();
$query->select('id')
->from($table)
->where($query->expr()->eq('backend_id', $query->createNamedParameter($backendId)))
->andWhere($query->expr()->eq('resource_id', $query->createNamedParameter($resourceId)));
- $stmt = $query->execute();
+ $result = $query->executeQuery();
- return $stmt->fetch()['id'];
+ $id = (int) $result->fetchOne();
+ $result->closeCursor();
+ return $id;
}
}