1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-23 21:18:19 +01:00
phorge-phorge/src/applications/differential/storage/revision/DifferentialRevision.php

159 lines
4 KiB
PHP
Raw Normal View History

2011-01-24 11:01:53 -08:00
<?php
/*
* Copyright 2011 Facebook, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class DifferentialRevision extends DifferentialDAO {
2011-01-25 17:17:19 -08:00
protected $title;
2011-01-24 11:01:53 -08:00
protected $status;
protected $summary;
protected $testPlan;
2011-01-25 13:26:09 -08:00
protected $revertPlan;
protected $blameRevision;
2011-01-24 11:01:53 -08:00
protected $phid;
protected $authorPHID;
2011-01-24 11:01:53 -08:00
protected $dateCommitted;
protected $lineCount;
protected $attached = array();
protected $unsubscribed = array();
2011-01-26 18:46:34 -08:00
private $relationships;
private $commits;
2011-01-26 18:46:34 -08:00
const RELATIONSHIP_TABLE = 'differential_relationship';
2011-04-27 01:27:06 -07:00
const TABLE_VIEW_TIME = 'differential_viewtime';
const TABLE_COMMIT = 'differential_commit';
2011-01-26 18:46:34 -08:00
const RELATION_REVIEWER = 'revw';
const RELATION_SUBSCRIBED = 'subd';
2011-01-25 17:17:19 -08:00
public function getConfiguration() {
return array(
self::CONFIG_AUX_PHID => true,
self::CONFIG_SERIALIZATION => array(
'attached' => self::SERIALIZATION_JSON,
'unsubscribed' => self::SERIALIZATION_JSON,
),
2011-01-25 17:17:19 -08:00
) + parent::getConfiguration();
}
public function loadCommitPHIDs() {
if (!$this->getID()) {
return ($this->commits = array());
}
$commits = queryfx_all(
$this->establishConnection('r'),
'SELECT commitPHID FROM %T WHERE revisionID = %d',
self::TABLE_COMMIT,
$this->getID());
$commits = ipull($commits, 'commitPHID');
return ($this->commits = $commits);
}
public function getCommitPHIDs() {
if ($this->commits === null) {
throw new Exception("Must load commits!");
}
return $this->commits;
}
public function getAttachedPHIDs($type) {
return array_keys(idx($this->attached, $type, array()));
}
public function setAttachedPHIDs($type, array $phids) {
$this->attached[$type] = array_fill_keys($phids, array());
return $this;
}
2011-01-25 17:17:19 -08:00
public function generatePHID() {
return PhabricatorPHID::generateNewPHID(
PhabricatorPHIDConstants::PHID_TYPE_DREV);
2011-01-25 17:17:19 -08:00
}
2011-01-26 18:46:34 -08:00
2011-01-27 14:55:52 -08:00
public function loadDiffs() {
if (!$this->getID()) {
return array();
}
return id(new DifferentialDiff())->loadAllWhere(
'revisionID = %d',
$this->getID());
}
public function loadComments() {
if (!$this->getID()) {
return array();
}
return id(new DifferentialComment())->loadAllWhere(
'revisionID = %d',
$this->getID());
}
2011-01-30 13:20:56 -08:00
public function loadActiveDiff() {
return id(new DifferentialDiff())->loadOneWhere(
'revisionID = %d ORDER BY id DESC LIMIT 1',
$this->getID());
}
2011-01-25 17:17:19 -08:00
public function loadRelationships() {
2011-01-26 18:46:34 -08:00
if (!$this->getID()) {
$this->relationships = array();
return;
}
$data = queryfx_all(
$this->establishConnection('r'),
'SELECT * FROM %T WHERE revisionID = %d ORDER BY sequence',
self::RELATIONSHIP_TABLE,
$this->getID());
$this->relationships = igroup($data, 'relation');
return $this;
2011-01-25 17:17:19 -08:00
}
2011-01-26 18:46:34 -08:00
2011-01-25 17:17:19 -08:00
public function getReviewers() {
2011-01-26 18:46:34 -08:00
return $this->getRelatedPHIDs(self::RELATION_REVIEWER);
2011-01-25 17:17:19 -08:00
}
2011-01-26 18:46:34 -08:00
2011-01-25 17:17:19 -08:00
public function getCCPHIDs() {
2011-01-26 18:46:34 -08:00
return $this->getRelatedPHIDs(self::RELATION_SUBSCRIBED);
}
private function getRelatedPHIDs($relation) {
if ($this->relationships === null) {
2011-01-26 18:46:34 -08:00
throw new Exception("Must load relationships!");
}
2011-02-02 19:38:43 -08:00
return ipull($this->getRawRelations($relation), 'objectPHID');
2011-01-26 18:46:34 -08:00
}
public function getRawRelations($relation) {
return idx($this->relationships, $relation, array());
}
public function getUnsubscribedPHIDs() {
return array_keys($this->getUnsubscribed());
}
2011-01-24 11:01:53 -08:00
}