Merge remote-tracking branch 'upstream/develop' into item-thread
[friendica.git/.git] / src / Module / Objects.php
1 <?php
2 /**
3  * @file src/Module/Objects.php
4  */
5 namespace Friendica\Module;
6
7 use Friendica\BaseModule;
8 use Friendica\Protocol\ActivityPub;
9 use Friendica\Core\System;
10 use Friendica\Model\Item;
11 use Friendica\Database\DBA;
12
13 /**
14  * ActivityPub Objects
15  */
16 class Objects extends BaseModule
17 {
18         public static function rawContent()
19         {
20                 $a = self::getApp();
21
22                 if (empty($a->argv[1])) {
23                         System::httpExit(404);
24                 }
25
26                 if (!ActivityPub::isRequest()) {
27                         goaway(str_replace('objects/', 'display/', $a->query_string));
28                 }
29
30                 $item = Item::selectFirst(['id'], ['guid' => $a->argv[1], 'wall' => true, 'private' => false]);
31                 if (!DBA::isResult($item)) {
32                         System::httpExit(404);
33                 }
34
35                 $data = ActivityPub\Transmitter::createObjectFromItemID($item['id']);
36
37                 header('Content-Type: application/activity+json');
38                 echo json_encode($data);
39                 exit();
40         }
41 }