}
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;
$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"]));
+ }
}
}