mirror of
https://github.com/friendica/friendica
synced 2024-11-13 01:02:53 +00:00
Probing sometimes failed / problems with some web servers
This commit is contained in:
parent
6998897a34
commit
c09c806f78
2 changed files with 8 additions and 6 deletions
|
@ -107,6 +107,11 @@ function z_fetch_url($url, $binary = false, &$redirects = 0, $opts = array()) {
|
||||||
@curl_setopt($ch, CURLOPT_RANGE, '0-' . $range);
|
@curl_setopt($ch, CURLOPT_RANGE, '0-' . $range);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Without this setting it seems as if some webservers send compressed content
|
||||||
|
// This seems to confuse curl so that it shows this uncompressed.
|
||||||
|
/// @todo We could possibly set this value to "gzip" or something similar
|
||||||
|
curl_setopt($ch, CURLOPT_ENCODING, '');
|
||||||
|
|
||||||
if (x($opts, 'headers')) {
|
if (x($opts, 'headers')) {
|
||||||
@curl_setopt($ch, CURLOPT_HTTPHEADER, $opts['headers']);
|
@curl_setopt($ch, CURLOPT_HTTPHEADER, $opts['headers']);
|
||||||
}
|
}
|
||||||
|
|
|
@ -104,13 +104,10 @@ class Probe {
|
||||||
logger("Probing for ".$host, LOGGER_DEBUG);
|
logger("Probing for ".$host, LOGGER_DEBUG);
|
||||||
|
|
||||||
$ret = z_fetch_url($ssl_url, false, $redirects, array('timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml'));
|
$ret = z_fetch_url($ssl_url, false, $redirects, array('timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml'));
|
||||||
if (($ret['errno'] == CURLE_OPERATION_TIMEDOUT) && !self::ownHost($ssl_url)) {
|
if ($ret['success']) {
|
||||||
logger("Probing timeout for ".$ssl_url, LOGGER_DEBUG);
|
$xml = $ret['body'];
|
||||||
return false;
|
$xrd = parse_xml_string($xml, false);
|
||||||
}
|
}
|
||||||
$xml = $ret['body'];
|
|
||||||
|
|
||||||
$xrd = parse_xml_string($xml, false);
|
|
||||||
|
|
||||||
if (!is_object($xrd)) {
|
if (!is_object($xrd)) {
|
||||||
$ret = z_fetch_url($url, false, $redirects, array('timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml'));
|
$ret = z_fetch_url($url, false, $redirects, array('timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml'));
|
||||||
|
|
Loading…
Reference in a new issue