summaryrefslogtreecommitdiffstats
path: root/apps/settings/lib/SetupChecks/SchedulingTableSize.php
blob: b23972ca7dc64bb39af8bd94a0bf920426f1f49f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
<?php

declare(strict_types=1);

/**
 * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
 * SPDX-License-Identifier: AGPL-3.0-or-later
 */
namespace OCA\Settings\SetupChecks;

use OCP\IDBConnection;
use OCP\IL10N;
use OCP\SetupCheck\ISetupCheck;
use OCP\SetupCheck\SetupResult;

class SchedulingTableSize implements ISetupCheck {
	public const MAX_SCHEDULING_ENTRIES = 50000;

	public function __construct(
		private IL10N $l10n,
		private IDBConnection $connection,
	) {
	}

	public function getName(): string {
		return $this->l10n->t('Scheduling objects table size');
	}

	public function getCategory(): string {
		return 'database';
	}

	public function run(): SetupResult {
		$qb = $this->connection->getQueryBuilder();
		$qb->select($qb->func()->count('id'))
			->from('schedulingobjects');
		$query = $qb->executeQuery();
		$count = $query->fetchOne();
		$query->closeCursor();

		if ($count > self::MAX_SCHEDULING_ENTRIES) {
			return SetupResult::warning(
				$this->l10n->t('You have more than %s rows in the scheduling objects table. Please run the expensive repair jobs via occ maintenance:repair --include-expensive.', [
					self::MAX_SCHEDULING_ENTRIES,
				])
			);
		}
		return SetupResult::success(
			$this->l10n->t('Scheduling objects table size is within acceptable range.')
		);
	}
}