X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=include%2FScrape.php;h=a26576a69ec5257182c839e846cd59ac1238c266;hb=0adff6f6b893bd7562547bb00021f358383f51ba;hp=68926a997ec1aa9dc8afd888ce3d5249030b4bdb;hpb=477614df267952bb8bbaf6b0b2ec44cc4fa074c1;p=friendica.git diff --git a/include/Scrape.php b/include/Scrape.php index 68926a997e..a26576a69e 100644 --- a/include/Scrape.php +++ b/include/Scrape.php @@ -596,7 +596,7 @@ function probe_url($url, $mode = PROBE_NORMAL, $level = 1) { if($diaspora && $diaspora_base && $diaspora_guid) { $diaspora_notify = $diaspora_base.'receive/users/'.$diaspora_guid; - if($mode == PROBE_DIASPORA || ! $notify || ($notify == $diaspora_notify)) { + if($mode == PROBE_DIASPORA || !$notify || ($notify == $diaspora_notify)) { $notify = $diaspora_notify; $batch = $diaspora_base . 'receive/public' ; } @@ -799,6 +799,9 @@ function probe_url($url, $mode = PROBE_NORMAL, $level = 1) { if (substr($baseurl, -10) == "/index.php") $baseurl = str_replace("/index.php", "", $baseurl); + if ($network == "") + $network = NETWORK_PHANTOM; + $baseurl = rtrim($baseurl, "/"); if(strpos($url,'@') AND ($addr == "") AND ($network == NETWORK_DFRN)) @@ -832,7 +835,7 @@ function probe_url($url, $mode = PROBE_NORMAL, $level = 1) { require_once('include/bbcode.php'); $address = GetProfileUsername($url, "", true); $result2 = probe_url($address, $mode, ++$level); - if ($result2['network'] != "") + if (!in_array($result2['network'], array("", NETWORK_PHANTOM, NETWORK_FEED))) $result = $result2; } @@ -840,8 +843,20 @@ function probe_url($url, $mode = PROBE_NORMAL, $level = 1) { if (($result['network'] == NETWORK_FEED) AND ($result['baseurl'] != "") AND ($result['nick'] != "")) { $addr = $result['nick'].'@'.str_replace("http://", "", $result['baseurl']); $result2 = probe_url($addr, $mode, ++$level); - if (($result2['network'] != "") AND ($result2['network'] != NETWORK_FEED)) + if (!in_array($result2['network'], array("", NETWORK_PHANTOM, NETWORK_FEED))) + $result = $result2; + } + + // Quickfix for Hubzilla systems with enabled OStatus plugin + if (($result['network'] == NETWORK_DIASPORA) AND ($result["batch"] == "")) { + $result2 = probe_url($url, PROBE_DIASPORA, ++$level); + if ($result2['network'] == NETWORK_DIASPORA) { + $addr = $result["addr"]; $result = $result2; + + if (($result["addr"] == "") AND ($addr != "")) + $result["addr"] = $addr; + } } }