mirror of
https://we.phorge.it/source/phorge.git
synced 2025-02-07 04:18:31 +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
133 lines
3.2 KiB
PHP
133 lines
3.2 KiB
PHP
<?php
|
|
|
|
/**
|
|
* A collection of dashboard panels with a specific layout.
|
|
*/
|
|
final class PhabricatorDashboard extends PhabricatorDashboardDAO
|
|
implements
|
|
PhabricatorPolicyInterface,
|
|
PhabricatorDestructibleInterface {
|
|
|
|
protected $name;
|
|
protected $viewPolicy;
|
|
protected $editPolicy;
|
|
protected $layoutConfig = array();
|
|
|
|
private $panelPHIDs = self::ATTACHABLE;
|
|
private $panels = self::ATTACHABLE;
|
|
|
|
public static function initializeNewDashboard(PhabricatorUser $actor) {
|
|
return id(new PhabricatorDashboard())
|
|
->setName('')
|
|
->setViewPolicy(PhabricatorPolicies::POLICY_USER)
|
|
->setEditPolicy($actor->getPHID())
|
|
->attachPanels(array())
|
|
->attachPanelPHIDs(array());
|
|
}
|
|
|
|
public static function copyDashboard(
|
|
PhabricatorDashboard $dst,
|
|
PhabricatorDashboard $src) {
|
|
|
|
$dst->name = $src->name;
|
|
$dst->layoutConfig = $src->layoutConfig;
|
|
|
|
return $dst;
|
|
}
|
|
|
|
public function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_AUX_PHID => true,
|
|
self::CONFIG_SERIALIZATION => array(
|
|
'layoutConfig' => self::SERIALIZATION_JSON,
|
|
),
|
|
self::CONFIG_COLUMN_SCHEMA => array(
|
|
'name' => 'text255',
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public function generatePHID() {
|
|
return PhabricatorPHID::generateNewPHID(
|
|
PhabricatorDashboardDashboardPHIDType::TYPECONST);
|
|
}
|
|
|
|
public function getLayoutConfigObject() {
|
|
return PhabricatorDashboardLayoutConfig::newFromDictionary(
|
|
$this->getLayoutConfig());
|
|
}
|
|
|
|
public function setLayoutConfigFromObject(
|
|
PhabricatorDashboardLayoutConfig $object) {
|
|
$this->setLayoutConfig($object->toDictionary());
|
|
return $this;
|
|
}
|
|
|
|
public function attachPanelPHIDs(array $phids) {
|
|
$this->panelPHIDs = $phids;
|
|
return $this;
|
|
}
|
|
|
|
public function getPanelPHIDs() {
|
|
return $this->assertAttached($this->panelPHIDs);
|
|
}
|
|
|
|
public function attachPanels(array $panels) {
|
|
assert_instances_of($panels, 'PhabricatorDashboardPanel');
|
|
$this->panels = $panels;
|
|
return $this;
|
|
}
|
|
|
|
public function getPanels() {
|
|
return $this->assertAttached($this->panels);
|
|
}
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
|
|
|
|
|
public function getCapabilities() {
|
|
return array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
);
|
|
}
|
|
|
|
public function getPolicy($capability) {
|
|
switch ($capability) {
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
return $this->getViewPolicy();
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
return $this->getEditPolicy();
|
|
}
|
|
}
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
return false;
|
|
}
|
|
|
|
public function describeAutomaticCapability($capability) {
|
|
return null;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorDestructibleInterface )----------------------------------- */
|
|
|
|
|
|
public function destroyObjectPermanently(
|
|
PhabricatorDestructionEngine $engine) {
|
|
|
|
$this->openTransaction();
|
|
$installs = id(new PhabricatorDashboardInstall())->loadAllWhere(
|
|
'dashboardPHID = %s',
|
|
$this->getPHID());
|
|
foreach ($installs as $install) {
|
|
$install->delete();
|
|
}
|
|
|
|
$this->delete();
|
|
$this->saveTransaction();
|
|
}
|
|
|
|
|
|
}
|