3 final class PhabricatorAuthSetupCheck
extends PhabricatorSetupCheck
{
5 public function getDefaultGroup() {
6 return self
::GROUP_IMPORTANT
;
9 protected function executeChecks() {
10 // NOTE: We're not actually building these providers. Building providers
11 // can require additional configuration to be present (e.g., to build
12 // redirect and login URIs using `phabricator.base-uri`) and it won't
13 // necessarily be available when running setup checks.
15 // Since this check is only meant as a hint to new administrators about
16 // steps they should take, we don't need to be thorough about checking
17 // that providers are enabled, available, correctly configured, etc. As
18 // long as they've created some kind of provider in the auth app before,
19 // they know that it exists and don't need the hint to go check it out.
21 $configs = id(new PhabricatorAuthProviderConfigQuery())
22 ->setViewer(PhabricatorUser
::getOmnipotentUser())
28 'You have not configured any authentication providers yet. You '.
29 'should add a provider (like username/password, LDAP, or GitHub '.
30 'OAuth) so users can register and log in. You can add and configure '.
31 'providers using the Auth Application.');
34 ->newIssue('auth.noproviders')
35 ->setShortName(pht('No Auth Providers'))
36 ->setName(pht('No Authentication Providers Configured'))
37 ->setMessage($message)
38 ->addLink('/auth/', pht('Auth Application'));
43 // This check is meant for new administrators, but we don't want to
44 // show both this warning and the "No Auth Providers" warning. Also,
45 // show this as a reminder to go back and do a `bin/auth lock` after
46 // they make their desired changes.
47 $is_locked = PhabricatorEnv
::getEnvConfig('auth.lock-config');
48 if (!$is_locked && !$did_warn) {
50 'Your authentication provider configuration is unlocked. Once you '.
51 'finish setting up or modifying authentication, you should lock the '.
52 'configuration to prevent unauthorized changes.'.
54 'Leaving your authentication provider configuration unlocked '.
55 'increases the damage that a compromised administrator account can '.
56 'do to your install. For example, an attacker who compromises an '.
57 'administrator account can change authentication providers to point '.
58 'at a server they control and attempt to intercept usernames and '.
61 'To prevent this attack, you should configure authentication, and '.
62 'then lock the configuration by running "bin/auth lock" from the '.
63 'command line. This will prevent changing the authentication config '.
64 'without first running "bin/auth unlock".');
66 ->newIssue('auth.config-unlocked')
67 ->setShortName(pht('Auth Config Unlocked'))
68 ->setName(pht('Authenticaton Configuration Unlocked'))
71 'Authentication configuration is currently unlocked. Once you '.
72 'finish configuring authentication, you should lock it.'))
73 ->setMessage($message)
74 ->addRelatedPhabricatorConfig('auth.lock-config')
77 '<tt>phabricator/ $</tt> ./bin/auth lock'));