]> git.mxchange.org Git - friendica.git/blobdiff - mod/poco.php
Merge pull request #11575 from annando/issue-11469
[friendica.git] / mod / poco.php
index bfa4957f1435329255fbbc73bcf026a70bef3096..73179a33f203bab06ab49f6b893471c3117a7b16 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2022, the Friendica project
  *
  * @license GNU AGPL version 3 or any later version
  *
@@ -25,122 +25,41 @@ use Friendica\Content\Text\BBCode;
 use Friendica\Core\Logger;
 use Friendica\Core\Protocol;
 use Friendica\Core\Renderer;
+use Friendica\Core\System;
 use Friendica\Database\DBA;
 use Friendica\DI;
-use Friendica\Model\GServer;
+use Friendica\Module\Response;
 use Friendica\Util\DateTimeFormat;
-use Friendica\Util\Strings;
 use Friendica\Util\XML;
 
 function poco_init(App $a) {
-       $system_mode = false;
-
        if (intval(DI::config()->get('system', 'block_public')) || (DI::config()->get('system', 'block_local_dir'))) {
                throw new \Friendica\Network\HTTPException\ForbiddenException();
        }
 
-       if ($a->argc > 1) {
-               $nickname = Strings::escapeTags(trim($a->argv[1]));
-       }
-       if (empty($nickname)) {
-               if (!DBA::exists('profile', ['net-publish' => true])) {
-                       throw new \Friendica\Network\HTTPException\ForbiddenException();
-               }
-               $system_mode = true;
-       }
-
-       $format = ($_GET['format'] ?? '') ?: 'json';
-
-       $justme = false;
-       $global = false;
-
-       if ($a->argc > 1 && $a->argv[1] === '@server') {
-               // List of all servers that this server knows
-               $ret = GServer::getActive();
-               header('Content-type: application/json');
-               echo json_encode($ret);
-               exit();
-       }
-
-       if ($a->argc > 1 && $a->argv[1] === '@global') {
-               // Global is not supported anymore
+       if (DI::args()->getArgc() > 1) {
+               // Only the system mode is supported 
                throw new \Friendica\Network\HTTPException\NotFoundException();
        }
-       if ($a->argc > 2 && $a->argv[2] === '@me') {
-               $justme = true;
-       }
-       if ($a->argc > 3 && $a->argv[3] === '@all') {
-               $justme = false;
-       }
-       if ($a->argc > 3 && $a->argv[3] === '@self') {
-               $justme = true;
-       }
-       if ($a->argc > 4 && intval($a->argv[4]) && $justme == false) {
-               $cid = intval($a->argv[4]);
-       }
 
-       if (!$system_mode && !$global) {
-               $user = DBA::selectFirst('owner-view', ['uid', 'nickname'], ['nickname' => $nickname, 'hide-friends' => false]);
-               if (!DBA::isResult($user)) {
-                       throw new \Friendica\Network\HTTPException\NotFoundException();
-               }
-       }
+       $format = ($_GET['format'] ?? '') ?: 'json';
 
-       if ($justme) {
-               $sql_extra = " AND `contact`.`self` = 1 ";
-       } else {
-               $sql_extra = "";
+       $totalResults = DBA::count('profile', ['net-publish' => true]);
+       if ($totalResults == 0) {
+               throw new \Friendica\Network\HTTPException\ForbiddenException();
        }
 
-       if (!empty($cid)) {
-               $sql_extra = sprintf(" AND `contact`.`id` = %d ", intval($cid));
-       }
-       if (!empty($_GET['updatedSince'])) {
-               $update_limit = date(DateTimeFormat::MYSQL, strtotime($_GET['updatedSince']));
-       }
-       if ($system_mode) {
-               $totalResults = DBA::count('profile', ['net-publish' => true]);
-       } else {
-               $contacts = q("SELECT count(*) AS `total` FROM `contact` WHERE `uid` = %d AND NOT `blocked` AND NOT `pending` AND NOT `unsearchable` AND NOT `archive`
-                       AND NOT `failed`
-                       AND `network` IN ('%s', '%s', '%s', '%s') $sql_extra",
-                       intval($user['uid']),
-                       DBA::escape(Protocol::DFRN),
-                       DBA::escape(Protocol::DIASPORA),
-                       DBA::escape(Protocol::OSTATUS),
-                       DBA::escape(Protocol::STATUSNET)
-               );
-       }
-       if (empty($totalResults) && DBA::isResult($contacts)) {
-               $totalResults = intval($contacts[0]['total']);
-       } elseif (empty($totalResults)) {
-               $totalResults = 0;
-       }
        if (!empty($_GET['startIndex'])) {
                $startIndex = intval($_GET['startIndex']);
        } else {
                $startIndex = 0;
        }
-       $itemsPerPage = ((!empty($_GET['count'])) ? intval($_GET['count']) : $totalResults);
+       $itemsPerPage = (!empty($_GET['count']) ? intval($_GET['count']) : $totalResults);
 
-       if ($system_mode) {
-               Logger::log("Start system mode query", Logger::DEBUG);
-               $contacts = DBA::selectToArray('owner-view', [], ['net-publish' => true], ['limit' => [$startIndex, $itemsPerPage]]);
-       } else {
-               Logger::log("Start query for user " . $user['nickname'], Logger::DEBUG);
-               $contacts = q("SELECT * FROM `contact` WHERE `uid` = %d AND NOT `blocked` AND NOT `pending` AND NOT `hidden` AND NOT `archive`
-                       AND NOT `failed` AND NOT `unsearchable`
-                       AND `network` IN ('%s', '%s', '%s', '%s') $sql_extra LIMIT %d, %d",
-                       intval($user['uid']),
-                       DBA::escape(Protocol::DFRN),
-                       DBA::escape(Protocol::DIASPORA),
-                       DBA::escape(Protocol::OSTATUS),
-                       DBA::escape(Protocol::STATUSNET),
-                       intval($startIndex),
-                       intval($itemsPerPage)
-               );
-       }
-       Logger::log("Query done", Logger::DEBUG);
+       Logger::info("Start system mode query");
+       $contacts = DBA::selectToArray('owner-view', [], ['net-publish' => true], ['limit' => [$startIndex, $itemsPerPage]]);
+
+       Logger::info("Query done");
 
        $ret = [];
        if (!empty($_GET['sorted'])) {
@@ -149,7 +68,7 @@ function poco_init(App $a) {
        if (!empty($_GET['filtered'])) {
                $ret['filtered'] = false;
        }
-       if (!empty($_GET['updatedSince']) && ! $global) {
+       if (!empty($_GET['updatedSince'])) {
                $ret['updatedSince'] = false;
        }
        $ret['startIndex']   = (int) $startIndex;
@@ -157,7 +76,6 @@ function poco_init(App $a) {
        $ret['totalResults'] = (int) $totalResults;
        $ret['entry']        = [];
 
-
        $fields_ret = [
                'id' => false,
                'displayName' => false,
@@ -174,7 +92,7 @@ function poco_init(App $a) {
                'generation' => false
        ];
 
-       if (empty($_GET['fields']) || ($_GET['fields'] === '@all')) {
+       if (empty($_GET['fields'])) {
                foreach ($fields_ret as $k => $v) {
                        $fields_ret[$k] = true;
                }
@@ -196,13 +114,7 @@ function poco_init(App $a) {
                        }
 
                        if (! isset($contact['generation'])) {
-                               if ($global) {
-                                       $contact['generation'] = 3;
-                               } elseif ($system_mode) {
-                                       $contact['generation'] = 1;
-                               } else {
-                                       $contact['generation'] = 2;
-                               }
+                               $contact['generation'] = 1;
                        }
 
                        if (($contact['keywords'] == "") && isset($contact['pub_keywords'])) {
@@ -211,10 +123,12 @@ function poco_init(App $a) {
                        if (isset($contact['account-type'])) {
                                $contact['contact-type'] = $contact['account-type'];
                        }
-                       $about = DI::cache()->get("about:" . $contact['updated'] . ":" . $contact['nurl']);
+
+                       $cacheKey = 'about:' . $contact['nick'] . ':' . DateTimeFormat::utc($contact['updated'], DateTimeFormat::ATOM);
+                       $about = DI::cache()->get($cacheKey);
                        if (is_null($about)) {
-                               $about = BBCode::convert($contact['about'], false);
-                               DI::cache()->set("about:" . $contact['updated'] . ":" . $contact['nurl'], $about);
+                               $about = BBCode::convertForUriId($contact['uri-id'], $contact['about']);
+                               DI::cache()->set($cacheKey, $about);
                        }
 
                        // Non connected persons can only see the keywords of a Diaspora account
@@ -249,20 +163,16 @@ function poco_init(App $a) {
                                $entry['preferredUsername'] = $contact['nick'];
                        }
                        if ($fields_ret['updated']) {
-                               if (! $global) {
-                                       $entry['updated'] = $contact['success_update'];
+                               $entry['updated'] = $contact['success_update'];
 
-                                       if ($contact['name-date'] > $entry['updated']) {
-                                               $entry['updated'] = $contact['name-date'];
-                                       }
-                                       if ($contact['uri-date'] > $entry['updated']) {
-                                               $entry['updated'] = $contact['uri-date'];
-                                       }
-                                       if ($contact['avatar-date'] > $entry['updated']) {
-                                               $entry['updated'] = $contact['avatar-date'];
-                                       }
-                               } else {
-                                       $entry['updated'] = $contact['updated'];
+                               if ($contact['name-date'] > $entry['updated']) {
+                                       $entry['updated'] = $contact['name-date'];
+                               }
+                               if ($contact['uri-date'] > $entry['updated']) {
+                                       $entry['updated'] = $contact['uri-date'];
+                               }
+                               if ($contact['avatar-date'] > $entry['updated']) {
+                                       $entry['updated'] = $contact['avatar-date'];
                                }
                                $entry['updated'] = date("c", strtotime($entry['updated']));
                        }
@@ -295,19 +205,13 @@ function poco_init(App $a) {
                        if ($fields_ret['address']) {
                                $entry['address'] = [];
 
-                               // Deactivated. It just reveals too much data. (Although its from the default profile)
-                               //if (isset($rr['address']))
-                               //       $entry['address']['streetAddress'] = $rr['address'];
-
                                if (isset($contact['locality'])) {
                                        $entry['address']['locality'] = $contact['locality'];
                                }
+
                                if (isset($contact['region'])) {
                                        $entry['address']['region'] = $contact['region'];
                                }
-                               // See above
-                               //if (isset($rr['postal-code']))
-                               //       $entry['address']['postalCode'] = $rr['postal-code'];
 
                                if (isset($contact['country'])) {
                                        $entry['address']['country'] = $contact['country'];
@@ -323,17 +227,13 @@ function poco_init(App $a) {
                $ret['entry'][] = [];
        }
 
-       Logger::log("End of poco", Logger::DEBUG);
+       Logger::info("End of poco");
 
        if ($format === 'xml') {
-               header('Content-type: text/xml');
-               echo Renderer::replaceMacros(Renderer::getMarkupTemplate('poco_xml.tpl'), XML::arrayEscape(['$response' => $ret]));
-               exit();
+               System::httpExit(Renderer::replaceMacros(Renderer::getMarkupTemplate('poco_xml.tpl'), XML::arrayEscape(['$response' => $ret])), Response::TYPE_XML);
        }
        if ($format === 'json') {
-               header('Content-type: application/json');
-               echo json_encode($ret);
-               exit();
+               System::jsonExit($ret);
        } else {
                throw new \Friendica\Network\HTTPException\InternalServerErrorException();
        }