Removed unused PoCo functionality
This commit is contained in:
parent
a54675b597
commit
23b7da3664
148
mod/poco.php
148
mod/poco.php
|
@ -27,120 +27,37 @@ use Friendica\Core\Protocol;
|
||||||
use Friendica\Core\Renderer;
|
use Friendica\Core\Renderer;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
use Friendica\Model\GServer;
|
|
||||||
use Friendica\Util\DateTimeFormat;
|
|
||||||
use Friendica\Util\Strings;
|
use Friendica\Util\Strings;
|
||||||
use Friendica\Util\XML;
|
use Friendica\Util\XML;
|
||||||
|
|
||||||
function poco_init(App $a) {
|
function poco_init(App $a) {
|
||||||
$system_mode = false;
|
|
||||||
|
|
||||||
if (intval(DI::config()->get('system', 'block_public')) || (DI::config()->get('system', 'block_local_dir'))) {
|
if (intval(DI::config()->get('system', 'block_public')) || (DI::config()->get('system', 'block_local_dir'))) {
|
||||||
throw new \Friendica\Network\HTTPException\ForbiddenException();
|
throw new \Friendica\Network\HTTPException\ForbiddenException();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($a->argc > 1) {
|
if ($a->argc > 1) {
|
||||||
$nickname = Strings::escapeTags(trim($a->argv[1]));
|
// Only the system mode is supported
|
||||||
}
|
throw new \Friendica\Network\HTTPException\NotFoundException();
|
||||||
if (empty($nickname)) {
|
|
||||||
if (!DBA::exists('profile', ['net-publish' => true])) {
|
|
||||||
throw new \Friendica\Network\HTTPException\ForbiddenException();
|
|
||||||
}
|
|
||||||
$system_mode = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$format = ($_GET['format'] ?? '') ?: 'json';
|
$format = ($_GET['format'] ?? '') ?: 'json';
|
||||||
|
|
||||||
$justme = false;
|
$totalResults = DBA::count('profile', ['net-publish' => true]);
|
||||||
$global = false;
|
if ($totalResults == 0) {
|
||||||
|
throw new \Friendica\Network\HTTPException\ForbiddenException();
|
||||||
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
|
|
||||||
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();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($justme) {
|
|
||||||
$sql_extra = " AND `contact`.`self` = 1 ";
|
|
||||||
} else {
|
|
||||||
$sql_extra = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
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'])) {
|
if (!empty($_GET['startIndex'])) {
|
||||||
$startIndex = intval($_GET['startIndex']);
|
$startIndex = intval($_GET['startIndex']);
|
||||||
} else {
|
} else {
|
||||||
$startIndex = 0;
|
$startIndex = 0;
|
||||||
}
|
}
|
||||||
$itemsPerPage = ((!empty($_GET['count'])) ? intval($_GET['count']) : $totalResults);
|
$itemsPerPage = (!empty($_GET['count']) ? intval($_GET['count']) : $totalResults);
|
||||||
|
|
||||||
if ($system_mode) {
|
Logger::info("Start system mode query");
|
||||||
Logger::log("Start system mode query", Logger::DEBUG);
|
$contacts = DBA::selectToArray('owner-view', [], ['net-publish' => true], ['limit' => [$startIndex, $itemsPerPage]]);
|
||||||
$contacts = DBA::selectToArray('owner-view', [], ['net-publish' => true], ['limit' => [$startIndex, $itemsPerPage]]);
|
|
||||||
} else {
|
Logger::info("Query done");
|
||||||
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);
|
|
||||||
|
|
||||||
$ret = [];
|
$ret = [];
|
||||||
if (!empty($_GET['sorted'])) {
|
if (!empty($_GET['sorted'])) {
|
||||||
|
@ -149,7 +66,7 @@ function poco_init(App $a) {
|
||||||
if (!empty($_GET['filtered'])) {
|
if (!empty($_GET['filtered'])) {
|
||||||
$ret['filtered'] = false;
|
$ret['filtered'] = false;
|
||||||
}
|
}
|
||||||
if (!empty($_GET['updatedSince']) && ! $global) {
|
if (!empty($_GET['updatedSince'])) {
|
||||||
$ret['updatedSince'] = false;
|
$ret['updatedSince'] = false;
|
||||||
}
|
}
|
||||||
$ret['startIndex'] = (int) $startIndex;
|
$ret['startIndex'] = (int) $startIndex;
|
||||||
|
@ -157,7 +74,6 @@ function poco_init(App $a) {
|
||||||
$ret['totalResults'] = (int) $totalResults;
|
$ret['totalResults'] = (int) $totalResults;
|
||||||
$ret['entry'] = [];
|
$ret['entry'] = [];
|
||||||
|
|
||||||
|
|
||||||
$fields_ret = [
|
$fields_ret = [
|
||||||
'id' => false,
|
'id' => false,
|
||||||
'displayName' => false,
|
'displayName' => false,
|
||||||
|
@ -174,7 +90,7 @@ function poco_init(App $a) {
|
||||||
'generation' => false
|
'generation' => false
|
||||||
];
|
];
|
||||||
|
|
||||||
if (empty($_GET['fields']) || ($_GET['fields'] === '@all')) {
|
if (empty($_GET['fields'])) {
|
||||||
foreach ($fields_ret as $k => $v) {
|
foreach ($fields_ret as $k => $v) {
|
||||||
$fields_ret[$k] = true;
|
$fields_ret[$k] = true;
|
||||||
}
|
}
|
||||||
|
@ -196,13 +112,7 @@ function poco_init(App $a) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! isset($contact['generation'])) {
|
if (! isset($contact['generation'])) {
|
||||||
if ($global) {
|
$contact['generation'] = 1;
|
||||||
$contact['generation'] = 3;
|
|
||||||
} elseif ($system_mode) {
|
|
||||||
$contact['generation'] = 1;
|
|
||||||
} else {
|
|
||||||
$contact['generation'] = 2;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($contact['keywords'] == "") && isset($contact['pub_keywords'])) {
|
if (($contact['keywords'] == "") && isset($contact['pub_keywords'])) {
|
||||||
|
@ -249,20 +159,16 @@ function poco_init(App $a) {
|
||||||
$entry['preferredUsername'] = $contact['nick'];
|
$entry['preferredUsername'] = $contact['nick'];
|
||||||
}
|
}
|
||||||
if ($fields_ret['updated']) {
|
if ($fields_ret['updated']) {
|
||||||
if (! $global) {
|
$entry['updated'] = $contact['success_update'];
|
||||||
$entry['updated'] = $contact['success_update'];
|
|
||||||
|
|
||||||
if ($contact['name-date'] > $entry['updated']) {
|
if ($contact['name-date'] > $entry['updated']) {
|
||||||
$entry['updated'] = $contact['name-date'];
|
$entry['updated'] = $contact['name-date'];
|
||||||
}
|
}
|
||||||
if ($contact['uri-date'] > $entry['updated']) {
|
if ($contact['uri-date'] > $entry['updated']) {
|
||||||
$entry['updated'] = $contact['uri-date'];
|
$entry['updated'] = $contact['uri-date'];
|
||||||
}
|
}
|
||||||
if ($contact['avatar-date'] > $entry['updated']) {
|
if ($contact['avatar-date'] > $entry['updated']) {
|
||||||
$entry['updated'] = $contact['avatar-date'];
|
$entry['updated'] = $contact['avatar-date'];
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$entry['updated'] = $contact['updated'];
|
|
||||||
}
|
}
|
||||||
$entry['updated'] = date("c", strtotime($entry['updated']));
|
$entry['updated'] = date("c", strtotime($entry['updated']));
|
||||||
}
|
}
|
||||||
|
@ -295,19 +201,13 @@ function poco_init(App $a) {
|
||||||
if ($fields_ret['address']) {
|
if ($fields_ret['address']) {
|
||||||
$entry['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'])) {
|
if (isset($contact['locality'])) {
|
||||||
$entry['address']['locality'] = $contact['locality'];
|
$entry['address']['locality'] = $contact['locality'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($contact['region'])) {
|
if (isset($contact['region'])) {
|
||||||
$entry['address']['region'] = $contact['region'];
|
$entry['address']['region'] = $contact['region'];
|
||||||
}
|
}
|
||||||
// See above
|
|
||||||
//if (isset($rr['postal-code']))
|
|
||||||
// $entry['address']['postalCode'] = $rr['postal-code'];
|
|
||||||
|
|
||||||
if (isset($contact['country'])) {
|
if (isset($contact['country'])) {
|
||||||
$entry['address']['country'] = $contact['country'];
|
$entry['address']['country'] = $contact['country'];
|
||||||
|
@ -323,7 +223,7 @@ function poco_init(App $a) {
|
||||||
$ret['entry'][] = [];
|
$ret['entry'][] = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
Logger::log("End of poco", Logger::DEBUG);
|
Logger::info("End of poco");
|
||||||
|
|
||||||
if ($format === 'xml') {
|
if ($format === 'xml') {
|
||||||
header('Content-type: text/xml');
|
header('Content-type: text/xml');
|
||||||
|
|
|
@ -1653,18 +1653,4 @@ class GServer
|
||||||
|
|
||||||
DI::config()->set('poco', 'last_federation_discovery', time());
|
DI::config()->set('poco', 'last_federation_discovery', time());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns a list of 1,000 active servers order by the last contact
|
|
||||||
*
|
|
||||||
* @return array List of server urls
|
|
||||||
* @throws Exception
|
|
||||||
*/
|
|
||||||
public static function getActive()
|
|
||||||
{
|
|
||||||
$result = DBA::p("SELECT `url`, `site_name` AS `displayName`, `network`, `platform`, `version` FROM `gserver`
|
|
||||||
WHERE `network` IN (?, ?, ?, ?) AND NOT `failed` ORDER BY `last_contact` LIMIT ?",
|
|
||||||
Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS, Protocol::ACTIVITYPUB, 1000);
|
|
||||||
return DBA::toArray($result);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -63,41 +63,4 @@ class UpdateServerPeers
|
||||||
}
|
}
|
||||||
Logger::info('Server peer update ended', ['total' => $total, 'added' => $added, 'url' => $url]);
|
Logger::info('Server peer update ended', ['total' => $total, 'added' => $added, 'url' => $url]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Fetch server list from remote servers and adds them when they are new.
|
|
||||||
*
|
|
||||||
* @param string $poco URL to the POCO endpoint
|
|
||||||
*/
|
|
||||||
private static function fetchServerlist($poco)
|
|
||||||
{
|
|
||||||
$curlResult = DI::httpRequest()->get($poco . '/@server');
|
|
||||||
if (!$curlResult->isSuccess()) {
|
|
||||||
Logger::info('Server is not reachable or does not offer the "poco" endpoint', ['poco' => $poco]);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$serverlist = json_decode($curlResult->getBody(), true);
|
|
||||||
if (!is_array($serverlist)) {
|
|
||||||
Logger::info('Server does not have any servers listed', ['poco' => $poco]);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
Logger::info('PoCo Server update start', ['poco' => $poco]);
|
|
||||||
|
|
||||||
$total = 0;
|
|
||||||
$added = 0;
|
|
||||||
foreach ($serverlist as $server) {
|
|
||||||
++$total;
|
|
||||||
if (DBA::exists('gserver', ['nurl' => Strings::normaliseLink($server['url'])])) {
|
|
||||||
// We already know this server
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// This endpoint doesn't offer the schema. So we assume that it is HTTPS.
|
|
||||||
Worker::add(PRIORITY_LOW, 'UpdateGServer', $server['url']);
|
|
||||||
++$added;
|
|
||||||
}
|
|
||||||
|
|
||||||
Logger::info('PoCo Server update ended', ['total' => $total, 'added' => $added, 'poco' => $poco]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue