]> git.mxchange.org Git - friendica.git/blobdiff - src/Module/Objects.php
Use "received" instead of "created" when displaying posts in creation order
[friendica.git] / src / Module / Objects.php
index 3aa8c9e21704ff66ff170d9c120622764ae17ae7..2104e8042fd98e3c2cc9f7bc57eb9782a7627826 100644 (file)
@@ -5,11 +5,10 @@
 namespace Friendica\Module;
 
 use Friendica\BaseModule;
-use Friendica\Protocol\ActivityPub;
 use Friendica\Core\System;
-use Friendica\Model\Item;
 use Friendica\Database\DBA;
-use Friendica\Util\HTTPSignature;
+use Friendica\Model\Item;
+use Friendica\Protocol\ActivityPub;
 
 /**
  * ActivityPub Objects
@@ -21,7 +20,7 @@ class Objects extends BaseModule
                $a = self::getApp();
 
                if (empty($a->argv[1])) {
-                       System::httpExit(404);
+                       throw new \Friendica\Network\HTTPException\NotFoundException();
                }
 
                if (!ActivityPub::isRequest()) {
@@ -31,13 +30,16 @@ class Objects extends BaseModule
                /// @todo Add Authentication to enable fetching of non public content
                // $requester = HTTPSignature::getSigner('', $_SERVER);
 
-               $item = Item::selectFirst(['id', 'author-link'], ['guid' => $a->argv[1], 'private' => false]);
+               // At first we try the original post with that guid
+               // @TODO: Replace with parameter from router
+               $item = Item::selectFirst(['id'], ['guid' => $a->argv[1], 'origin' => true, 'private' => false]);
                if (!DBA::isResult($item)) {
-                       System::httpExit(404);
-               }
-
-               if (!strstr($item['author-link'], System::baseUrl())) {
-                       System::httpExit(404);
+                       // If no original post could be found, it could possibly be a forum post, there we remove the "origin" field.
+                       // @TODO: Replace with parameter from router
+                       $item = Item::selectFirst(['id', 'author-link'], ['guid' => $a->argv[1], 'private' => false]);
+                       if (!DBA::isResult($item) || !strstr($item['author-link'], System::baseUrl())) {
+                               throw new \Friendica\Network\HTTPException\NotFoundException();
+                       }
                }
 
                $data = ActivityPub\Transmitter::createObjectFromItemID($item['id']);