]> git.mxchange.org Git - friendica.git/commitdiff
Fix: Fetching content via the "objects" endpoint behaved wrong
authorMichael Vogel <icarus@dabo.de>
Thu, 26 Mar 2020 06:52:48 +0000 (07:52 +0100)
committerMichael Vogel <icarus@dabo.de>
Thu, 26 Mar 2020 06:52:48 +0000 (07:52 +0100)
src/Module/Objects.php
src/Protocol/ActivityPub/Transmitter.php

index 023ced08ce33b04fda4d04f9023ccdd383f5d499..264f3dbd64b290514ccc54526d1bc960278c8e84 100644 (file)
@@ -49,17 +49,19 @@ class Objects extends BaseModule
 
                // 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' => [item::PRIVATE, Item::UNLISTED]]);
+               $item = Item::selectFirst(['id'], ['guid' => $a->argv[1], 'origin' => true, 'private' => [item::PUBLIC, Item::UNLISTED]]);
                if (!DBA::isResult($item)) {
                        // 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' => [item::PRIVATE, Item::UNLISTED]]);
+                       $item = Item::selectFirst(['id', 'author-link'], ['guid' => $a->argv[1], 'private' => [item::PUBLIC, Item::UNLISTED]]);
                        if (!DBA::isResult($item) || !strstr($item['author-link'], DI::baseUrl()->get())) {
                                throw new \Friendica\Network\HTTPException\NotFoundException();
                        }
                }
 
                $activity = ActivityPub\Transmitter::createActivityFromItem($item['id'], true);
+               $activity['type'] = $activity['type'] == 'Update' ? 'Create' : $activity['type'];
+
                // Only display "Create" activity objects here, no reshares or anything else
                if (!is_array($activity['object']) || ($activity['type'] != 'Create')) {
                        throw new \Friendica\Network\HTTPException\NotFoundException();
index f6c9311fcc2283cfeab301c5f6a309fbd7a97a08..e39a4f95817e3a33d6378cc1b8487a23e7f58b79 100644 (file)
@@ -193,6 +193,8 @@ class Transmitter
                        $items = Item::select(['id'], $condition, ['limit' => [($page - 1) * 20, 20], 'order' => ['created' => true]]);
                        while ($item = Item::fetch($items)) {
                                $activity = self::createActivityFromItem($item['id'], true);
+                               $activity['type'] = $activity['type'] == 'Update' ? 'Create' : $activity['type'];
+
                                // Only list "Create" activity objects here, no reshares
                                if (is_array($activity['object']) && ($activity['type'] == 'Create')) {
                                        $list[] = $activity['object'];