2019-12-20 20:30:13 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2020-02-09 15:18:46 +00:00
|
|
|
* @copyright Copyright (C) 2020, Friendica
|
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*
|
2019-12-20 20:30:13 +00:00
|
|
|
*/
|
2020-02-09 15:18:46 +00:00
|
|
|
|
2019-12-20 20:30:13 +00:00
|
|
|
namespace Friendica\Worker;
|
|
|
|
|
2020-01-18 14:41:19 +00:00
|
|
|
use Friendica\Core\Cache\Duration;
|
2019-12-20 20:30:13 +00:00
|
|
|
use Friendica\Core\Logger;
|
|
|
|
use Friendica\Core\Protocol;
|
2020-01-04 22:59:20 +00:00
|
|
|
use Friendica\Core\Search;
|
2019-12-20 20:30:13 +00:00
|
|
|
use Friendica\Database\DBA;
|
2020-01-06 23:41:20 +00:00
|
|
|
use Friendica\DI;
|
2020-07-16 19:22:38 +00:00
|
|
|
use Friendica\Model\Contact;
|
2019-12-20 20:30:13 +00:00
|
|
|
use Friendica\Model\GContact;
|
|
|
|
use Friendica\Model\GServer;
|
2020-03-04 21:07:05 +00:00
|
|
|
use Friendica\Network\HTTPRequest;
|
2019-12-20 20:30:13 +00:00
|
|
|
use Friendica\Util\Strings;
|
|
|
|
|
|
|
|
class SearchDirectory
|
|
|
|
{
|
|
|
|
// <search pattern>: Searches for "search pattern" in the directory.
|
|
|
|
public static function execute($search)
|
|
|
|
{
|
2020-01-19 20:21:13 +00:00
|
|
|
if (!DI::config()->get('system', 'poco_local_search')) {
|
2019-12-20 20:30:13 +00:00
|
|
|
Logger::info('Local search is not enabled');
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-01-06 23:45:49 +00:00
|
|
|
$data = DI::cache()->get('SearchDirectory:' . $search);
|
2019-12-20 20:30:13 +00: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-03-04 21:07:05 +00:00
|
|
|
$x = HTTPRequest::fetchUrl(Search::getGlobalDirectory() . '/lsearch?p=1&n=500&search=' . urlencode($search));
|
2019-12-20 20:30:13 +00:00
|
|
|
$j = json_decode($x);
|
|
|
|
|
|
|
|
if (!empty($j->results)) {
|
|
|
|
foreach ($j->results as $jj) {
|
|
|
|
// Check if the contact already exists
|
2020-07-19 11:42:23 +00:00
|
|
|
$gcontact = DBA::selectFirst('gcontact', ['failed'], ['nurl' => Strings::normaliseLink($jj->url)]);
|
2019-12-20 20:30:13 +00:00
|
|
|
if (DBA::isResult($gcontact)) {
|
|
|
|
Logger::info('Profile already exists', ['profile' => $jj->url, 'search' => $search]);
|
|
|
|
|
2020-07-19 11:42:23 +00:00
|
|
|
if ($gcontact['failed']) {
|
2019-12-20 20:30:13 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update the contact
|
|
|
|
GContact::updateFromProbe($jj->url);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2020-01-01 17:54:36 +00:00
|
|
|
$server_url = GContact::getBasepath($jj->url, true);
|
2019-12-20 20:30:13 +00:00
|
|
|
if ($server_url != '') {
|
|
|
|
if (!GServer::check($server_url)) {
|
2019-12-21 04:23:26 +00:00
|
|
|
Logger::info("Friendica server doesn't answer.", ['server' => $server_url]);
|
2019-12-20 20:30:13 +00:00
|
|
|
continue;
|
|
|
|
}
|
2019-12-21 04:23:26 +00:00
|
|
|
Logger::info('Friendica server seems to be okay.', ['server' => $server_url]);
|
2019-12-20 20:30:13 +00:00
|
|
|
}
|
|
|
|
|
2020-07-16 19:22:38 +00:00
|
|
|
$data = Contact::getByURL($jj->url);
|
2019-12-20 20:30:13 +00:00
|
|
|
if ($data['network'] == Protocol::DFRN) {
|
2019-12-21 04:23:26 +00:00
|
|
|
Logger::info('Add profile to local directory', ['profile' => $jj->url]);
|
2019-12-20 20:30:13 +00:00
|
|
|
|
|
|
|
if ($jj->tags != '') {
|
|
|
|
$data['keywords'] = $jj->tags;
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['server_url'] = $data['baseurl'];
|
|
|
|
|
|
|
|
GContact::update($data);
|
|
|
|
} else {
|
2019-12-21 04:23:26 +00:00
|
|
|
Logger::info('Profile is not responding or no Friendica contact', ['profile' => $jj->url, 'network' => $data['network']]);
|
2019-12-20 20:30:13 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-01-18 14:41:19 +00:00
|
|
|
DI::cache()->set('SearchDirectory:' . $search, time(), Duration::DAY);
|
2019-12-20 20:30:13 +00:00
|
|
|
}
|
|
|
|
}
|