friendica-github/src/Worker/UpdateGContact.php

92 lines
2.2 KiB
PHP
Raw Normal View History

<?php
/**
2017-11-15 21:12:33 +00:00
* @file src/Worker/UpdateGcontact.php
*/
2017-11-18 07:33:44 +00:00
namespace Friendica\Worker;
2018-10-29 21:20:46 +00:00
use Friendica\Core\Logger;
use Friendica\Core\Protocol;
use Friendica\Database\DBA;
use Friendica\Network\Probe;
use Friendica\Protocol\PortableContact;
use Friendica\Util\DateTimeFormat;
use Friendica\Util\Strings;
class UpdateGContact
{
public static function execute($contact_id)
{
2018-10-29 21:20:46 +00:00
Logger::log('update_gcontact: start');
2017-11-15 21:12:33 +00:00
if (empty($contact_id)) {
2018-10-29 21:20:46 +00:00
Logger::log('update_gcontact: no contact');
2017-11-15 21:12:33 +00:00
return;
}
2017-11-15 21:12:33 +00:00
$r = q("SELECT * FROM `gcontact` WHERE `id` = %d", intval($contact_id));
2018-07-21 12:46:04 +00:00
if (!DBA::isResult($r)) {
2017-11-15 21:12:33 +00:00
return;
}
2019-07-01 18:00:55 +00:00
if (!in_array($r[0]["network"], Protocol::FEDERATED)) {
2017-11-15 21:12:33 +00:00
return;
}
2017-11-15 21:12:33 +00:00
$data = Probe::uri($r[0]["url"]);
2019-07-01 18:00:55 +00:00
if (!in_array($data["network"], Protocol::FEDERATED)) {
if ($r[0]["server_url"] != "") {
2017-11-15 21:12:33 +00:00
PortableContact::checkServer($r[0]["server_url"], $r[0]["network"]);
}
2017-11-15 21:12:33 +00:00
q("UPDATE `gcontact` SET `last_failure` = '%s' WHERE `id` = %d",
2018-07-21 13:10:13 +00:00
DBA::escape(DateTimeFormat::utcNow()), intval($contact_id));
2017-11-15 21:12:33 +00:00
return;
}
if (($data["name"] == "") && ($r[0]['name'] != "")) {
2017-11-15 21:12:33 +00:00
$data["name"] = $r[0]['name'];
}
2017-11-15 21:12:33 +00:00
if (($data["nick"] == "") && ($r[0]['nick'] != "")) {
2017-11-15 21:12:33 +00:00
$data["nick"] = $r[0]['nick'];
}
if (($data["addr"] == "") && ($r[0]['addr'] != "")) {
2017-11-15 21:12:33 +00:00
$data["addr"] = $r[0]['addr'];
}
2017-11-15 21:12:33 +00:00
if (($data["photo"] == "") && ($r[0]['photo'] != "")) {
2017-11-15 21:12:33 +00:00
$data["photo"] = $r[0]['photo'];
}
2017-11-15 21:12:33 +00:00
q("UPDATE `gcontact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
WHERE `id` = %d",
2018-07-21 13:10:13 +00:00
DBA::escape($data["name"]),
DBA::escape($data["nick"]),
DBA::escape($data["addr"]),
DBA::escape($data["photo"]),
intval($contact_id)
);
2017-11-15 21:12:33 +00:00
q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
WHERE `uid` = 0 AND `addr` = '' AND `nurl` = '%s'",
2018-07-21 13:10:13 +00:00
DBA::escape($data["name"]),
DBA::escape($data["nick"]),
DBA::escape($data["addr"]),
DBA::escape($data["photo"]),
DBA::escape(Strings::normaliseLink($data["url"]))
);
2017-11-15 21:12:33 +00:00
q("UPDATE `contact` SET `addr` = '%s'
WHERE `uid` != 0 AND `addr` = '' AND `nurl` = '%s'",
2018-07-21 13:10:13 +00:00
DBA::escape($data["addr"]),
DBA::escape(Strings::normaliseLink($data["url"]))
);
2017-11-15 21:12:33 +00:00
}
}