1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-24 05:28:18 +01:00

Add renderText to FeedStory for simple text repr of story

Summary:
This pushes the rendering of feed stories out of IRCDifferentialNotificationHandler and into feed.query

Also fixes bug in feed.query that broke attachment of related objects to stories.

Test Plan: echo '{"view": "text", "limit": 10}' | arc call-conduit feed.query

Reviewers: epriestley

Reviewed By: epriestley

CC: aran, Korvin, codeblock

Differential Revision: https://secure.phabricator.com/D4390
This commit is contained in:
John Watson 2013-01-10 11:10:32 -08:00 committed by epriestley
parent dceb161150
commit 1f58185f89
8 changed files with 199 additions and 6 deletions

View file

@ -77,14 +77,8 @@ final class ConduitAPI_feed_query_Method extends ConduitAPIMethod {
$stories = $query->execute(); $stories = $query->execute();
if ($stories) { if ($stories) {
$handle_phids = array_mergev(mpull($stories, 'getRequiredHandlePHIDs'));
$handles = id(new PhabricatorObjectHandleData($handle_phids))
->loadHandles();
foreach ($stories as $story) { foreach ($stories as $story) {
$story->setHandles($handles);
$story_data = $story->getStoryData(); $story_data = $story->getStoryData();
$data = null; $data = null;
@ -110,6 +104,15 @@ final class ConduitAPI_feed_query_Method extends ConduitAPIMethod {
'data' => $story_data->getStoryData(), 'data' => $story_data->getStoryData(),
); );
break; break;
case 'text':
$data = array(
'class' => $story_data->getStoryType(),
'epoch' => $story_data->getEpoch(),
'authorPHID' => $story_data->getAuthorPHID(),
'chronologicalKey' => $story_data->getChronologicalKey(),
'text' => $story->renderText()
);
break;
default: default:
throw new ConduitException('ERR-UNKNOWN-TYPE'); throw new ConduitException('ERR-UNKNOWN-TYPE');
} }

View file

@ -41,4 +41,17 @@ final class PhabricatorFeedStoryAudit extends PhabricatorFeedStory {
return $view; return $view;
} }
public function renderText() {
$author_name = $this->getHandle($this->getAuthorPHID())->getLinkName();
$commit_path = $this->getHandle($this->getPrimaryObjectPHID())->getURI();
$commit_uri = PhabricatorEnv::getURI($commit_path);
$action = $this->getValue('action');
$verb = PhabricatorAuditActionConstants::getActionPastTenseVerb($action);
$text = "{$author_name} {$verb} commit {$commit_uri}";
return $text;
}
} }

View file

@ -57,4 +57,39 @@ final class PhabricatorFeedStoryCommit extends PhabricatorFeedStory {
return $view; return $view;
} }
public function renderText() {
$author = null;
if ($this->getAuthorPHID()) {
$author = $this->getHandle($this->getAuthorPHID())->getLinkName();
} else {
$author = $this->getValue('authorName');
}
$committer = null;
if ($this->getValue('committerPHID')) {
$committer_handle = $this->getHandle($this->getValue('committerPHID'));
$committer = $committer_handle->getLinkName();
} else if ($this->getValue('committerName')) {
$committer = $this->getValue('committerName');
}
$commit_handle = $this->getHandle($this->getPrimaryObjectPHID());
$commit_uri = PhabricatorEnv::getURI($commit_handle->getURI());
$commit_name = $commit_handle->getLinkName();
if (!$committer) {
$committer = $author;
$author = null;
}
if ($author) {
$text = "{$committer} (authored by {$author})".
"committed {$commit_name} {$commit_uri}";
} else {
$text = "{$committer} committed {$commit_name} {$commit_uri}";
}
return $text;
}
} }

View file

@ -56,6 +56,21 @@ final class PhabricatorFeedStoryDifferential extends PhabricatorFeedStory {
return $one_line; return $one_line;
} }
public function renderText() {
$author_name = $this->getHandle($this->getAuthorPHID())->getLinkName();
$revision_handle = $this->getHandle($this->getPrimaryObjectPHID());
$revision_title = $revision_handle->getLinkName();
$revision_uri = PhabricatorEnv::getURI($revision_handle->getURI());
$action = $this->getValue('action');
$verb = DifferentialAction::getActionPastTenseVerb($action);
$text = "{$author_name} {$verb} revision {$revision_title} {$revision_uri}";
return $text;
}
public function getNotificationAggregations() { public function getNotificationAggregations() {
$class = get_class($this); $class = get_class($this);
$phid = $this->getStoryData()->getValue('revision_phid'); $phid = $this->getStoryData()->getValue('revision_phid');

View file

@ -82,6 +82,44 @@ final class PhabricatorFeedStoryManiphest
return $one_line; return $one_line;
} }
public function renderText() {
$actor_phid = $this->getAuthorPHID();
$author_name = $this->getHandle($actor_phid)->getLinkName();
$owner_phid = $this->getValue('ownerPHID');
$owner_name = $this->getHandle($owner_phid)->getLinkName();
$task_phid = $this->getPrimaryObjectPHID();
$task_handle = $this->getHandle($task_phid);
$task_title = $task_handle->getLinkName();
$task_uri = PhabricatorEnv::getURI($task_handle->getURI());
$action = $this->getValue('action');
$verb = ManiphestAction::getActionPastTenseVerb($action);
switch ($action) {
case ManiphestAction::ACTION_ASSIGN:
case ManiphestAction::ACTION_REASSIGN:
if ($owner_phid) {
if ($owner_phid == $actor_phid) {
$text = "{$author_name} claimed {$task_title}";
} else {
$text = "{$author_name} {$verb} {$task_title} to {$owner_name}";
}
} else {
$text = "{$author_name} placed {$task_title} up for grabs";
}
break;
default:
$text = "{$author_name} {$verb} {$task_title}";
break;
}
$text .= " {$task_uri}";
return $text;
}
public function getNotificationAggregations() { public function getNotificationAggregations() {
$class = get_class($this); $class = get_class($this);
$phid = $this->getStoryData()->getValue('taskPHID'); $phid = $this->getStoryData()->getValue('taskPHID');

View file

@ -44,4 +44,17 @@ final class PhabricatorFeedStoryPhriction extends PhabricatorFeedStory {
return $view; return $view;
} }
public function renderText() {
$author_name = $this->getHandle($this->getAuthorPHID())->getLinkName();
$document_handle = $this->getHandle($this->getPrimaryObjectPHID());
$document_title = $document_handle->getLinkName();
$document_uri = PhabricatorEnv::getURI($document_handle->getURI());
$text = "{$author_name} {$verb} the document".
"{$document_title} {$document_uri}";
return $text;
}
} }

View file

@ -82,4 +82,70 @@ final class PhabricatorFeedStoryProject extends PhabricatorFeedStory {
return $view; return $view;
} }
public function renderText() {
$type = $this->getValue('type');
$old = $this->getValue('old');
$new = $this->getValue('new');
$proj_handle = $this->getHandle($this->getPrimaryObjectPHID());
$proj_name = $proj_handle->getLinkName();
$proj_uri = PhabricatorEnv::getURI($proj_handle->getURI());
$author_phid = $this->getAuthorPHID();
$author_name = $this->getHandle($author_phid)->getLinkName();
switch ($type) {
case PhabricatorProjectTransactionType::TYPE_NAME:
if (strlen($old)) {
$action = 'renamed project '.
$proj_name.
' from '.
$old.
' to '.
$new;
} else {
$action = 'created project '.
$proj_name.
' (as '.
$new.
')';
}
break;
case PhabricatorProjectTransactionType::TYPE_STATUS:
$action = 'changed project '.
$proj_name.
' status from '.
$old.
' to '.
$new;
break;
case PhabricatorProjectTransactionType::TYPE_MEMBERS:
$add = array_diff($new, $old);
$rem = array_diff($old, $new);
if ((count($add) == 1) && (count($rem) == 0) &&
(head($add) == $author_phid)) {
$action = 'joined project';
} else if ((count($add) == 0) && (count($rem) == 1) &&
(head($rem) == $author_phid)) {
$action = 'left project';
} else if (empty($rem)) {
$action = 'added members to project';
} else if (empty($add)) {
$action = 'removed members from project';
} else {
$action = 'changed members of project';
}
$action .= " {$proj_name}";
break;
default:
$action = "updated project {$proj_name}";
break;
}
$text = "{$author_name} {$action} {$proj_uri}";
return $text;
}
} }

View file

@ -23,4 +23,14 @@ final class PhabricatorFeedStoryStatus extends PhabricatorFeedStory {
return $view; return $view;
} }
public function renderText() {
$author_handle = $this->getHandle($this->getPrimaryObjectPHID());
$author_name = $author_handle->getLinkName();
$author_uri = PhabricatorEnv::getURI($author_handle->getURI());
$text = "{$author_name} updated their status {$author_url}";
return $text;
}
} }