123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- <?php
- declare(strict_types=1);
- /**
- * @copyright Copyright (c) 2023 Côme Chilliet <come.chilliet@nextcloud.com>
- *
- * @author Côme Chilliet <come.chilliet@nextcloud.com>
- *
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
- */
- namespace OC\Core\Command;
- use OCP\SetupCheck\ISetupCheckManager;
- use Symfony\Component\Console\Input\InputInterface;
- use Symfony\Component\Console\Output\OutputInterface;
- class SetupChecks extends Base {
- public function __construct(
- private ISetupCheckManager $setupCheckManager,
- ) {
- parent::__construct();
- }
- protected function configure(): void {
- parent::configure();
- $this
- ->setName('setupchecks')
- ->setDescription('Run setup checks and output the results')
- ;
- }
- /**
- * @TODO move this method to a common service used by notifications, activity and this command
- * @throws \InvalidArgumentException if a parameter has no name or no type
- */
- private function richToParsed(string $message, array $parameters): string {
- $placeholders = [];
- $replacements = [];
- foreach ($parameters as $placeholder => $parameter) {
- $placeholders[] = '{' . $placeholder . '}';
- foreach (['name','type'] as $requiredField) {
- if (!isset($parameter[$requiredField]) || !is_string($parameter[$requiredField])) {
- throw new \InvalidArgumentException("Invalid rich object, {$requiredField} field is missing");
- }
- }
- $replacements[] = match($parameter['type']) {
- 'user' => '@' . $parameter['name'],
- 'file' => $parameter['path'] ?? $parameter['name'],
- default => $parameter['name'],
- };
- }
- return str_replace($placeholders, $replacements, $message);
- }
- protected function execute(InputInterface $input, OutputInterface $output): int {
- $results = $this->setupCheckManager->runAll();
- switch ($input->getOption('output')) {
- case self::OUTPUT_FORMAT_JSON:
- case self::OUTPUT_FORMAT_JSON_PRETTY:
- $this->writeArrayInOutputFormat($input, $output, $results);
- break;
- default:
- foreach ($results as $category => $checks) {
- $output->writeln("\t{$category}:");
- foreach ($checks as $check) {
- $styleTag = match ($check->getSeverity()) {
- 'success' => 'info',
- 'error' => 'error',
- 'warning' => 'comment',
- default => null,
- };
- $emoji = match ($check->getSeverity()) {
- 'success' => '✓',
- 'error' => '✗',
- 'warning' => '⚠',
- default => 'ℹ',
- };
- $verbosity = ($check->getSeverity() === 'error' ? OutputInterface::VERBOSITY_QUIET : OutputInterface::VERBOSITY_NORMAL);
- $description = $check->getDescription();
- $descriptionParameters = $check->getDescriptionParameters();
- if ($description !== null && $descriptionParameters !== null) {
- $description = $this->richToParsed($description, $descriptionParameters);
- }
- $output->writeln(
- "\t\t".
- ($styleTag !== null ? "<{$styleTag}>" : '').
- "{$emoji} ".
- ($check->getName() ?? $check::class).
- ($description !== null ? ': '.$description : '').
- ($styleTag !== null ? "</{$styleTag}>" : ''),
- $verbosity
- );
- }
- }
- }
- foreach ($results as $category => $checks) {
- foreach ($checks as $check) {
- if ($check->getSeverity() !== 'success') {
- return self::FAILURE;
- }
- }
- }
- return self::SUCCESS;
- }
- }
|