Page MenuHomePhabricator

D10423.diff
No OneTemporary

D10423.diff

diff --git a/src/applications/transactions/editor/PhabricatorApplicationTransactionCommentEditor.php b/src/applications/transactions/editor/PhabricatorApplicationTransactionCommentEditor.php
--- a/src/applications/transactions/editor/PhabricatorApplicationTransactionCommentEditor.php
+++ b/src/applications/transactions/editor/PhabricatorApplicationTransactionCommentEditor.php
@@ -46,6 +46,12 @@
$comment->setViewPolicy(PhabricatorPolicies::POLICY_PUBLIC);
$comment->setEditPolicy($this->getActingAsPHID());
+ $file_phids = PhabricatorMarkupEngine::extractFilePHIDsFromEmbeddedFiles(
+ $actor,
+ array(
+ $comment->getContent(),
+ ));
+
$xaction->openTransaction();
$xaction->beginReadLocking();
if ($xaction->getID()) {
@@ -67,10 +73,19 @@
$xaction->endReadLocking();
$xaction->saveTransaction();
- $xaction->attachComment($comment);
+ // Add links to any files newly referenced by the edit.
+ if ($file_phids) {
+ $editor = new PhabricatorEdgeEditor();
+ foreach ($file_phids as $file_phid) {
+ $editor->addEdge(
+ $xaction->getObjectPHID(),
+ PhabricatorEdgeConfig::TYPE_OBJECT_HAS_FILE,
+ $file_phid);
+ }
+ $editor->save();
+ }
- // TODO: Emit an event for notifications/feed? Can we handle them
- // generically?
+ $xaction->attachComment($comment);
return $this;
}

File Metadata

Mime Type
text/plain
Expires
Thu, May 30, 6:29 AM (3 w, 4 d ago)
Storage Engine
blob
Storage Format
Encrypted (AES-256-CBC)
Storage Handle
6290806
Default Alt Text
D10423.diff (1 KB)

Event Timeline