Page MenuHomePhabricator

D8109.diff
No OneTemporary

D8109.diff

Index: resources/sql/autopatches/20140130.dash.1.board.sql
===================================================================
--- /dev/null
+++ resources/sql/autopatches/20140130.dash.1.board.sql
@@ -0,0 +1,10 @@
+CREATE TABLE {$NAMESPACE}_dashboard.dashboard (
+ id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
+ phid VARCHAR(64) NOT NULL COLLATE utf8_bin,
+ name VARCHAR(255) NOT NULL,
+ viewPolicy VARCHAR(64) NOT NULL COLLATE utf8_bin,
+ editPolicy VARCHAR(64) NOT NULL COLLATE utf8_bin,
+ dateCreated INT UNSIGNED NOT NULL,
+ dateModified INT UNSIGNED NOT NULL,
+ UNIQUE KEY `key_phid` (phid)
+) ENGINE=InnoDB, COLLATE=utf8_general_ci;
Index: resources/sql/autopatches/20140130.dash.2.panel.sql
===================================================================
--- /dev/null
+++ resources/sql/autopatches/20140130.dash.2.panel.sql
@@ -0,0 +1,11 @@
+CREATE TABLE {$NAMESPACE}_dashboard.dashboard_panel (
+ id INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
+ phid VARCHAR(64) NOT NULL COLLATE utf8_bin,
+ name VARCHAR(255) NOT NULL,
+ viewPolicy VARCHAR(64) NOT NULL COLLATE utf8_bin,
+ editPolicy VARCHAR(64) NOT NULL COLLATE utf8_bin,
+ properties LONGTEXT NOT NULL COLLATE utf8_bin,
+ dateCreated INT UNSIGNED NOT NULL,
+ dateModified INT UNSIGNED NOT NULL,
+ UNIQUE KEY `key_phid` (phid)
+) ENGINE=InnoDB, COLLATE=utf8_general_ci;
Index: src/__phutil_library_map__.php
===================================================================
--- src/__phutil_library_map__.php
+++ src/__phutil_library_map__.php
@@ -1075,6 +1075,7 @@
'PhabricatorApplicationConpherence' => 'applications/conpherence/application/PhabricatorApplicationConpherence.php',
'PhabricatorApplicationCountdown' => 'applications/countdown/application/PhabricatorApplicationCountdown.php',
'PhabricatorApplicationDaemons' => 'applications/daemon/application/PhabricatorApplicationDaemons.php',
+ 'PhabricatorApplicationDashboard' => 'applications/dashboard/application/PhabricatorApplicationDashboard.php',
'PhabricatorApplicationDetailViewController' => 'applications/meta/controller/PhabricatorApplicationDetailViewController.php',
'PhabricatorApplicationDifferential' => 'applications/differential/application/PhabricatorApplicationDifferential.php',
'PhabricatorApplicationDiffusion' => 'applications/diffusion/application/PhabricatorApplicationDiffusion.php',
@@ -1378,6 +1379,18 @@
'PhabricatorDaemonManagementWorkflow' => 'applications/daemon/management/PhabricatorDaemonManagementWorkflow.php',
'PhabricatorDaemonReference' => 'infrastructure/daemon/control/PhabricatorDaemonReference.php',
'PhabricatorDaemonTaskGarbageCollector' => 'applications/daemon/garbagecollector/PhabricatorDaemonTaskGarbageCollector.php',
+ 'PhabricatorDashboard' => 'applications/dashboard/storage/PhabricatorDashboard.php',
+ 'PhabricatorDashboardController' => 'applications/dashboard/controller/PhabricatorDashboardController.php',
+ 'PhabricatorDashboardDAO' => 'applications/dashboard/storage/PhabricatorDashboardDAO.php',
+ 'PhabricatorDashboardListController' => 'applications/dashboard/controller/PhabricatorDashboardListController.php',
+ 'PhabricatorDashboardPHIDTypeDashboard' => 'applications/dashboard/phid/PhabricatorDashboardPHIDTypeDashboard.php',
+ 'PhabricatorDashboardPHIDTypePanel' => 'applications/dashboard/phid/PhabricatorDashboardPHIDTypePanel.php',
+ 'PhabricatorDashboardPanel' => 'applications/dashboard/storage/PhabricatorDashboardPanel.php',
+ 'PhabricatorDashboardPanelListController' => 'applications/dashboard/controller/PhabricatorDashboardPanelListController.php',
+ 'PhabricatorDashboardPanelQuery' => 'applications/dashboard/query/PhabricatorDashboardPanelQuery.php',
+ 'PhabricatorDashboardPanelSearchEngine' => 'applications/dashboard/query/PhabricatorDashboardPanelSearchEngine.php',
+ 'PhabricatorDashboardQuery' => 'applications/dashboard/query/PhabricatorDashboardQuery.php',
+ 'PhabricatorDashboardSearchEngine' => 'applications/dashboard/query/PhabricatorDashboardSearchEngine.php',
'PhabricatorDataNotAttachedException' => 'infrastructure/storage/lisk/PhabricatorDataNotAttachedException.php',
'PhabricatorDebugController' => 'applications/system/PhabricatorDebugController.php',
'PhabricatorDefaultFileStorageEngineSelector' => 'applications/files/engineselector/PhabricatorDefaultFileStorageEngineSelector.php',
@@ -3662,6 +3675,7 @@
'PhabricatorApplicationConpherence' => 'PhabricatorApplication',
'PhabricatorApplicationCountdown' => 'PhabricatorApplication',
'PhabricatorApplicationDaemons' => 'PhabricatorApplication',
+ 'PhabricatorApplicationDashboard' => 'PhabricatorApplication',
'PhabricatorApplicationDetailViewController' => 'PhabricatorApplicationsController',
'PhabricatorApplicationDifferential' => 'PhabricatorApplication',
'PhabricatorApplicationDiffusion' => 'PhabricatorApplication',
@@ -4007,6 +4021,30 @@
'PhabricatorDaemonManagementStopWorkflow' => 'PhabricatorDaemonManagementWorkflow',
'PhabricatorDaemonManagementWorkflow' => 'PhabricatorManagementWorkflow',
'PhabricatorDaemonTaskGarbageCollector' => 'PhabricatorGarbageCollector',
+ 'PhabricatorDashboard' =>
+ array(
+ 0 => 'PhabricatorDashboardDAO',
+ 1 => 'PhabricatorPolicyInterface',
+ ),
+ 'PhabricatorDashboardController' => 'PhabricatorController',
+ 'PhabricatorDashboardDAO' => 'PhabricatorLiskDAO',
+ 'PhabricatorDashboardListController' =>
+ array(
+ 0 => 'PhabricatorDashboardController',
+ 1 => 'PhabricatorApplicationSearchResultsControllerInterface',
+ ),
+ 'PhabricatorDashboardPHIDTypeDashboard' => 'PhabricatorPHIDType',
+ 'PhabricatorDashboardPHIDTypePanel' => 'PhabricatorPHIDType',
+ 'PhabricatorDashboardPanel' => 'PhabricatorDashboardDAO',
+ 'PhabricatorDashboardPanelListController' =>
+ array(
+ 0 => 'PhabricatorDashboardController',
+ 1 => 'PhabricatorApplicationSearchResultsControllerInterface',
+ ),
+ 'PhabricatorDashboardPanelQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
+ 'PhabricatorDashboardPanelSearchEngine' => 'PhabricatorApplicationSearchEngine',
+ 'PhabricatorDashboardQuery' => 'PhabricatorCursorPagedPolicyAwareQuery',
+ 'PhabricatorDashboardSearchEngine' => 'PhabricatorApplicationSearchEngine',
'PhabricatorDataNotAttachedException' => 'Exception',
'PhabricatorDebugController' => 'PhabricatorController',
'PhabricatorDefaultFileStorageEngineSelector' => 'PhabricatorFileStorageEngineSelector',
Index: src/applications/dashboard/application/PhabricatorApplicationDashboard.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/application/PhabricatorApplicationDashboard.php
@@ -0,0 +1,40 @@
+<?php
+
+final class PhabricatorApplicationDashboard extends PhabricatorApplication {
+
+ public function getBaseURI() {
+ return '/dashboard/';
+ }
+
+ public function getShortDescription() {
+ return pht('Such Data');
+ }
+
+ public function getIconName() {
+ return 'dashboard';
+ }
+
+ public function getRoutes() {
+ return array(
+ '/W(?P<id>\d+)' => 'PhabricatorDashboardPanelViewController',
+ '/dashboard/' => array(
+ '(?:query/(?P<queryKey>[^/]+)/)?'
+ => 'PhabricatorDashboardListController',
+ 'view/(?P<id>\d+)/' => 'PhabricatorDashboardViewController',
+ 'panel/' => array(
+ '(?:query/(?P<queryKey>[^/]+)/)?'
+ => 'PhabricatorDashboardPanelListController',
+ ),
+ ),
+ );
+ }
+
+ public function shouldAppearInLaunchView() {
+ return false;
+ }
+
+ public function canUninstall() {
+ return false;
+ }
+
+}
Index: src/applications/dashboard/controller/PhabricatorDashboardController.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/controller/PhabricatorDashboardController.php
@@ -0,0 +1,5 @@
+<?php
+
+abstract class PhabricatorDashboardController extends PhabricatorController {
+
+}
Index: src/applications/dashboard/controller/PhabricatorDashboardListController.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/controller/PhabricatorDashboardListController.php
@@ -0,0 +1,43 @@
+<?php
+
+final class PhabricatorDashboardListController
+ extends PhabricatorDashboardController
+ implements PhabricatorApplicationSearchResultsControllerInterface {
+
+ private $queryKey;
+ public function willProcessRequest(array $data) {
+ $this->queryKey = idx($data, 'queryKey');
+ }
+
+ public function processRequest() {
+ $request = $this->getRequest();
+ $controller = id(new PhabricatorApplicationSearchController($request))
+ ->setQueryKey($this->queryKey)
+ ->setSearchEngine(new PhabricatorDashboardSearchEngine())
+ ->setNavigation($this->buildSideNavView());
+ return $this->delegateToController($controller);
+ }
+
+ public function buildSideNavView() {
+ $user = $this->getRequest()->getUser();
+
+ $nav = new AphrontSideNavFilterView();
+ $nav->setBaseURI(new PhutilURI($this->getApplicationURI()));
+
+ id(new PhabricatorDashboardSearchEngine())
+ ->setViewer($user)
+ ->addNavigationItems($nav->getMenu());
+
+ $nav->selectFilter(null);
+
+ return $nav;
+ }
+
+ public function renderResultsList(
+ array $dashboards,
+ PhabricatorSavedQuery $query) {
+
+ return 'got '.count($dashboards).' ok';
+ }
+
+}
Index: src/applications/dashboard/controller/PhabricatorDashboardPanelListController.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/controller/PhabricatorDashboardPanelListController.php
@@ -0,0 +1,43 @@
+<?php
+
+final class PhabricatorDashboardPanelListController
+ extends PhabricatorDashboardController
+ implements PhabricatorApplicationSearchResultsControllerInterface {
+
+ private $queryKey;
+ public function willProcessRequest(array $data) {
+ $this->queryKey = idx($data, 'queryKey');
+ }
+
+ public function processRequest() {
+ $request = $this->getRequest();
+ $controller = id(new PhabricatorApplicationSearchController($request))
+ ->setQueryKey($this->queryKey)
+ ->setSearchEngine(new PhabricatorDashboardPanelSearchEngine())
+ ->setNavigation($this->buildSideNavView());
+ return $this->delegateToController($controller);
+ }
+
+ public function buildSideNavView() {
+ $user = $this->getRequest()->getUser();
+
+ $nav = new AphrontSideNavFilterView();
+ $nav->setBaseURI(new PhutilURI($this->getApplicationURI()));
+
+ id(new PhabricatorDashboardPanelSearchEngine())
+ ->setViewer($user)
+ ->addNavigationItems($nav->getMenu());
+
+ $nav->selectFilter(null);
+
+ return $nav;
+ }
+
+ public function renderResultsList(
+ array $panels,
+ PhabricatorSavedQuery $query) {
+
+ return 'got '.count($panels).' ok';
+ }
+
+}
Index: src/applications/dashboard/phid/PhabricatorDashboardPHIDTypeDashboard.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/phid/PhabricatorDashboardPHIDTypeDashboard.php
@@ -0,0 +1,42 @@
+<?php
+
+final class PhabricatorDashboardPHIDTypeDashboard extends PhabricatorPHIDType {
+
+ const TYPECONST = 'DSHB';
+
+ public function getTypeConstant() {
+ return self::TYPECONST;
+ }
+
+ public function getTypeName() {
+ return pht('Dashboard');
+ }
+
+ public function newObject() {
+ return new PhabricatorDashboard();
+ }
+
+ protected function buildQueryForObjects(
+ PhabricatorObjectQuery $query,
+ array $phids) {
+
+ return id(new PhabricatorDashboardQuery())
+ ->withPHIDs($phids);
+ }
+
+ public function loadHandles(
+ PhabricatorHandleQuery $query,
+ array $handles,
+ array $objects) {
+
+ foreach ($handles as $phid => $handle) {
+ $dashboard = $objects[$phid];
+
+ $id = $dashboard->getID();
+
+ $handle->setName($dashboard->getName());
+ $handle->setURI("/dashboard/view/{$id}/");
+ }
+ }
+
+}
Index: src/applications/dashboard/phid/PhabricatorDashboardPHIDTypePanel.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/phid/PhabricatorDashboardPHIDTypePanel.php
@@ -0,0 +1,73 @@
+<?php
+
+final class PhabricatorDashboardPHIDTypePanel extends PhabricatorPHIDType {
+
+ const TYPECONST = 'DSHP';
+
+ public function getTypeConstant() {
+ return self::TYPECONST;
+ }
+
+ public function getTypeName() {
+ return pht('Panel');
+ }
+
+ public function newObject() {
+ return new PhabricatorDashboardPanel();
+ }
+
+ protected function buildQueryForObjects(
+ PhabricatorObjectQuery $query,
+ array $phids) {
+
+ return id(new PhabricatorDashboardPanelQuery())
+ ->withPHIDs($phids);
+ }
+
+ public function loadHandles(
+ PhabricatorHandleQuery $query,
+ array $handles,
+ array $objects) {
+
+ foreach ($handles as $phid => $handle) {
+ $panel = $objects[$phid];
+
+ $name = $panel->getName();
+ $monogram = $panel->getMonogram();
+
+ $handle->setName($panel->getMonogram());
+ $handle->setFullName("{$monogram} {$name}");
+ $handle->setURI("/{$monogram}");
+ }
+ }
+
+ public function canLoadNamedObject($name) {
+ return preg_match('/^W\d*[1-9]\d*$/i', $name);
+ }
+
+ public function loadNamedObjects(
+ PhabricatorObjectQuery $query,
+ array $names) {
+
+ $id_map = array();
+ foreach ($names as $name) {
+ $id = (int)substr($name, 1);
+ $id_map[$id][] = $name;
+ }
+
+ $objects = id(new PhabricatorDashboardPanelQuery())
+ ->setViewer($query->getViewer())
+ ->withIDs(array_keys($id_map))
+ ->execute();
+
+ $results = array();
+ foreach ($objects as $id => $object) {
+ foreach (idx($id_map, $id, array()) as $name) {
+ $results[$name] = $object;
+ }
+ }
+
+ return $results;
+ }
+
+}
Index: src/applications/dashboard/query/PhabricatorDashboardPanelQuery.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/query/PhabricatorDashboardPanelQuery.php
@@ -0,0 +1,60 @@
+<?php
+
+final class PhabricatorDashboardPanelQuery
+ extends PhabricatorCursorPagedPolicyAwareQuery {
+
+ private $ids;
+ private $phids;
+
+ public function withIDs(array $ids) {
+ $this->ids = $ids;
+ return $this;
+ }
+
+ public function withPHIDs(array $phids) {
+ $this->phids = $phids;
+ return $this;
+ }
+
+ protected function loadPage() {
+ $table = new PhabricatorDashboardPanel();
+ $conn_r = $table->establishConnection('r');
+
+ $data = queryfx_all(
+ $conn_r,
+ 'SELECT * FROM %T %Q %Q %Q',
+ $table->getTableName(),
+ $this->buildWhereClause($conn_r),
+ $this->buildOrderClause($conn_r),
+ $this->buildLimitClause($conn_r));
+
+ return $table->loadAllFromArray($data);
+ }
+
+ protected function buildWhereClause($conn_r) {
+ $where = array();
+
+ if ($this->ids) {
+ $where[] = qsprintf(
+ $conn_r,
+ 'id IN (%Ld)',
+ $this->ids);
+ }
+
+ if ($this->phids) {
+ $where[] = qsprintf(
+ $conn_r,
+ 'phid IN (%Ls)',
+ $this->phids);
+ }
+
+ $where[] = $this->buildPagingClause($conn_r);
+
+ return $this->formatWhereClause($where);
+ }
+
+ public function getQueryApplicationClass() {
+ return 'PhabricatorApplicationDashboard';
+ }
+
+}
Index: src/applications/dashboard/query/PhabricatorDashboardPanelSearchEngine.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/query/PhabricatorDashboardPanelSearchEngine.php
@@ -0,0 +1,49 @@
+<?php
+
+final class PhabricatorDashboardPanelSearchEngine
+ extends PhabricatorApplicationSearchEngine {
+
+ public function buildSavedQueryFromRequest(AphrontRequest $request) {
+ $saved = new PhabricatorSavedQuery();
+
+ return $saved;
+ }
+
+ public function buildQueryFromSavedQuery(PhabricatorSavedQuery $saved) {
+ $query = id(new PhabricatorDashboardPanelQuery());
+
+ return $query;
+ }
+
+ public function buildSearchForm(
+ AphrontFormView $form,
+ PhabricatorSavedQuery $saved_query) {
+ return;
+ }
+
+ protected function getURI($path) {
+ return '/dashboard/panel/'.$path;
+ }
+
+ public function getBuiltinQueryNames() {
+ $names = array(
+ 'all' => pht('All Panels'),
+ );
+
+ return $names;
+ }
+
+ public function buildSavedQueryFromBuiltin($query_key) {
+
+ $query = $this->newSavedQuery();
+ $query->setQueryKey($query_key);
+
+ switch ($query_key) {
+ case 'all':
+ return $query;
+ }
+
+ return parent::buildSavedQueryFromBuiltin($query_key);
+ }
+
+}
Index: src/applications/dashboard/query/PhabricatorDashboardQuery.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/query/PhabricatorDashboardQuery.php
@@ -0,0 +1,60 @@
+<?php
+
+final class PhabricatorDashboardQuery
+ extends PhabricatorCursorPagedPolicyAwareQuery {
+
+ private $ids;
+ private $phids;
+
+ public function withIDs(array $ids) {
+ $this->ids = $ids;
+ return $this;
+ }
+
+ public function withPHIDs(array $phids) {
+ $this->phids = $phids;
+ return $this;
+ }
+
+ protected function loadPage() {
+ $table = new PhabricatorDashboard();
+ $conn_r = $table->establishConnection('r');
+
+ $data = queryfx_all(
+ $conn_r,
+ 'SELECT * FROM %T %Q %Q %Q',
+ $table->getTableName(),
+ $this->buildWhereClause($conn_r),
+ $this->buildOrderClause($conn_r),
+ $this->buildLimitClause($conn_r));
+
+ return $table->loadAllFromArray($data);
+ }
+
+ protected function buildWhereClause($conn_r) {
+ $where = array();
+
+ if ($this->ids) {
+ $where[] = qsprintf(
+ $conn_r,
+ 'id IN (%Ld)',
+ $this->ids);
+ }
+
+ if ($this->phids) {
+ $where[] = qsprintf(
+ $conn_r,
+ 'phid IN (%Ls)',
+ $this->phids);
+ }
+
+ $where[] = $this->buildPagingClause($conn_r);
+
+ return $this->formatWhereClause($where);
+ }
+
+ public function getQueryApplicationClass() {
+ return 'PhabricatorApplicationDashboard';
+ }
+
+}
Index: src/applications/dashboard/query/PhabricatorDashboardSearchEngine.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/query/PhabricatorDashboardSearchEngine.php
@@ -0,0 +1,49 @@
+<?php
+
+final class PhabricatorDashboardSearchEngine
+ extends PhabricatorApplicationSearchEngine {
+
+ public function buildSavedQueryFromRequest(AphrontRequest $request) {
+ $saved = new PhabricatorSavedQuery();
+
+ return $saved;
+ }
+
+ public function buildQueryFromSavedQuery(PhabricatorSavedQuery $saved) {
+ $query = id(new PhabricatorDashboardQuery());
+
+ return $query;
+ }
+
+ public function buildSearchForm(
+ AphrontFormView $form,
+ PhabricatorSavedQuery $saved_query) {
+ return;
+ }
+
+ protected function getURI($path) {
+ return '/dashboard/'.$path;
+ }
+
+ public function getBuiltinQueryNames() {
+ $names = array(
+ 'all' => pht('All Dashboards'),
+ );
+
+ return $names;
+ }
+
+ public function buildSavedQueryFromBuiltin($query_key) {
+
+ $query = $this->newSavedQuery();
+ $query->setQueryKey($query_key);
+
+ switch ($query_key) {
+ case 'all':
+ return $query;
+ }
+
+ return parent::buildSavedQueryFromBuiltin($query_key);
+ }
+
+}
Index: src/applications/dashboard/storage/PhabricatorDashboard.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/storage/PhabricatorDashboard.php
@@ -0,0 +1,52 @@
+<?php
+
+/**
+ * A collection of dashboard panels with a specific layout.
+ */
+final class PhabricatorDashboard extends PhabricatorDashboardDAO
+ implements PhabricatorPolicyInterface {
+
+ private $name;
+ private $viewPolicy;
+ private $editPolicy;
+
+ public function getConfiguration() {
+ return array(
+ self::CONFIG_AUX_PHID => true,
+ ) + parent::getConfiguration();
+ }
+
+ public function generatePHID() {
+ return PhabricatorPHID::generateNewPHID(
+ PhabricatorDashboardPHIDTypeDashboard::TYPECONST);
+ }
+
+
+/* -( 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;
+ }
+
+}
Index: src/applications/dashboard/storage/PhabricatorDashboardDAO.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/storage/PhabricatorDashboardDAO.php
@@ -0,0 +1,9 @@
+<?php
+
+abstract class PhabricatorDashboardDAO extends PhabricatorLiskDAO {
+
+ public function getApplicationName() {
+ return 'dashboard';
+ }
+
+}
Index: src/applications/dashboard/storage/PhabricatorDashboardPanel.php
===================================================================
--- /dev/null
+++ src/applications/dashboard/storage/PhabricatorDashboardPanel.php
@@ -0,0 +1,68 @@
+<?php
+
+/**
+ * An individual dashboard panel.
+ */
+final class PhabricatorDashboardPanel extends PhabricatorDashboardDAO {
+
+ private $name;
+ private $viewPolicy;
+ private $editPolicy;
+ private $properties = array();
+
+ public function getConfiguration() {
+ return array(
+ self::CONFIG_AUX_PHID => true,
+ self::CONFIG_SERIALIZATION => array(
+ 'properties' => self::SERIALIZATION_JSON,
+ ),
+ ) + parent::getConfiguration();
+ }
+
+ public function generatePHID() {
+ return PhabricatorPHID::generateNewPHID(
+ PhabricatorDashboardPHIDTypeDashboard::TYPECONST);
+ }
+
+ 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 getMonogram() {
+ return 'W'.$this->getID();
+ }
+
+
+/* -( 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;
+ }
+
+}
Index: src/infrastructure/storage/patch/PhabricatorBuiltinPatchList.php
===================================================================
--- src/infrastructure/storage/patch/PhabricatorBuiltinPatchList.php
+++ src/infrastructure/storage/patch/PhabricatorBuiltinPatchList.php
@@ -117,6 +117,7 @@
'db.nuance' => array(),
'db.passphrase' => array(),
'db.phragment' => array(),
+ 'db.dashboard' => array(),
'0000.legacy.sql' => array(
'legacy' => 0,
),

File Metadata

Mime Type
text/plain
Expires
Sat, Sep 27, 7:36 AM (4 w, 1 d ago)
Storage Engine
blob
Storage Format
Encrypted (AES-256-CBC)
Storage Handle
8390181
Default Alt Text
D8109.diff (23 KB)

Event Timeline