mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-11 17:32:41 +01:00
298604c9d3
Summary: Fixes T6084. Changes: - Rename `phabricator.show-beta-applications` to `phabricator.show-prototypes`, to reinforce that these include early-development applications. - Migrate the config setting. - Add an explicit "no support" banner to the config page. - Rename "Beta" to "Prototype" in the UI. - Use "bomb" icon instead of "half star" icon. - Document prototype applications in more detail. - Explicitly document that we do not support these applications. Test Plan: - Ran migration. - Resolved "obsolete config" issue. - Viewed config setting. - Browsed prototypes in Applications app. - Viewed documentation. Reviewers: chad, btrahan Reviewed By: btrahan Subscribers: epriestley, hach-que Maniphest Tasks: T6084 Differential Revision: https://secure.phabricator.com/D10493
201 lines
7 KiB
PHP
201 lines
7 KiB
PHP
<?php
|
|
|
|
final class PhabricatorSetupCheckExtraConfig extends PhabricatorSetupCheck {
|
|
|
|
protected function executeChecks() {
|
|
$ancient_config = self::getAncientConfig();
|
|
|
|
$all_keys = PhabricatorEnv::getAllConfigKeys();
|
|
$all_keys = array_keys($all_keys);
|
|
sort($all_keys);
|
|
|
|
$defined_keys = PhabricatorApplicationConfigOptions::loadAllOptions();
|
|
|
|
foreach ($all_keys as $key) {
|
|
if (isset($defined_keys[$key])) {
|
|
continue;
|
|
}
|
|
|
|
if (isset($ancient_config[$key])) {
|
|
$summary = pht(
|
|
'This option has been removed. You may delete it at your '.
|
|
'convenience.');
|
|
$message = pht(
|
|
"The configuration option '%s' has been removed. You may delete ".
|
|
"it at your convenience.".
|
|
"\n\n%s",
|
|
$key,
|
|
$ancient_config[$key]);
|
|
$short = pht('Obsolete Config');
|
|
$name = pht('Obsolete Configuration Option "%s"', $key);
|
|
} else {
|
|
$summary = pht('This option is not recognized. It may be misspelled.');
|
|
$message = pht(
|
|
"The configuration option '%s' is not recognized. It may be ".
|
|
"misspelled, or it might have existed in an older version of ".
|
|
"Phabricator. It has no effect, and should be corrected or deleted.",
|
|
$key);
|
|
$short = pht('Unknown Config');
|
|
$name = pht('Unknown Configuration Option "%s"', $key);
|
|
}
|
|
|
|
$issue = $this->newIssue('config.unknown.'.$key)
|
|
->setShortName($short)
|
|
->setName($name)
|
|
->setSummary($summary);
|
|
|
|
$stack = PhabricatorEnv::getConfigSourceStack();
|
|
$stack = $stack->getStack();
|
|
|
|
$found = array();
|
|
$found_local = false;
|
|
$found_database = false;
|
|
|
|
foreach ($stack as $source_key => $source) {
|
|
$value = $source->getKeys(array($key));
|
|
if ($value) {
|
|
$found[] = $source->getName();
|
|
if ($source instanceof PhabricatorConfigDatabaseSource) {
|
|
$found_database = true;
|
|
}
|
|
if ($source instanceof PhabricatorConfigLocalSource) {
|
|
$found_local = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
$message = $message."\n\n".pht(
|
|
'This configuration value is defined in these %d '.
|
|
'configuration source(s): %s.',
|
|
count($found),
|
|
implode(', ', $found));
|
|
$issue->setMessage($message);
|
|
|
|
if ($found_local) {
|
|
$command = csprintf('phabricator/ $ ./bin/config delete %s', $key);
|
|
$issue->addCommand($command);
|
|
}
|
|
|
|
if ($found_database) {
|
|
$issue->addPhabricatorConfig($key);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return a map of deleted config options. Keys are option keys; values are
|
|
* explanations of what happened to the option.
|
|
*/
|
|
public static function getAncientConfig() {
|
|
$reason_auth = pht(
|
|
'This option has been migrated to the "Auth" application. Your old '.
|
|
'configuration is still in effect, but now stored in "Auth" instead of '.
|
|
'configuration. Going forward, you can manage authentication from '.
|
|
'the web UI.');
|
|
|
|
$auth_config = array(
|
|
'controller.oauth-registration',
|
|
'auth.password-auth-enabled',
|
|
'facebook.auth-enabled',
|
|
'facebook.registration-enabled',
|
|
'facebook.auth-permanent',
|
|
'facebook.application-id',
|
|
'facebook.application-secret',
|
|
'facebook.require-https-auth',
|
|
'github.auth-enabled',
|
|
'github.registration-enabled',
|
|
'github.auth-permanent',
|
|
'github.application-id',
|
|
'github.application-secret',
|
|
'google.auth-enabled',
|
|
'google.registration-enabled',
|
|
'google.auth-permanent',
|
|
'google.application-id',
|
|
'google.application-secret',
|
|
'ldap.auth-enabled',
|
|
'ldap.hostname',
|
|
'ldap.port',
|
|
'ldap.base_dn',
|
|
'ldap.search_attribute',
|
|
'ldap.search-first',
|
|
'ldap.username-attribute',
|
|
'ldap.real_name_attributes',
|
|
'ldap.activedirectory_domain',
|
|
'ldap.version',
|
|
'ldap.referrals',
|
|
'ldap.anonymous-user-name',
|
|
'ldap.anonymous-user-password',
|
|
'ldap.start-tls',
|
|
'disqus.auth-enabled',
|
|
'disqus.registration-enabled',
|
|
'disqus.auth-permanent',
|
|
'disqus.application-id',
|
|
'disqus.application-secret',
|
|
'phabricator.oauth-uri',
|
|
'phabricator.auth-enabled',
|
|
'phabricator.registration-enabled',
|
|
'phabricator.auth-permanent',
|
|
'phabricator.application-id',
|
|
'phabricator.application-secret',
|
|
);
|
|
|
|
$ancient_config = array_fill_keys($auth_config, $reason_auth);
|
|
|
|
$markup_reason = pht(
|
|
'Custom remarkup rules are now added by subclassing '.
|
|
'PhabricatorRemarkupCustomInlineRule or '.
|
|
'PhabricatorRemarkupCustomBlockRule.');
|
|
|
|
$session_reason = pht(
|
|
'Sessions now expire and are garbage collected rather than having an '.
|
|
'arbitrary concurrency limit.');
|
|
|
|
$differential_field_reason = pht(
|
|
'All Differential fields are now managed through the configuration '.
|
|
'option "%s". Use that option to configure which fields are shown.',
|
|
'differential.fields');
|
|
|
|
$ancient_config += array(
|
|
'phid.external-loaders' =>
|
|
pht(
|
|
'External loaders have been replaced. Extend `PhabricatorPHIDType` '.
|
|
'to implement new PHID and handle types.'),
|
|
'maniphest.custom-task-extensions-class' =>
|
|
pht(
|
|
'Maniphest fields are now loaded automatically. You can configure '.
|
|
'them with `maniphest.fields`.'),
|
|
'maniphest.custom-fields' =>
|
|
pht(
|
|
'Maniphest fields are now defined in '.
|
|
'`maniphest.custom-field-definitions`. Existing definitions have '.
|
|
'been migrated.'),
|
|
'differential.custom-remarkup-rules' => $markup_reason,
|
|
'differential.custom-remarkup-block-rules' => $markup_reason,
|
|
'auth.sshkeys.enabled' => pht(
|
|
'SSH keys are now actually useful, so they are always enabled.'),
|
|
'differential.anonymous-access' => pht(
|
|
'Phabricator now has meaningful global access controls. See '.
|
|
'`policy.allow-public`.'),
|
|
'celerity.resource-path' => pht(
|
|
'An alternate resource map is no longer supported. Instead, use '.
|
|
'multiple maps. See T4222.'),
|
|
'metamta.send-immediately' => pht(
|
|
'Mail is now always delivered by the daemons.'),
|
|
'auth.sessions.conduit' => $session_reason,
|
|
'auth.sessions.web' => $session_reason,
|
|
'tokenizer.ondemand' => pht(
|
|
'Phabricator now manages typeahead strategies automatically.'),
|
|
'differential.revision-custom-detail-renderer' => pht(
|
|
'Obsolete; use standard rendering events instead.'),
|
|
'differential.show-host-field' => $differential_field_reason,
|
|
'differential.show-test-plan-field' => $differential_field_reason,
|
|
'differential.field-selector' => $differential_field_reason,
|
|
'phabricator.show-beta-applications' => pht(
|
|
'This option has been renamed to `phabricator.show-prototypes` '.
|
|
'to emphasize the unfinished nature of many prototype applications. '.
|
|
'Your existing setting has been migrated.'),
|
|
);
|
|
|
|
return $ancient_config;
|
|
}
|
|
}
|