]> git.mxchange.org Git - friendica.git/blob - src/Worker/UpdateGContact.php
normalise_link calls
[friendica.git] / src / Worker / UpdateGContact.php
1 <?php
2
3 /**
4  * @file src/Worker/UpdateGcontact.php
5  */
6
7 namespace Friendica\Worker;
8
9 use Friendica\Core\Logger;
10 use Friendica\Core\Protocol;
11 use Friendica\Database\DBA;
12 use Friendica\Network\Probe;
13 use Friendica\Protocol\PortableContact;
14 use Friendica\Util\DateTimeFormat;
15 use Friendica\Util\Strings;
16
17 class UpdateGContact
18 {
19         public static function execute($contact_id)
20         {
21                 Logger::log('update_gcontact: start');
22
23                 if (empty($contact_id)) {
24                         Logger::log('update_gcontact: no contact');
25                         return;
26                 }
27
28                 $r = q("SELECT * FROM `gcontact` WHERE `id` = %d", intval($contact_id));
29
30                 if (!DBA::isResult($r)) {
31                         return;
32                 }
33
34                 if (!in_array($r[0]["network"], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS])) {
35                         return;
36                 }
37
38                 $data = Probe::uri($r[0]["url"]);
39
40                 if (!in_array($data["network"], [Protocol::ACTIVITYPUB, Protocol::DFRN, Protocol::DIASPORA, Protocol::OSTATUS])) {
41                         if ($r[0]["server_url"] != "") {
42                                 PortableContact::checkServer($r[0]["server_url"], $r[0]["network"]);
43                         }
44
45                         q("UPDATE `gcontact` SET `last_failure` = '%s' WHERE `id` = %d",
46                                 DBA::escape(DateTimeFormat::utcNow()), intval($contact_id));
47                         return;
48                 }
49
50                 if (($data["name"] == "") && ($r[0]['name'] != "")) {
51                         $data["name"] = $r[0]['name'];
52                 }
53
54                 if (($data["nick"] == "") && ($r[0]['nick'] != "")) {
55                         $data["nick"] = $r[0]['nick'];
56                 }
57
58                 if (($data["addr"] == "") && ($r[0]['addr'] != "")) {
59                         $data["addr"] = $r[0]['addr'];
60                 }
61
62                 if (($data["photo"] == "") && ($r[0]['photo'] != "")) {
63                         $data["photo"] = $r[0]['photo'];
64                 }
65
66
67                 q("UPDATE `gcontact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
68                                         WHERE `id` = %d",
69                                         DBA::escape($data["name"]),
70                                         DBA::escape($data["nick"]),
71                                         DBA::escape($data["addr"]),
72                                         DBA::escape($data["photo"]),
73                         intval($contact_id)
74                 );
75
76                 q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
77                                         WHERE `uid` = 0 AND `addr` = '' AND `nurl` = '%s'",
78                                         DBA::escape($data["name"]),
79                                         DBA::escape($data["nick"]),
80                                         DBA::escape($data["addr"]),
81                                         DBA::escape($data["photo"]),
82                                         DBA::escape(Strings::normaliseLink($data["url"]))
83                 );
84
85                 q("UPDATE `contact` SET `addr` = '%s'
86                                         WHERE `uid` != 0 AND `addr` = '' AND `nurl` = '%s'",
87                                         DBA::escape($data["addr"]),
88                                         DBA::escape(Strings::normaliseLink($data["url"]))
89                 );
90         }
91 }