mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-05 20:31:03 +01:00
67fbfe6ccc
Summary: Ref T1191. Notable: - Allowed objects to remove default columns (some feed tables have no `id`). - Added a "note" severity and moved all the charset stuff down to that to make progress more clear. Test Plan: Trying to make the whole thing blue... {F205970} Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley Maniphest Tasks: T1191 Differential Revision: https://secure.phabricator.com/D10519
100 lines
2.6 KiB
PHP
100 lines
2.6 KiB
PHP
<?php
|
|
|
|
final class PhabricatorAuthProviderConfig extends PhabricatorAuthDAO
|
|
implements PhabricatorPolicyInterface {
|
|
|
|
protected $providerClass;
|
|
protected $providerType;
|
|
protected $providerDomain;
|
|
|
|
protected $isEnabled;
|
|
protected $shouldAllowLogin = 0;
|
|
protected $shouldAllowRegistration = 0;
|
|
protected $shouldAllowLink = 0;
|
|
protected $shouldAllowUnlink = 0;
|
|
protected $shouldTrustEmails = 0;
|
|
|
|
protected $properties = array();
|
|
|
|
private $provider;
|
|
|
|
public function generatePHID() {
|
|
return PhabricatorPHID::generateNewPHID(
|
|
PhabricatorPHIDConstants::PHID_TYPE_AUTH);
|
|
}
|
|
|
|
public function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_AUX_PHID => true,
|
|
self::CONFIG_SERIALIZATION => array(
|
|
'properties' => self::SERIALIZATION_JSON,
|
|
),
|
|
self::CONFIG_COLUMN_SCHEMA => array(
|
|
'isEnabled' => 'bool',
|
|
'providerClass' => 'text128',
|
|
'providerType' => 'text64',
|
|
'providerDomain' => 'text128',
|
|
'shouldAllowLogin' => 'bool',
|
|
'shouldAllowRegistration' => 'bool',
|
|
'shouldAllowLink' => 'bool',
|
|
'shouldAllowUnlink' => 'bool',
|
|
'shouldTrustEmails' => 'bool',
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public function getProperty($key, $default = null) {
|
|
return idx($this->properties, $key, $default);
|
|
}
|
|
|
|
public function setProperty($key, $value) {
|
|
$this->properties[$key] = $value;
|
|
return $this;
|
|
}
|
|
|
|
public function getProvider() {
|
|
if (!$this->provider) {
|
|
$base = PhabricatorAuthProvider::getAllBaseProviders();
|
|
$found = null;
|
|
foreach ($base as $provider) {
|
|
if (get_class($provider) == $this->providerClass) {
|
|
$found = $provider;
|
|
break;
|
|
}
|
|
}
|
|
if ($found) {
|
|
$this->provider = id(clone $found)->attachProviderConfig($this);
|
|
}
|
|
}
|
|
return $this->provider;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
|
|
|
|
|
public function getCapabilities() {
|
|
return array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
);
|
|
}
|
|
|
|
public function getPolicy($capability) {
|
|
switch ($capability) {
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
return PhabricatorPolicies::POLICY_USER;
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
return PhabricatorPolicies::POLICY_ADMIN;
|
|
}
|
|
}
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
return false;
|
|
}
|
|
|
|
public function describeAutomaticCapability($capability) {
|
|
return null;
|
|
}
|
|
|
|
}
|