2015-11-05 18:47:54 -05:00
|
|
|
<?php
|
2018-01-24 21:08:45 -05:00
|
|
|
|
2017-11-15 10:53:16 -05:00
|
|
|
/**
|
2017-11-15 16:12:33 -05:00
|
|
|
* @file src/Worker/UpdateGcontact.php
|
2017-11-15 10:53:16 -05:00
|
|
|
*/
|
2018-01-24 21:08:45 -05:00
|
|
|
|
2017-11-18 02:33:44 -05:00
|
|
|
namespace Friendica\Worker;
|
|
|
|
|
2018-07-21 08:40:21 -04:00
|
|
|
use Friendica\Database\DBA;
|
2017-11-15 10:53:16 -05:00
|
|
|
use Friendica\Network\Probe;
|
|
|
|
use Friendica\Protocol\PortableContact;
|
2018-01-26 21:38:34 -05:00
|
|
|
use Friendica\Util\DateTimeFormat;
|
2017-01-18 16:45:32 -05:00
|
|
|
|
2018-01-24 21:08:45 -05:00
|
|
|
class UpdateGContact
|
|
|
|
{
|
|
|
|
public static function execute($contact_id)
|
|
|
|
{
|
2017-11-15 16:12:33 -05:00
|
|
|
logger('update_gcontact: start');
|
2015-11-05 18:47:54 -05:00
|
|
|
|
2017-11-15 16:12:33 -05:00
|
|
|
if (empty($contact_id)) {
|
|
|
|
logger('update_gcontact: no contact');
|
|
|
|
return;
|
|
|
|
}
|
2015-11-05 18:47:54 -05:00
|
|
|
|
2017-11-15 16:12:33 -05:00
|
|
|
$r = q("SELECT * FROM `gcontact` WHERE `id` = %d", intval($contact_id));
|
2015-11-05 18:47:54 -05:00
|
|
|
|
2018-07-21 08:46:04 -04:00
|
|
|
if (!DBA::isResult($r)) {
|
2017-11-15 16:12:33 -05:00
|
|
|
return;
|
|
|
|
}
|
2015-11-05 18:47:54 -05:00
|
|
|
|
2018-01-15 08:05:12 -05:00
|
|
|
if (!in_array($r[0]["network"], [NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS])) {
|
2017-11-15 16:12:33 -05:00
|
|
|
return;
|
|
|
|
}
|
2015-11-05 18:47:54 -05:00
|
|
|
|
2017-11-15 16:12:33 -05:00
|
|
|
$data = Probe::uri($r[0]["url"]);
|
2015-11-06 03:15:20 -05:00
|
|
|
|
2018-01-15 08:05:12 -05:00
|
|
|
if (!in_array($data["network"], [NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS])) {
|
2018-01-24 21:08:45 -05:00
|
|
|
if ($r[0]["server_url"] != "") {
|
2017-11-15 16:12:33 -05:00
|
|
|
PortableContact::checkServer($r[0]["server_url"], $r[0]["network"]);
|
2018-01-24 21:08:45 -05:00
|
|
|
}
|
2015-11-05 18:47:54 -05:00
|
|
|
|
2017-11-15 16:12:33 -05:00
|
|
|
q("UPDATE `gcontact` SET `last_failure` = '%s' WHERE `id` = %d",
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape(DateTimeFormat::utcNow()), intval($contact_id));
|
2017-11-15 16:12:33 -05:00
|
|
|
return;
|
|
|
|
}
|
2015-11-06 03:15:20 -05:00
|
|
|
|
2018-01-24 21:08:45 -05:00
|
|
|
if (($data["name"] == "") && ($r[0]['name'] != "")) {
|
2017-11-15 16:12:33 -05:00
|
|
|
$data["name"] = $r[0]['name'];
|
2018-01-24 21:08:45 -05:00
|
|
|
}
|
2017-11-15 16:12:33 -05:00
|
|
|
|
2018-01-24 21:08:45 -05:00
|
|
|
if (($data["nick"] == "") && ($r[0]['nick'] != "")) {
|
2017-11-15 16:12:33 -05:00
|
|
|
$data["nick"] = $r[0]['nick'];
|
2018-01-24 21:08:45 -05:00
|
|
|
}
|
2015-11-05 18:47:54 -05:00
|
|
|
|
2018-01-24 21:08:45 -05:00
|
|
|
if (($data["addr"] == "") && ($r[0]['addr'] != "")) {
|
2017-11-15 16:12:33 -05:00
|
|
|
$data["addr"] = $r[0]['addr'];
|
2018-01-24 21:08:45 -05:00
|
|
|
}
|
2017-11-15 16:12:33 -05:00
|
|
|
|
2018-01-24 21:08:45 -05:00
|
|
|
if (($data["photo"] == "") && ($r[0]['photo'] != "")) {
|
2017-11-15 16:12:33 -05:00
|
|
|
$data["photo"] = $r[0]['photo'];
|
2018-01-24 21:08:45 -05:00
|
|
|
}
|
2017-11-15 16:12:33 -05:00
|
|
|
|
|
|
|
|
|
|
|
q("UPDATE `gcontact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
|
|
|
|
WHERE `id` = %d",
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape($data["name"]),
|
|
|
|
DBA::escape($data["nick"]),
|
|
|
|
DBA::escape($data["addr"]),
|
|
|
|
DBA::escape($data["photo"]),
|
2018-01-24 21:08:45 -05:00
|
|
|
intval($contact_id)
|
|
|
|
);
|
2017-11-15 16:12:33 -05:00
|
|
|
|
|
|
|
q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
|
|
|
|
WHERE `uid` = 0 AND `addr` = '' AND `nurl` = '%s'",
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape($data["name"]),
|
|
|
|
DBA::escape($data["nick"]),
|
|
|
|
DBA::escape($data["addr"]),
|
|
|
|
DBA::escape($data["photo"]),
|
|
|
|
DBA::escape(normalise_link($data["url"]))
|
2018-01-24 21:08:45 -05:00
|
|
|
);
|
2017-11-15 16:12:33 -05:00
|
|
|
|
|
|
|
q("UPDATE `contact` SET `addr` = '%s'
|
|
|
|
WHERE `uid` != 0 AND `addr` = '' AND `nurl` = '%s'",
|
2018-07-21 09:10:13 -04:00
|
|
|
DBA::escape($data["addr"]),
|
|
|
|
DBA::escape(normalise_link($data["url"]))
|
2018-01-24 21:08:45 -05:00
|
|
|
);
|
2017-11-15 16:12:33 -05:00
|
|
|
}
|
2015-11-05 18:47:54 -05:00
|
|
|
}
|