);
if(count($r)) {
$network = $r[0]["network"];
- $profile_url = $r[0]["url"];
+ //$profile_url = $r[0]["url"];
}
}
}
if ((($network == "") OR ($name == "") OR ($profile_photo == "") OR ($server_url == "") OR $alternate)
- AND poco_reachable($profile_url, $server_url, $network, true)) {
+ AND poco_reachable($profile_url, $server_url, $network, false)) {
$data = probe_url($profile_url);
+ $orig_profile = $profile_url;
+
$network = $data["network"];
$name = $data["name"];
$nick = $data["nick"];
$profile_photo = $data["photo"];
$server_url = $data["baseurl"];
- if ($alternate AND ($network == NETWORK_OSTATUS))
+ if ($alternate AND ($network == NETWORK_OSTATUS)) {
+ // Delete the old entry - if it exists
+ $r = q("SELECT `id` FROM `gcontact` WHERE `nurl` = '%s'", dbesc(normalise_link($orig_profile)));
+ if ($r) {
+ q("DELETE FROM `gcontact` WHERE `nurl` = '%s'", dbesc(normalise_link($orig_profile)));
+ q("DELETE FROM `glink` WHERE `gcid` = %d", intval($r[0]["id"]));
+ }
+
+ // possibly create a new entry
poco_check($profile_url, $name, $network, $profile_photo, $about, $location, $gender, $keywords, $connect_url, $updated, $generation, $cid, $uid, $zcid);
+ }
}
if ($alternate AND ($network == NETWORK_OSTATUS))
$last_contact = "0000-00-00 00:00:00";
$last_failure = "0000-00-00 00:00:00";
}
- logger("Server ".$server_url." is unknown. Start discovery.", LOGGER_DEBUG);
+ logger("Server ".$server_url." is outdated or unknown. Start discovery. Force: ".$force." Created: ".$servers[0]["created"]." Failure: ".$last_failure." Contact: ".$last_contact, LOGGER_DEBUG);
$failure = false;
$orig_last_failure = $last_failure;
$done[] = $a->get_baseurl() . '/poco';
- if(strlen(get_config('system','directory_submit_url'))) {
+ if(strlen(get_config('system','directory'))) {
$x = fetch_url(get_server()."/pubsites");
if($x) {
$j = json_decode($x);
}
}
+function poco_discover_federation() {
+ $last = get_config('poco','last_federation_discovery');
+
+ if($last) {
+ $next = $last + (24 * 60 * 60);
+ if($next > time())
+ return;
+ }
+
+ $serverdata = fetch_url("http://the-federation.info/pods.json");
+
+ if (!$serverdata)
+ return;
+
+ $servers = json_decode($serverdata);
+
+ foreach($servers->pods AS $server)
+ poco_check_server("https://".$server->host);
+
+ set_config('poco','last_federation_discovery', time());
+
+}
+
function poco_discover($complete = false) {
+ // Update the server list
+ poco_discover_federation();
+
$no_of_queries = 5;
- $last_update = date("c", time() - (60 * 60 * 6)); // 24
- $last_update = date("c", time() - (60 * 60 * 24)); // 24
+ $requery_days = intval(get_config("system", "poco_requery_days"));
+
+ if ($requery_days == 0)
+ $requery_days = 7;
+
+ $last_update = date("c", time() - (60 * 60 * 24 * $requery_days));
$r = q("SELECT `poco`, `nurl`, `url`, `network` FROM `gserver` WHERE `last_contact` >= `last_failure` AND `poco` != '' AND `last_poco_query` < '%s' ORDER BY RAND()", dbesc($last_update));
if ($r)
foreach ($r AS $server) {
- if (!poco_check_server($server["url"], $server["network"]))
+ if (!poco_check_server($server["url"], $server["network"])) {
+ // The server is not reachable? Okay, then we will try it later
+ q("UPDATE `gserver` SET `last_poco_query` = '%s' WHERE `nurl` = '%s'", dbesc(datetime_convert()), dbesc($server["nurl"]));
continue;
+ }
// Fetch all users from the other server
$url = $server["poco"]."/?fields=displayName,urls,photos,updated,network,aboutMe,currentLocation,tags,gender,generation";
q("UPDATE `gserver` SET `last_poco_query` = '%s' WHERE `nurl` = '%s'", dbesc(datetime_convert()), dbesc($server["nurl"]));
if (!$complete AND (--$no_of_queries == 0))
break;
- } else // If the server hadn't replied correctly, then force a sanity check
+ } else {
+ // If the server hadn't replied correctly, then force a sanity check
poco_check_server($server["url"], $server["network"], true);
+
+ // If we couldn't reach the server, we will try it some time later
+ q("UPDATE `gserver` SET `last_poco_query` = '%s' WHERE `nurl` = '%s'", dbesc(datetime_convert()), dbesc($server["nurl"]));
+ }
}
}