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