2019-12-20 21:30:13 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @file src/Worker/SearchDirectory.php
|
|
|
|
*/
|
|
|
|
namespace Friendica\Worker;
|
|
|
|
|
2020-01-18 15:41:19 +01:00
|
|
|
use Friendica\Core\Cache\Duration;
|
2019-12-20 21:30:13 +01:00
|
|
|
use Friendica\Core\Logger;
|
|
|
|
use Friendica\Core\Protocol;
|
2020-01-04 23:59:20 +01:00
|
|
|
use Friendica\Core\Search;
|
2019-12-20 21:30:13 +01:00
|
|
|
use Friendica\Database\DBA;
|
2020-01-07 00:41:20 +01:00
|
|
|
use Friendica\DI;
|
2019-12-20 21:30:13 +01:00
|
|
|
use Friendica\Model\GContact;
|
|
|
|
use Friendica\Model\GServer;
|
|
|
|
use Friendica\Network\Probe;
|
|
|
|
use Friendica\Util\Network;
|
|
|
|
use Friendica\Util\Strings;
|
|
|
|
|
|
|
|
class SearchDirectory
|
|
|
|
{
|
|
|
|
// <search pattern>: Searches for "search pattern" in the directory.
|
|
|
|
public static function execute($search)
|
|
|
|
{
|
2020-01-19 21:21:13 +01:00
|
|
|
if (!DI::config()->get('system', 'poco_local_search')) {
|
2019-12-20 21:30:13 +01:00
|
|
|
Logger::info('Local search is not enabled');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-01-07 00:45:49 +01:00
|
|
|
$data = DI::cache()->get('SearchDirectory:' . $search);
|
2019-12-20 21:30:13 +01:00
|
|
|
if (!is_null($data)) {
|
|
|
|
// Only search for the same item every 24 hours
|
|
|
|
if (time() < $data + (60 * 60 * 24)) {
|
|
|
|
Logger::info('Already searched this in the last 24 hours', ['search' => $search]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-04 23:59:20 +01:00
|
|
|
$x = Network::fetchUrl(Search::getGlobalDirectory() . '/lsearch?p=1&n=500&search=' . urlencode($search));
|
2019-12-20 21:30:13 +01:00
|
|
|
$j = json_decode($x);
|
|
|
|
|
|
|
|
if (!empty($j->results)) {
|
|
|
|
foreach ($j->results as $jj) {
|
|
|
|
// Check if the contact already exists
|
|
|
|
$gcontact = DBA::selectFirst('gcontact', ['id', 'last_contact', 'last_failure', 'updated'], ['nurl' => Strings::normaliseLink($jj->url)]);
|
|
|
|
if (DBA::isResult($gcontact)) {
|
|
|
|
Logger::info('Profile already exists', ['profile' => $jj->url, 'search' => $search]);
|
|
|
|
|
|
|
|
if (($gcontact['last_contact'] < $gcontact['last_failure']) &&
|
|
|
|
($gcontact['updated'] < $gcontact['last_failure'])) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update the contact
|
|
|
|
GContact::updateFromProbe($jj->url);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2020-01-01 18:54:36 +01:00
|
|
|
$server_url = GContact::getBasepath($jj->url, true);
|
2019-12-20 21:30:13 +01:00
|
|
|
if ($server_url != '') {
|
|
|
|
if (!GServer::check($server_url)) {
|
2019-12-21 05:23:26 +01:00
|
|
|
Logger::info("Friendica server doesn't answer.", ['server' => $server_url]);
|
2019-12-20 21:30:13 +01:00
|
|
|
continue;
|
|
|
|
}
|
2019-12-21 05:23:26 +01:00
|
|
|
Logger::info('Friendica server seems to be okay.', ['server' => $server_url]);
|
2019-12-20 21:30:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$data = Probe::uri($jj->url);
|
|
|
|
if ($data['network'] == Protocol::DFRN) {
|
2019-12-21 05:23:26 +01:00
|
|
|
Logger::info('Add profile to local directory', ['profile' => $jj->url]);
|
2019-12-20 21:30:13 +01:00
|
|
|
|
|
|
|
if ($jj->tags != '') {
|
|
|
|
$data['keywords'] = $jj->tags;
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['server_url'] = $data['baseurl'];
|
|
|
|
|
|
|
|
GContact::update($data);
|
|
|
|
} else {
|
2019-12-21 05:23:26 +01:00
|
|
|
Logger::info('Profile is not responding or no Friendica contact', ['profile' => $jj->url, 'network' => $data['network']]);
|
2019-12-20 21:30:13 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-01-18 15:41:19 +01:00
|
|
|
DI::cache()->set('SearchDirectory:' . $search, time(), Duration::DAY);
|
2019-12-20 21:30:13 +01:00
|
|
|
}
|
|
|
|
}
|