SetupCheckManager.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * @copyright Copyright (c) 2022 Carl Schwan <carl@carlschwan.eu>
  5. *
  6. * @author Carl Schwan <carl@carlschwan.eu>
  7. * @author Côme Chilliet <come.chilliet@nextcloud.com>
  8. *
  9. * @license AGPL-3.0
  10. *
  11. * This code is free software: you can redistribute it and/or modify
  12. * it under the terms of the GNU Affero General Public License, version 3,
  13. * as published by the Free Software Foundation.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU Affero General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU Affero General Public License, version 3,
  21. * along with this program. If not, see <http://www.gnu.org/licenses/>
  22. *
  23. */
  24. namespace OC\SetupCheck;
  25. use OC\AppFramework\Bootstrap\Coordinator;
  26. use OCP\Server;
  27. use OCP\SetupCheck\ISetupCheck;
  28. use OCP\SetupCheck\ISetupCheckManager;
  29. use OCP\SetupCheck\SetupResult;
  30. use Psr\Log\LoggerInterface;
  31. class SetupCheckManager implements ISetupCheckManager {
  32. public function __construct(
  33. private Coordinator $coordinator,
  34. private LoggerInterface $logger,
  35. ) {
  36. }
  37. public function runAll(): array {
  38. $results = [];
  39. $setupChecks = $this->coordinator->getRegistrationContext()->getSetupChecks();
  40. foreach ($setupChecks as $setupCheck) {
  41. /** @var ISetupCheck $setupCheckObject */
  42. $setupCheckObject = Server::get($setupCheck->getService());
  43. $this->logger->debug('Running check '.get_class($setupCheckObject));
  44. try {
  45. $setupResult = $setupCheckObject->run();
  46. } catch (\Throwable $t) {
  47. $setupResult = SetupResult::error("An exception occured while running the setup check:\n$t");
  48. $this->logger->error('Exception running check '.get_class($setupCheckObject).': '.$t->getMessage(), ['exception' => $t]);
  49. }
  50. $setupResult->setName($setupCheckObject->getName());
  51. $category = $setupCheckObject->getCategory();
  52. $results[$category] ??= [];
  53. $results[$category][$setupCheckObject::class] = $setupResult;
  54. }
  55. return $results;
  56. }
  57. }