2012-08-10 19:44:04 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
final class PonderAnswer extends PonderDAO
|
2013-07-26 22:19:49 +02:00
|
|
|
implements
|
|
|
|
PhabricatorMarkupInterface,
|
|
|
|
PonderVotableInterface,
|
2013-07-29 02:23:04 +02:00
|
|
|
PhabricatorPolicyInterface,
|
|
|
|
PhabricatorSubscribableInterface,
|
|
|
|
PhabricatorTokenReceiverInterface {
|
2012-08-10 19:44:04 +02:00
|
|
|
|
|
|
|
const MARKUP_FIELD_CONTENT = 'markup:content';
|
|
|
|
|
|
|
|
protected $authorPHID;
|
|
|
|
protected $questionID;
|
|
|
|
|
|
|
|
protected $content;
|
|
|
|
protected $contentSource;
|
|
|
|
|
|
|
|
protected $voteCount;
|
|
|
|
private $vote;
|
2013-07-26 22:13:38 +02:00
|
|
|
private $question = self::ATTACHABLE;
|
adding comments to ponder
Summary: This is pretty spartan, but it does the job.
Test Plan:
Patch, update storage, add some comment
to your favorite question or answer.
Reviewers: nh, vrana, epriestley
Reviewed By: epriestley
CC: aran, Korvin, starruler, syrneus, me.here, victorzarate7
Maniphest Tasks: T1645
Differential Revision: https://secure.phabricator.com/D3471
2012-09-11 21:13:20 +02:00
|
|
|
private $comments;
|
2012-08-10 19:44:04 +02:00
|
|
|
|
2013-07-29 04:28:00 +02:00
|
|
|
private $userVotes = array();
|
|
|
|
|
2013-07-26 22:13:38 +02:00
|
|
|
public function attachQuestion(PonderQuestion $question = null) {
|
2012-08-10 19:44:04 +02:00
|
|
|
$this->question = $question;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getQuestion() {
|
2013-07-26 22:13:38 +02:00
|
|
|
return $this->assertAttached($this->question);
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|
|
|
|
|
2013-09-19 00:15:25 +02:00
|
|
|
public function getURI() {
|
|
|
|
return '/Q'.$this->getQuestionID().'#A'.$this->getID();
|
|
|
|
}
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
public function setUserVote($vote) {
|
|
|
|
$this->vote = $vote['data'];
|
|
|
|
if (!$this->vote) {
|
2013-07-28 03:37:17 +02:00
|
|
|
$this->vote = PonderVote::VOTE_NONE;
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2013-07-29 04:28:00 +02:00
|
|
|
public function attachUserVote($user_phid, $vote) {
|
|
|
|
$this->vote = $vote;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
public function getUserVote() {
|
|
|
|
return $this->vote;
|
|
|
|
}
|
|
|
|
|
adding comments to ponder
Summary: This is pretty spartan, but it does the job.
Test Plan:
Patch, update storage, add some comment
to your favorite question or answer.
Reviewers: nh, vrana, epriestley
Reviewed By: epriestley
CC: aran, Korvin, starruler, syrneus, me.here, victorzarate7
Maniphest Tasks: T1645
Differential Revision: https://secure.phabricator.com/D3471
2012-09-11 21:13:20 +02:00
|
|
|
public function setComments($comments) {
|
|
|
|
$this->comments = $comments;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getComments() {
|
|
|
|
return $this->comments;
|
|
|
|
}
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
public function getConfiguration() {
|
|
|
|
return array(
|
|
|
|
self::CONFIG_AUX_PHID => true,
|
|
|
|
) + parent::getConfiguration();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function generatePHID() {
|
|
|
|
return PhabricatorPHID::generateNewPHID(
|
2013-07-26 22:19:49 +02:00
|
|
|
PonderPHIDTypeAnswer::TYPECONST);
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function setContentSource(PhabricatorContentSource $content_source) {
|
|
|
|
$this->contentSource = $content_source->serialize();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getContentSource() {
|
|
|
|
return PhabricatorContentSource::newFromSerialized($this->contentSource);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getMarkupField() {
|
|
|
|
return self::MARKUP_FIELD_CONTENT;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Markup interface
|
|
|
|
|
|
|
|
public function getMarkupFieldKey($field) {
|
|
|
|
$hash = PhabricatorHash::digest($this->getMarkupText($field));
|
|
|
|
$id = $this->getID();
|
|
|
|
return "ponder:A{$id}:{$field}:{$hash}";
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getMarkupText($field) {
|
|
|
|
return $this->getContent();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function newMarkupEngine($field) {
|
2013-08-05 19:47:26 +02:00
|
|
|
return PhabricatorMarkupEngine::getEngine();
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function didMarkupText(
|
|
|
|
$field,
|
|
|
|
$output,
|
|
|
|
PhutilMarkupEngine $engine) {
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function shouldUseMarkupCache($field) {
|
|
|
|
return (bool)$this->getID();
|
|
|
|
}
|
|
|
|
|
|
|
|
// votable interface
|
|
|
|
public function getUserVoteEdgeType() {
|
|
|
|
return PhabricatorEdgeConfig::TYPE_VOTING_USER_HAS_ANSWER;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getVotablePHID() {
|
|
|
|
return $this->getPHID();
|
|
|
|
}
|
2013-07-26 22:19:49 +02:00
|
|
|
|
|
|
|
|
|
|
|
/* -( PhabricatorPolicyInterface )----------------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
public function getCapabilities() {
|
|
|
|
return array(
|
|
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPolicy($capability) {
|
|
|
|
switch ($capability) {
|
|
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
|
|
return $this->getQuestion()->getPolicy($capability);
|
|
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
|
|
return PhabricatorPolicies::POLICY_NOONE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasAutomaticCapability($capability, PhabricatorUser $viewer) {
|
|
|
|
switch ($capability) {
|
|
|
|
case PhabricatorPolicyCapability::CAN_VIEW:
|
|
|
|
return $this->getQuestion()->hasAutomaticCapability(
|
|
|
|
$capability,
|
|
|
|
$viewer);
|
|
|
|
case PhabricatorPolicyCapability::CAN_EDIT:
|
|
|
|
return ($this->getAuthorPHID() == $viewer->getPHID());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-29 02:23:04 +02:00
|
|
|
|
|
|
|
/* -( PhabricatorTokenReceiverInterface )---------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
public function getUsersToNotifyOfTokenGiven() {
|
|
|
|
return array(
|
|
|
|
$this->getAuthorPHID(),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* -( PhabricatorSubscribableInterface )----------------------------------- */
|
|
|
|
|
|
|
|
|
|
|
|
public function isAutomaticallySubscribed($phid) {
|
|
|
|
return ($phid == $this->getAuthorPHID());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-10 19:44:04 +02:00
|
|
|
}
|