mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-07 13:21:02 +01:00
b0d815d157
Summary: When configuration is set incorrectly (e.g., of the wrong type), detect and repair it by setting it to the default value. A setup warning will be raised separately. Notably, this removes the need to hard-code all the class types. This runs separately from the "invalid config" check because we need to run it on every page, but do setup checks only once per restart (some of them are slow). Also dirty setup when we edit configuration. Test Plan: Set config incorrectly on purpose, saw Phabricator correct it on restart and on every subsequent page load until it was fixed. Reviewers: btrahan, vrana Reviewed By: vrana CC: aran Maniphest Tasks: T2292 Differential Revision: https://secure.phabricator.com/D4492
30 lines
967 B
PHP
30 lines
967 B
PHP
<?php
|
|
|
|
final class PhabricatorSetupCheckInvalidConfig extends PhabricatorSetupCheck {
|
|
|
|
protected function executeChecks() {
|
|
$groups = PhabricatorApplicationConfigOptions::loadAll();
|
|
foreach ($groups as $group) {
|
|
$options = $group->getOptions();
|
|
foreach ($options as $option) {
|
|
try {
|
|
$group->validateOption(
|
|
$option,
|
|
PhabricatorEnv::getUnrepairedEnvConfig($option->getKey()));
|
|
} catch (PhabricatorConfigValidationException $ex) {
|
|
$this
|
|
->newIssue('config.invalid.'.$option->getKey())
|
|
->setName(pht("Config '%s' Invalid", $option->getKey()))
|
|
->setMessage(
|
|
pht(
|
|
"Configuration option '%s' has invalid value and ".
|
|
"was restored to the default: %s",
|
|
$option->getKey(),
|
|
$ex->getMessage()))
|
|
->addPhabricatorConfig($option->getKey());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|