aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings/lib/SetupChecks/CheckUserCertificates.php
diff options
context:
space:
mode:
authorCôme Chilliet <91878298+come-nc@users.noreply.github.com>2023-10-19 15:41:23 +0200
committerGitHub <noreply@github.com>2023-10-19 15:41:23 +0200
commitb6c35b3be0a2c2a26e6409990a3855c36fa06ce9 (patch)
tree8c00ba871704c3a2dbf982704cbb3389bb66d8a8 /apps/settings/lib/SetupChecks/CheckUserCertificates.php
parent049804d02f05c6dc26109b25aec965e8f3188665 (diff)
parent789ff3f414fe9d128b6831b9981b2425ce0849d0 (diff)
downloadnextcloud-server-b6c35b3be0a2c2a26e6409990a3855c36fa06ce9.tar.gz
nextcloud-server-b6c35b3be0a2c2a26e6409990a3855c36fa06ce9.zip
Merge pull request #32550 from nextcloud/feat/api-cleanup-check
Add api to register setup checks
Diffstat (limited to 'apps/settings/lib/SetupChecks/CheckUserCertificates.php')
-rw-r--r--apps/settings/lib/SetupChecks/CheckUserCertificates.php54
1 files changed, 20 insertions, 34 deletions
diff --git a/apps/settings/lib/SetupChecks/CheckUserCertificates.php b/apps/settings/lib/SetupChecks/CheckUserCertificates.php
index 52fea7b6551..e09ef267e07 100644
--- a/apps/settings/lib/SetupChecks/CheckUserCertificates.php
+++ b/apps/settings/lib/SetupChecks/CheckUserCertificates.php
@@ -4,6 +4,7 @@ declare(strict_types=1);
/**
* @copyright Copyright (c) 2020 Morris Jobke <hey@morrisjobke.de>
+ * @copyright Copyright (c) 2022 Carl Schwan <carl@carlschwan.eu>
*
* @author Morris Jobke <hey@morrisjobke.de>
*
@@ -27,50 +28,35 @@ namespace OCA\Settings\SetupChecks;
use OCP\IConfig;
use OCP\IL10N;
-use OCP\IURLGenerator;
+use OCP\SetupCheck\ISetupCheck;
+use OCP\SetupCheck\SetupResult;
-class CheckUserCertificates {
- /** @var IL10N */
- private $l10n;
- /** @var string */
- private $configValue;
- /** @var IURLGenerator */
- private $urlGenerator;
+class CheckUserCertificates implements ISetupCheck {
+ private string $configValue;
- public function __construct(IL10N $l10n, IConfig $config, IURLGenerator $urlGenerator) {
- $this->l10n = $l10n;
- $configValue = $config->getAppValue('files_external', 'user_certificate_scan', '');
- $this->configValue = $configValue;
- $this->urlGenerator = $urlGenerator;
+ public function __construct(
+ private IL10N $l10n,
+ IConfig $config,
+ ) {
+ $this->configValue = $config->getAppValue('files_external', 'user_certificate_scan', '');
}
- public function description(): string {
- if ($this->configValue === '') {
- return '';
- }
- if ($this->configValue === 'not-run-yet') {
- return $this->l10n->t('A background job is pending that checks for user imported SSL certificates. Please check back later.');
- }
- return $this->l10n->t('There are some user imported SSL certificates present, that are not used anymore with Nextcloud 21. They can be imported on the command line via "occ security:certificates:import" command. Their paths inside the data directory are shown below.');
+ public function getCategory(): string {
+ return 'security';
}
- public function severity(): string {
- return 'warning';
+ public function getName(): string {
+ return $this->l10n->t('Checking for old user imported certificate');
}
- public function run(): bool {
+ public function run(): SetupResult {
// all fine if neither "not-run-yet" nor a result
- return $this->configValue === '';
- }
-
- public function elements(): array {
- if ($this->configValue === '' || $this->configValue === 'not-run-yet') {
- return [];
+ if ($this->configValue === '') {
+ return SetupResult::success();
}
- $data = json_decode($this->configValue);
- if (!is_array($data)) {
- return [];
+ if ($this->configValue === 'not-run-yet') {
+ return SetupResult::info($this->l10n->t('A background job is pending that checks for user imported SSL certificates. Please check back later.'));
}
- return $data;
+ return SetupResult::error($this->l10n->t('There are some user imported SSL certificates present, that are not used anymore with Nextcloud 21. They can be imported on the command line via "occ security:certificates:import" command. Their paths inside the data directory are shown below.'));
}
}