]> git.mxchange.org Git - friendica.git/blob - include/update_gcontact.php
Class file relocations
[friendica.git] / include / update_gcontact.php
1 <?php
2
3 use Friendica\Core\Config;
4 use Friendica\Network\Probe;
5 use Friendica\Database\DBM;
6
7 function update_gcontact_run(&$argv, &$argc) {
8         global $a;
9
10         require_once 'include/socgraph.php';
11
12         logger('update_gcontact: start');
13
14         if (($argc > 1) && (intval($argv[1]))) {
15                 $contact_id = intval($argv[1]);
16         }
17
18         if (!$contact_id) {
19                 logger('update_gcontact: no contact');
20                 return;
21         }
22
23         $r = q("SELECT * FROM `gcontact` WHERE `id` = %d", intval($contact_id));
24
25         if (!DBM::is_result($r)) {
26                 return;
27         }
28
29         if (!in_array($r[0]["network"], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS))) {
30                 return;
31         }
32
33         $data = Probe::uri($r[0]["url"]);
34
35         if (!in_array($data["network"], array(NETWORK_DFRN, NETWORK_DIASPORA, NETWORK_OSTATUS))) {
36                 if ($r[0]["server_url"] != "")
37                         poco_check_server($r[0]["server_url"], $r[0]["network"]);
38
39                 q("UPDATE `gcontact` SET `last_failure` = '%s' WHERE `id` = %d",
40                         dbesc(datetime_convert()), intval($contact_id));
41                 return;
42         }
43
44         if (($data["name"] == "") && ($r[0]['name'] != ""))
45                 $data["name"] = $r[0]['name'];
46
47         if (($data["nick"] == "") && ($r[0]['nick'] != ""))
48                 $data["nick"] = $r[0]['nick'];
49
50         if (($data["addr"] == "") && ($r[0]['addr'] != ""))
51                 $data["addr"] = $r[0]['addr'];
52
53         if (($data["photo"] == "") && ($r[0]['photo'] != ""))
54                 $data["photo"] = $r[0]['photo'];
55
56
57         q("UPDATE `gcontact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
58                                 WHERE `id` = %d",
59                                 dbesc($data["name"]),
60                                 dbesc($data["nick"]),
61                                 dbesc($data["addr"]),
62                                 dbesc($data["photo"]),
63                                 intval($contact_id)
64                         );
65
66         q("UPDATE `contact` SET `name` = '%s', `nick` = '%s', `addr` = '%s', `photo` = '%s'
67                                 WHERE `uid` = 0 AND `addr` = '' AND `nurl` = '%s'",
68                                 dbesc($data["name"]),
69                                 dbesc($data["nick"]),
70                                 dbesc($data["addr"]),
71                                 dbesc($data["photo"]),
72                                 dbesc(normalise_link($data["url"]))
73                         );
74
75         q("UPDATE `contact` SET `addr` = '%s'
76                                 WHERE `uid` != 0 AND `addr` = '' AND `nurl` = '%s'",
77                                 dbesc($data["addr"]),
78                                 dbesc(normalise_link($data["url"]))
79                         );
80 }