mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-23 21:18:19 +01:00
3d16eb5e57
Summary: Ref T3023 Token support for Phriction Documents, Ponder Questions, and Phame Blogs Test Plan: Token notifications and visual display seems to be working for the above types Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin, AnhNhan Maniphest Tasks: T3023 Differential Revision: https://secure.phabricator.com/D5862
196 lines
4.7 KiB
PHP
196 lines
4.7 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group phame
|
|
*/
|
|
final class PhamePost extends PhameDAO
|
|
implements
|
|
PhabricatorPolicyInterface,
|
|
PhabricatorMarkupInterface,
|
|
PhabricatorTokenReceiverInterface {
|
|
|
|
const MARKUP_FIELD_BODY = 'markup:body';
|
|
const MARKUP_FIELD_SUMMARY = 'markup:summary';
|
|
|
|
const VISIBILITY_DRAFT = 0;
|
|
const VISIBILITY_PUBLISHED = 1;
|
|
|
|
protected $id;
|
|
protected $phid;
|
|
protected $bloggerPHID;
|
|
protected $title;
|
|
protected $phameTitle;
|
|
protected $body;
|
|
protected $visibility;
|
|
protected $configData;
|
|
protected $datePublished;
|
|
protected $blogPHID;
|
|
|
|
private $blog;
|
|
|
|
public function setBlog(PhameBlog $blog) {
|
|
$this->blog = $blog;
|
|
return $this;
|
|
}
|
|
|
|
public function getBlog() {
|
|
return $this->blog;
|
|
}
|
|
|
|
public function getViewURI() {
|
|
// go for the pretty uri if we can
|
|
$domain = ($this->blog ? $this->blog->getDomain() : '');
|
|
if ($domain) {
|
|
$phame_title = PhabricatorSlug::normalize($this->getPhameTitle());
|
|
return 'http://'.$domain.'/post/'.$phame_title;
|
|
}
|
|
$uri = '/phame/post/view/'.$this->getID().'/';
|
|
return PhabricatorEnv::getProductionURI($uri);
|
|
}
|
|
|
|
public function isDraft() {
|
|
return $this->getVisibility() == self::VISIBILITY_DRAFT;
|
|
}
|
|
|
|
public function getHumanName() {
|
|
if ($this->isDraft()) {
|
|
$name = 'draft';
|
|
} else {
|
|
$name = 'post';
|
|
}
|
|
|
|
return $name;
|
|
}
|
|
|
|
public function getCommentsWidget() {
|
|
$config_data = $this->getConfigData();
|
|
if (empty($config_data)) {
|
|
return 'none';
|
|
}
|
|
return idx($config_data, 'comments_widget', 'none');
|
|
}
|
|
|
|
public function getConfiguration() {
|
|
return array(
|
|
self::CONFIG_AUX_PHID => true,
|
|
self::CONFIG_SERIALIZATION => array(
|
|
'configData' => self::SERIALIZATION_JSON,
|
|
),
|
|
) + parent::getConfiguration();
|
|
}
|
|
|
|
public function generatePHID() {
|
|
return PhabricatorPHID::generateNewPHID(
|
|
PhabricatorPHIDConstants::PHID_TYPE_POST);
|
|
}
|
|
|
|
public static function getVisibilityOptionsForSelect() {
|
|
return array(
|
|
self::VISIBILITY_DRAFT => 'Draft: visible only to me.',
|
|
self::VISIBILITY_PUBLISHED => 'Published: visible to the whole world.',
|
|
);
|
|
}
|
|
|
|
public function getCommentsWidgetOptionsForSelect() {
|
|
$current = $this->getCommentsWidget();
|
|
$options = array();
|
|
|
|
if ($current == 'facebook' ||
|
|
PhabricatorEnv::getEnvConfig('facebook.application-id')) {
|
|
$options['facebook'] = 'Facebook';
|
|
}
|
|
if ($current == 'disqus' ||
|
|
PhabricatorEnv::getEnvConfig('disqus.shortname')) {
|
|
$options['disqus'] = 'Disqus';
|
|
}
|
|
$options['none'] = 'None';
|
|
|
|
return $options;
|
|
}
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface Implementation )-------------------------- */
|
|
|
|
|
|
public function getCapabilities() {
|
|
return array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
);
|
|
}
|
|
|
|
|
|
public function getPolicy($capability) {
|
|
// Draft posts are visible only to the author. Published posts are visible
|
|
// to whoever the blog is visible to.
|
|
|
|
switch ($capability) {
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
if (!$this->isDraft() && $this->getBlog()) {
|
|
return $this->getBlog()->getViewPolicy();
|
|
} else {
|
|
return PhabricatorPolicies::POLICY_NOONE;
|
|
}
|
|
break;
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
return PhabricatorPolicies::POLICY_NOONE;
|
|
}
|
|
}
|
|
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $user) {
|
|
// A blog post's author can always view it, and is the only user allowed
|
|
// to edit it.
|
|
|
|
switch ($capability) {
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
return ($user->getPHID() == $this->getBloggerPHID());
|
|
}
|
|
}
|
|
|
|
|
|
/* -( PhabricatorMarkupInterface Implementation )-------------------------- */
|
|
|
|
|
|
public function getMarkupFieldKey($field) {
|
|
$hash = PhabricatorHash::digest($this->getMarkupText($field));
|
|
return $this->getPHID().':'.$field.':'.$hash;
|
|
}
|
|
|
|
|
|
public function newMarkupEngine($field) {
|
|
return PhabricatorMarkupEngine::newPhameMarkupEngine();
|
|
}
|
|
|
|
|
|
public function getMarkupText($field) {
|
|
switch ($field) {
|
|
case self::MARKUP_FIELD_BODY:
|
|
return $this->getBody();
|
|
case self::MARKUP_FIELD_SUMMARY:
|
|
return PhabricatorMarkupEngine::summarize($this->getBody());
|
|
}
|
|
}
|
|
|
|
public function didMarkupText(
|
|
$field,
|
|
$output,
|
|
PhutilMarkupEngine $engine) {
|
|
return $output;
|
|
}
|
|
|
|
|
|
public function shouldUseMarkupCache($field) {
|
|
return (bool)$this->getPHID();
|
|
}
|
|
|
|
/* -( PhabricatorTokenReceiverInterface )---------------------------------- */
|
|
|
|
public function getUsersToNotifyOfTokenGiven() {
|
|
return array(
|
|
$this->getBloggerPHID(),
|
|
);
|
|
}
|
|
|
|
}
|