mirror of
https://we.phorge.it/source/phorge.git
synced 2024-12-01 11:12:42 +01:00
f75f3a0c3b
Summary: Now you can actually replace an image! Ref T3572. This ended up needing a wee bit of infrastructure to work... - add replace image transaction to pholio - add replacesImagePHID to PholioImage - tweaks to editor to properly update images with respect to replacement - add edges to track replacement - expose getNodes on graph query infrastructure to query the entire graph of who replaced who - move pholio image to new phid infrastructure Still TODO - the history view should get chopped out a bit from the current view - no more inline comments / generally less functionality plus maybe a tweak or two to make this more sensical. Test Plan: replaced images and played with history controller a little. works okay. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Maniphest Tasks: T3572 Differential Revision: https://secure.phabricator.com/D6560
211 lines
5.1 KiB
PHP
211 lines
5.1 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group pholio
|
|
*/
|
|
final class PholioMock extends PholioDAO
|
|
implements
|
|
PhabricatorMarkupInterface,
|
|
PhabricatorPolicyInterface,
|
|
PhabricatorSubscribableInterface,
|
|
PhabricatorTokenReceiverInterface,
|
|
PhabricatorApplicationTransactionInterface {
|
|
|
|
const MARKUP_FIELD_DESCRIPTION = 'markup:description';
|
|
|
|
protected $authorPHID;
|
|
protected $viewPolicy;
|
|
|
|
protected $name;
|
|
protected $originalName;
|
|
protected $description;
|
|
protected $coverPHID;
|
|
protected $mailKey;
|
|
|
|
private $images = self::ATTACHABLE;
|
|
private $allImages = self::ATTACHABLE;
|
|
private $coverFile = self::ATTACHABLE;
|
|
private $tokenCount = self::ATTACHABLE;
|
|
|
|
public function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_AUX_PHID => true,
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public function generatePHID() {
|
|
return PhabricatorPHID::generateNewPHID('MOCK');
|
|
}
|
|
|
|
public function save() {
|
|
if (!$this->getMailKey()) {
|
|
$this->setMailKey(Filesystem::readRandomCharacters(20));
|
|
}
|
|
return parent::save();
|
|
}
|
|
|
|
/**
|
|
* These should be the images currently associated with the Mock.
|
|
*/
|
|
public function attachImages(array $images) {
|
|
assert_instances_of($images, 'PholioImage');
|
|
$this->images = $images;
|
|
return $this;
|
|
}
|
|
|
|
public function getImages() {
|
|
$this->assertAttached($this->images);
|
|
return $this->images;
|
|
}
|
|
|
|
/**
|
|
* These should be *all* images associated with the Mock. This includes
|
|
* images which have been removed and / or replaced from the Mock.
|
|
*/
|
|
public function attachAllImages(array $images) {
|
|
assert_instances_of($images, 'PholioImage');
|
|
$this->allImages = $images;
|
|
return $this;
|
|
}
|
|
|
|
public function getAllImages() {
|
|
$this->assertAttached($this->images);
|
|
return $this->allImages;
|
|
}
|
|
|
|
public function attachCoverFile(PhabricatorFile $file) {
|
|
$this->coverFile = $file;
|
|
return $this;
|
|
}
|
|
|
|
public function getCoverFile() {
|
|
$this->assertAttached($this->coverFile);
|
|
return $this->coverFile;
|
|
}
|
|
|
|
public function getTokenCount() {
|
|
$this->assertAttached($this->tokenCount);
|
|
return $this->tokenCount;
|
|
}
|
|
|
|
public function attachTokenCount($count) {
|
|
$this->tokenCount = $count;
|
|
return $this;
|
|
}
|
|
|
|
public function getImageHistorySet($image_id) {
|
|
$images = $this->getAllImages();
|
|
$images = mpull($images, null, 'getID');
|
|
$selected_image = $images[$image_id];
|
|
|
|
$replace_map = mpull($images, null, 'getReplacesImagePHID');
|
|
$phid_map = mpull($images, null, 'getPHID');
|
|
|
|
// find the earliest image
|
|
$image = $selected_image;
|
|
while (isset($phid_map[$image->getReplacesImagePHID()])) {
|
|
$image = $phid_map[$image->getReplacesImagePHID()];
|
|
}
|
|
|
|
// now build history moving forward
|
|
$history = array($image->getID() => $image);
|
|
while (isset($replace_map[$image->getPHID()])) {
|
|
$image = $replace_map[$image->getPHID()];
|
|
$history[$image->getID()] = $image;
|
|
}
|
|
|
|
return $history;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorSubscribableInterface Implementation )-------------------- */
|
|
|
|
|
|
public function isAutomaticallySubscribed($phid) {
|
|
return ($this->authorPHID == $phid);
|
|
}
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface Implementation )-------------------------- */
|
|
|
|
|
|
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 PhabricatorPolicies::POLICY_NOONE;
|
|
}
|
|
}
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
return ($viewer->getPHID() == $this->getAuthorPHID());
|
|
}
|
|
|
|
|
|
/* -( PhabricatorMarkupInterface )----------------------------------------- */
|
|
|
|
|
|
public function getMarkupFieldKey($field) {
|
|
$hash = PhabricatorHash::digest($this->getMarkupText($field));
|
|
return 'M:'.$hash;
|
|
}
|
|
|
|
public function newMarkupEngine($field) {
|
|
return PhabricatorMarkupEngine::newMarkupEngine(array());
|
|
}
|
|
|
|
public function getMarkupText($field) {
|
|
if ($this->getDescription()) {
|
|
$description = $this->getDescription();
|
|
} else {
|
|
$description = pht('No Description Given');
|
|
}
|
|
|
|
return $description;
|
|
}
|
|
|
|
public function didMarkupText($field, $output, PhutilMarkupEngine $engine) {
|
|
require_celerity_resource('phabricator-remarkup-css');
|
|
return phutil_tag(
|
|
'div',
|
|
array(
|
|
'class' => 'phabricator-remarkup',
|
|
),
|
|
$output);
|
|
}
|
|
|
|
public function shouldUseMarkupCache($field) {
|
|
return (bool)$this->getID();
|
|
}
|
|
|
|
|
|
/* -( PhabricatorApplicationTransactionInterface )------------------------- */
|
|
|
|
|
|
public function getApplicationTransactionEditor() {
|
|
return new PholioMockEditor();
|
|
}
|
|
|
|
public function getApplicationTransactionObject() {
|
|
return new PholioTransaction();
|
|
}
|
|
|
|
|
|
/* -( PhabricatorTokenReceiverInterface )---------------------------------- */
|
|
|
|
|
|
public function getUsersToNotifyOfTokenGiven() {
|
|
return array(
|
|
$this->getAuthorPHID(),
|
|
);
|
|
}
|
|
|
|
}
|