Merge pull request #5878 from nupplaphil/curl_response_refactoring
Curl response refactoring
This commit is contained in:
commit
a066befba5
|
@ -316,9 +316,9 @@ function subscribe_to_hub($url, array $importer, array $contact, $hubmode = 'sub
|
||||||
DBA::update('contact', ['hub-verify' => $verify_token], ['id' => $contact['id']]);
|
DBA::update('contact', ['hub-verify' => $verify_token], ['id' => $contact['id']]);
|
||||||
}
|
}
|
||||||
|
|
||||||
Network::post($url, $params);
|
$postResult = Network::post($url, $params);
|
||||||
|
|
||||||
logger('subscribe_to_hub: returns: ' . Network::getCurl()->getCode(), LOGGER_DEBUG);
|
logger('subscribe_to_hub: returns: ' . $postResult->getReturnCode(), LOGGER_DEBUG);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
|
@ -2567,6 +2567,5 @@ function admin_page_features(App $a)
|
||||||
function admin_page_server_vital()
|
function admin_page_server_vital()
|
||||||
{
|
{
|
||||||
// Fetch the host-meta to check if this really is a vital server
|
// Fetch the host-meta to check if this really is a vital server
|
||||||
$serverret = Network::curl(System::baseUrl() . '/.well-known/host-meta');
|
return Network::curl(System::baseUrl() . '/.well-known/host-meta')->isSuccess();
|
||||||
return $serverret["success"];
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -221,7 +221,7 @@ function dfrn_confirm_post(App $a, $handsfree = null)
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
$res = Network::post($dfrn_confirm, $params, null, $redirects, 120);
|
$res = Network::post($dfrn_confirm, $params, null, $redirects, 120)->getBody();
|
||||||
|
|
||||||
logger(' Confirm: received data: ' . $res, LOGGER_DATA);
|
logger(' Confirm: received data: ' . $res, LOGGER_DATA);
|
||||||
|
|
||||||
|
|
|
@ -502,7 +502,7 @@ function dfrn_poll_content(App $a)
|
||||||
'dfrn_version' => DFRN_PROTOCOL_VERSION,
|
'dfrn_version' => DFRN_PROTOCOL_VERSION,
|
||||||
'challenge' => $challenge,
|
'challenge' => $challenge,
|
||||||
'sec' => $sec
|
'sec' => $sec
|
||||||
]);
|
])->getBody();
|
||||||
}
|
}
|
||||||
|
|
||||||
$profile = ((DBA::isResult($r) && $r[0]['nickname']) ? $r[0]['nickname'] : $nickname);
|
$profile = ((DBA::isResult($r) && $r[0]['nickname']) ? $r[0]['nickname'] : $nickname);
|
||||||
|
|
|
@ -32,8 +32,7 @@ function feedtest_content(App $a)
|
||||||
|
|
||||||
$contact = DBA::selectFirst('contact', [], ['id' => $contact_id]);
|
$contact = DBA::selectFirst('contact', [], ['id' => $contact_id]);
|
||||||
|
|
||||||
$ret = Network::curl($contact['poll']);
|
$xml = Network::fetchUrl($contact['poll']);
|
||||||
$xml = $ret['body'];
|
|
||||||
|
|
||||||
$dummy = null;
|
$dummy = null;
|
||||||
$import_result = Feed::import($xml, $importer, $contact, $dummy, true);
|
$import_result = Feed::import($xml, $importer, $contact, $dummy, true);
|
||||||
|
|
|
@ -59,9 +59,9 @@ function match_content(App $a)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strlen(Config::get('system', 'directory'))) {
|
if (strlen(Config::get('system', 'directory'))) {
|
||||||
$x = Network::post(get_server().'/msearch', $params);
|
$x = Network::post(get_server().'/msearch', $params)->getBody();
|
||||||
} else {
|
} else {
|
||||||
$x = Network::post(System::baseUrl() . '/msearch', $params);
|
$x = Network::post(System::baseUrl() . '/msearch', $params)->getBody();
|
||||||
}
|
}
|
||||||
|
|
||||||
$j = json_decode($x);
|
$j = json_decode($x);
|
||||||
|
|
|
@ -44,14 +44,14 @@ function ostatus_subscribe_content(App $a) {
|
||||||
$api = $contact["baseurl"]."/api/";
|
$api = $contact["baseurl"]."/api/";
|
||||||
|
|
||||||
// Fetching friends
|
// Fetching friends
|
||||||
$data = Network::curl($api."statuses/friends.json?screen_name=".$contact["nick"]);
|
$curlResult = Network::curl($api."statuses/friends.json?screen_name=".$contact["nick"]);
|
||||||
|
|
||||||
if (!$data["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
PConfig::delete($uid, "ostatus", "legacy_contact");
|
PConfig::delete($uid, "ostatus", "legacy_contact");
|
||||||
return $o.L10n::t("Couldn't fetch friends for contact.");
|
return $o.L10n::t("Couldn't fetch friends for contact.");
|
||||||
}
|
}
|
||||||
|
|
||||||
PConfig::set($uid, "ostatus", "legacy_friends", $data["body"]);
|
PConfig::set($uid, "ostatus", "legacy_friends", $curlResult->getBody());
|
||||||
}
|
}
|
||||||
|
|
||||||
$friends = json_decode(PConfig::get($uid, "ostatus", "legacy_friends"));
|
$friends = json_decode(PConfig::get($uid, "ostatus", "legacy_friends"));
|
||||||
|
@ -72,8 +72,8 @@ function ostatus_subscribe_content(App $a) {
|
||||||
|
|
||||||
$o .= "<p>".$counter."/".$total.": ".$url;
|
$o .= "<p>".$counter."/".$total.": ".$url;
|
||||||
|
|
||||||
$data = Probe::uri($url);
|
$curlResult = Probe::uri($url);
|
||||||
if ($data["network"] == Protocol::OSTATUS) {
|
if ($curlResult["network"] == Protocol::OSTATUS) {
|
||||||
$result = Contact::createFromProbe($uid, $url, true, Protocol::OSTATUS);
|
$result = Contact::createFromProbe($uid, $url, true, Protocol::OSTATUS);
|
||||||
if ($result["success"]) {
|
if ($result["success"]) {
|
||||||
$o .= " - ".L10n::t("success");
|
$o .= " - ".L10n::t("success");
|
||||||
|
|
|
@ -60,12 +60,12 @@ function parse_url_content(App $a)
|
||||||
// the URL with the corresponding BBCode media tag
|
// the URL with the corresponding BBCode media tag
|
||||||
$redirects = 0;
|
$redirects = 0;
|
||||||
// Fetch the header of the URL
|
// Fetch the header of the URL
|
||||||
$result = Network::curl($url, false, $redirects, ['novalidate' => true, 'nobody' => true]);
|
$curlResponse = Network::curl($url, false, $redirects, ['novalidate' => true, 'nobody' => true]);
|
||||||
|
|
||||||
if ($result['success']) {
|
if ($curlResponse->isSuccess()) {
|
||||||
// Convert the header fields into an array
|
// Convert the header fields into an array
|
||||||
$hdrs = [];
|
$hdrs = [];
|
||||||
$h = explode("\n", $result['header']);
|
$h = explode("\n", $curlResponse->getHeader());
|
||||||
foreach ($h as $l) {
|
foreach ($h as $l) {
|
||||||
$header = array_map('trim', explode(':', trim($l), 2));
|
$header = array_map('trim', explode(':', trim($l), 2));
|
||||||
if (count($header) == 2) {
|
if (count($header) == 2) {
|
||||||
|
|
|
@ -104,8 +104,9 @@ function pubsubhubbub_init(App $a) {
|
||||||
// we don't actually enforce the lease time because GNU
|
// we don't actually enforce the lease time because GNU
|
||||||
// Social/StatusNet doesn't honour it (yet)
|
// Social/StatusNet doesn't honour it (yet)
|
||||||
|
|
||||||
$body = Network::fetchUrl($hub_callback . "?" . $params);
|
$fetchResult = Network::fetchUrlFull($hub_callback . "?" . $params);
|
||||||
$ret = Network::getCurl()->getCode();
|
$body = $fetchResult->getBody();
|
||||||
|
$ret = $fetchResult->getReturnCode();
|
||||||
|
|
||||||
// give up if the HTTP return code wasn't a success (2xx)
|
// give up if the HTTP return code wasn't a success (2xx)
|
||||||
if ($ret < 200 || $ret > 299) {
|
if ($ret < 200 || $ret > 299) {
|
||||||
|
|
|
@ -344,9 +344,9 @@ class ACL extends BaseObject
|
||||||
$a = self::getApp();
|
$a = self::getApp();
|
||||||
$p = $a->pager['page'] != 1 ? '&p=' . $a->pager['page'] : '';
|
$p = $a->pager['page'] != 1 ? '&p=' . $a->pager['page'] : '';
|
||||||
|
|
||||||
$response = Network::curl(get_server() . '/lsearch?f=' . $p . '&search=' . urlencode($search));
|
$curlResult = Network::curl(get_server() . '/lsearch?f=' . $p . '&search=' . urlencode($search));
|
||||||
if ($response['success']) {
|
if ($curlResult->isSuccess()) {
|
||||||
$lsearch = json_decode($response['body'], true);
|
$lsearch = json_decode($curlResult->getBody(), true);
|
||||||
if (!empty($lsearch['results'])) {
|
if (!empty($lsearch['results'])) {
|
||||||
$return = $lsearch['results'];
|
$return = $lsearch['results'];
|
||||||
}
|
}
|
||||||
|
|
|
@ -345,20 +345,20 @@ class Install extends BaseObject
|
||||||
$help = "";
|
$help = "";
|
||||||
$error_msg = "";
|
$error_msg = "";
|
||||||
if (function_exists('curl_init')) {
|
if (function_exists('curl_init')) {
|
||||||
$test = Network::fetchUrlFull(System::baseUrl() . "/install/testrewrite");
|
$fetchResult = Network::fetchUrlFull(System::baseUrl() . "/install/testrewrite");
|
||||||
|
|
||||||
$url = normalise_link(System::baseUrl() . "/install/testrewrite");
|
$url = normalise_link(System::baseUrl() . "/install/testrewrite");
|
||||||
if ($test['body'] != "ok") {
|
if ($fetchResult->getBody() != "ok") {
|
||||||
$test = Network::fetchUrlFull($url);
|
$fetchResult = Network::fetchUrlFull($url);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($test['body'] != "ok") {
|
if ($fetchResult->getBody() != "ok") {
|
||||||
$status = false;
|
$status = false;
|
||||||
$help = L10n::t('Url rewrite in .htaccess is not working. Check your server configuration.');
|
$help = L10n::t('Url rewrite in .htaccess is not working. Check your server configuration.');
|
||||||
$error_msg = [];
|
$error_msg = [];
|
||||||
$error_msg['head'] = L10n::t('Error message from Curl when fetching');
|
$error_msg['head'] = L10n::t('Error message from Curl when fetching');
|
||||||
$error_msg['url'] = $test['redirect_url'];
|
$error_msg['url'] = $fetchResult->getRedirectUrl();
|
||||||
$error_msg['msg'] = defaults($test, 'error', '');
|
$error_msg['msg'] = $fetchResult->getError();
|
||||||
}
|
}
|
||||||
self::addCheck($checks, L10n::t('Url rewrite is working'), $status, true, $help, $error_msg);
|
self::addCheck($checks, L10n::t('Url rewrite is working'), $status, true, $help, $error_msg);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -33,12 +33,12 @@ class APContact extends BaseObject
|
||||||
|
|
||||||
$webfinger = 'https://' . $addr_parts[1] . '/.well-known/webfinger?resource=acct:' . urlencode($addr);
|
$webfinger = 'https://' . $addr_parts[1] . '/.well-known/webfinger?resource=acct:' . urlencode($addr);
|
||||||
|
|
||||||
$ret = Network::curl($webfinger, false, $redirects, ['accept_content' => 'application/jrd+json,application/json']);
|
$curlResult = Network::curl($webfinger, false, $redirects, ['accept_content' => 'application/jrd+json,application/json']);
|
||||||
if (!$ret['success'] || empty($ret['body'])) {
|
if (!$curlResult->isSuccess() || empty($curlResult->getBody())) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = json_decode($ret['body'], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (empty($data['links'])) {
|
if (empty($data['links'])) {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -957,12 +957,12 @@ class GContact
|
||||||
|
|
||||||
$url = $server."/main/statistics";
|
$url = $server."/main/statistics";
|
||||||
|
|
||||||
$result = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
if (!$result["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$statistics = json_decode($result["body"]);
|
$statistics = json_decode($curlResult->getBody());
|
||||||
|
|
||||||
if (!empty($statistics->config)) {
|
if (!empty($statistics->config)) {
|
||||||
if ($statistics->config->instance_with_ssl) {
|
if ($statistics->config->instance_with_ssl) {
|
||||||
|
|
|
@ -1056,7 +1056,7 @@ class Profile
|
||||||
if ($basepath != System::baseUrl() && !strstr($dest, '/magic') && !strstr($dest, '/rmagic')) {
|
if ($basepath != System::baseUrl() && !strstr($dest, '/magic') && !strstr($dest, '/rmagic')) {
|
||||||
$magic_path = $basepath . '/magic' . '?f=&owa=1&dest=' . $dest;
|
$magic_path = $basepath . '/magic' . '?f=&owa=1&dest=' . $dest;
|
||||||
$serverret = Network::curl($magic_path);
|
$serverret = Network::curl($magic_path);
|
||||||
if (!empty($serverret['success'])) {
|
if ($serverret->isSuccess()) {
|
||||||
goaway($magic_path);
|
goaway($magic_path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -82,10 +82,10 @@ class Magic extends BaseModule
|
||||||
);
|
);
|
||||||
|
|
||||||
// Try to get an authentication token from the other instance.
|
// Try to get an authentication token from the other instance.
|
||||||
$x = Network::curl($basepath . '/owa', false, $redirects, ['headers' => $headers]);
|
$curlResult = Network::curl($basepath . '/owa', false, $redirects, ['headers' => $headers]);
|
||||||
|
|
||||||
if ($x['success']) {
|
if ($curlResult->isSuccess()) {
|
||||||
$j = json_decode($x['body'], true);
|
$j = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if ($j['success']) {
|
if ($j['success']) {
|
||||||
$token = '';
|
$token = '';
|
||||||
|
|
|
@ -188,7 +188,8 @@ class Proxy extends BaseModule
|
||||||
// It shouldn't happen but it does - spaces in URL
|
// It shouldn't happen but it does - spaces in URL
|
||||||
$_REQUEST['url'] = str_replace(' ', '+', $_REQUEST['url']);
|
$_REQUEST['url'] = str_replace(' ', '+', $_REQUEST['url']);
|
||||||
$redirects = 0;
|
$redirects = 0;
|
||||||
$img_str = Network::fetchUrl($_REQUEST['url'], true, $redirects, 10);
|
$fetchResult = Network::fetchUrlFull($_REQUEST['url'], true, $redirects, 10);
|
||||||
|
$img_str = $fetchResult->getBody();
|
||||||
|
|
||||||
$tempfile = tempnam(get_temppath(), 'cache');
|
$tempfile = tempnam(get_temppath(), 'cache');
|
||||||
file_put_contents($tempfile, $img_str);
|
file_put_contents($tempfile, $img_str);
|
||||||
|
@ -196,7 +197,7 @@ class Proxy extends BaseModule
|
||||||
unlink($tempfile);
|
unlink($tempfile);
|
||||||
|
|
||||||
// If there is an error then return a blank image
|
// If there is an error then return a blank image
|
||||||
if ((substr(Network::getCurl()->getCode(), 0, 1) == '4') || (!$img_str)) {
|
if ((substr($fetchResult->getReturnCode(), 0, 1) == '4') || (!$img_str)) {
|
||||||
$img_str = file_get_contents('images/blank.png');
|
$img_str = file_get_contents('images/blank.png');
|
||||||
$mime = 'image/png';
|
$mime = 'image/png';
|
||||||
$cachefile = ''; // Clear the cachefile so that the dummy isn't stored
|
$cachefile = ''; // Clear the cachefile so that the dummy isn't stored
|
||||||
|
|
|
@ -1,92 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
namespace Friendica\Network;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A content class for Curl call results
|
|
||||||
*/
|
|
||||||
class Curl
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @var string the Code of the Curl call
|
|
||||||
*/
|
|
||||||
private $code;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var string the content type of the Curl call
|
|
||||||
*/
|
|
||||||
private $contentType;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @var string the headers of the Curl call
|
|
||||||
*/
|
|
||||||
private $headers;
|
|
||||||
|
|
||||||
public function __construct($code = '', $contentType = '', $headers = '')
|
|
||||||
{
|
|
||||||
$this->code = $code;
|
|
||||||
$this->contentType = $contentType;
|
|
||||||
$this->headers = $headers;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the Curl Code
|
|
||||||
*
|
|
||||||
* @param string $code The Curl Code
|
|
||||||
*/
|
|
||||||
public function setCode($code)
|
|
||||||
{
|
|
||||||
$this->code = $code;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the Curl Code
|
|
||||||
*
|
|
||||||
* @return string The Curl Code
|
|
||||||
*/
|
|
||||||
public function getCode()
|
|
||||||
{
|
|
||||||
return $this->code;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the Curl Content Type
|
|
||||||
*
|
|
||||||
* @param string $content_type The Curl Content Type
|
|
||||||
*/
|
|
||||||
public function setContentType($content_type)
|
|
||||||
{
|
|
||||||
$this->contentType = $content_type;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the Curl Content Type
|
|
||||||
*
|
|
||||||
* @return string the Curl Content Type
|
|
||||||
*/
|
|
||||||
public function getContentType()
|
|
||||||
{
|
|
||||||
return $this->contentType;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sets the Curl headers
|
|
||||||
*
|
|
||||||
* @param string $headers the Curl headers
|
|
||||||
*/
|
|
||||||
public function setHeaders($headers)
|
|
||||||
{
|
|
||||||
$this->headers = $headers;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the Curl headers
|
|
||||||
*
|
|
||||||
* @return string the Curl headers
|
|
||||||
*/
|
|
||||||
public function getHeaders()
|
|
||||||
{
|
|
||||||
return $this->headers;
|
|
||||||
}
|
|
||||||
}
|
|
296
src/Network/CurlResult.php
Normal file
296
src/Network/CurlResult.php
Normal file
|
@ -0,0 +1,296 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Friendica\Network;
|
||||||
|
|
||||||
|
|
||||||
|
use Friendica\Network\HTTPException\InternalServerErrorException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A content class for Curl call results
|
||||||
|
*/
|
||||||
|
class CurlResult
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @var int HTTP return code or 0 if timeout or failure
|
||||||
|
*/
|
||||||
|
private $returnCode;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string the content type of the Curl call
|
||||||
|
*/
|
||||||
|
private $contentType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string the HTTP headers of the Curl call
|
||||||
|
*/
|
||||||
|
private $header;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var boolean true (if HTTP 2xx result) or false
|
||||||
|
*/
|
||||||
|
private $isSuccess;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string the URL which was called
|
||||||
|
*/
|
||||||
|
private $url;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string in case of redirect, content was finally retrieved from this URL
|
||||||
|
*/
|
||||||
|
private $redirectUrl;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string fetched content
|
||||||
|
*/
|
||||||
|
private $body;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array some informations about the fetched data
|
||||||
|
*/
|
||||||
|
private $info;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var boolean true if the URL has a redirect
|
||||||
|
*/
|
||||||
|
private $isRedirectUrl;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var boolean true if the curl request timed out
|
||||||
|
*/
|
||||||
|
private $isTimeout;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var int the error number or 0 (zero) if no error
|
||||||
|
*/
|
||||||
|
private $errorNumber;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var string the error message or '' (the empty string) if no
|
||||||
|
*/
|
||||||
|
private $error;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an errored CURL response
|
||||||
|
*
|
||||||
|
* @param string $url optional URL
|
||||||
|
*
|
||||||
|
* @return CurlResult a CURL with error response
|
||||||
|
*/
|
||||||
|
public static function createErrorCurl($url = '')
|
||||||
|
{
|
||||||
|
return new CurlResult($url, '', ['http_code' => 0]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Curl constructor.
|
||||||
|
* @param string $url the URL which was called
|
||||||
|
* @param string $result the result of the curl execution
|
||||||
|
* @param array $info an additional info array
|
||||||
|
* @param int $errorNumber the error number or 0 (zero) if no error
|
||||||
|
* @param string $error the error message or '' (the empty string) if no
|
||||||
|
*
|
||||||
|
* @throws InternalServerErrorException when HTTP code of the CURL response is missing
|
||||||
|
*/
|
||||||
|
public function __construct($url, $result, $info, $errorNumber = 0, $error = '')
|
||||||
|
{
|
||||||
|
if (!array_key_exists('http_code', $info)) {
|
||||||
|
throw new InternalServerErrorException('CURL response doesn\'t contains a response HTTP code');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->returnCode = $info['http_code'];
|
||||||
|
$this->url = $url;
|
||||||
|
$this->info = $info;
|
||||||
|
$this->errorNumber = $errorNumber;
|
||||||
|
$this->error = $error;
|
||||||
|
|
||||||
|
logger($url . ': ' . $this->returnCode . " " . $result, LOGGER_DATA);
|
||||||
|
|
||||||
|
$this->parseBodyHeader($result);
|
||||||
|
$this->checkSuccess();
|
||||||
|
$this->checkRedirect();
|
||||||
|
$this->checkInfo();
|
||||||
|
}
|
||||||
|
|
||||||
|
private function parseBodyHeader($result)
|
||||||
|
{
|
||||||
|
// Pull out multiple headers, e.g. proxy and continuation headers
|
||||||
|
// allow for HTTP/2.x without fixing code
|
||||||
|
|
||||||
|
$header = '';
|
||||||
|
$base = $result;
|
||||||
|
while (preg_match('/^HTTP\/[1-2].+? [1-5][0-9][0-9]/', $base)) {
|
||||||
|
$chunk = substr($base, 0, strpos($base, "\r\n\r\n") + 4);
|
||||||
|
$header .= $chunk;
|
||||||
|
$base = substr($base, strlen($chunk));
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->body = substr($result, strlen($header));
|
||||||
|
$this->header = $header;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function checkSuccess()
|
||||||
|
{
|
||||||
|
$this->isSuccess = ($this->returnCode >= 200 && $this->returnCode <= 299) || $this->errorNumber == 0;
|
||||||
|
|
||||||
|
if (!$this->isSuccess) {
|
||||||
|
logger('error: ' . $this->url . ': ' . $this->returnCode . ' - ' . $this->error, LOGGER_INFO);
|
||||||
|
logger('debug: ' . print_r($this->info, true), LOGGER_DATA);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!$this->isSuccess && $this->errorNumber == CURLE_OPERATION_TIMEDOUT) {
|
||||||
|
$this->isTimeout = true;
|
||||||
|
} else {
|
||||||
|
$this->isTimeout = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function checkRedirect()
|
||||||
|
{
|
||||||
|
if (!array_key_exists('url', $this->info)) {
|
||||||
|
$this->redirectUrl = '';
|
||||||
|
} else {
|
||||||
|
$this->redirectUrl = $this->info['url'];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->returnCode == 301 || $this->returnCode == 302 || $this->returnCode == 303 || $this->returnCode== 307) {
|
||||||
|
$new_location_info = (!array_key_exists('redirect_url', $this->info) ? '' : @parse_url($this->info['redirect_url']));
|
||||||
|
$old_location_info = (!array_key_exists('url', $this->info) ? '' : @parse_url($this->info['url']));
|
||||||
|
|
||||||
|
$this->redirectUrl = $new_location_info;
|
||||||
|
|
||||||
|
if (empty($new_location_info['path']) && !empty($new_location_info['host'])) {
|
||||||
|
$this->redirectUrl = $new_location_info['scheme'] . '://' . $new_location_info['host'] . $old_location_info['path'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$matches = [];
|
||||||
|
|
||||||
|
if (preg_match('/(Location:|URI:)(.*?)\n/i', $this->header, $matches)) {
|
||||||
|
$this->redirectUrl = trim(array_pop($matches));
|
||||||
|
}
|
||||||
|
if (strpos($this->redirectUrl, '/') === 0) {
|
||||||
|
$this->redirectUrl = $old_location_info["scheme"] . "://" . $old_location_info["host"] . $this->redirectUrl;
|
||||||
|
}
|
||||||
|
$old_location_query = @parse_url($this->url, PHP_URL_QUERY);
|
||||||
|
|
||||||
|
if ($old_location_query != '') {
|
||||||
|
$this->redirectUrl .= '?' . $old_location_query;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->isRedirectUrl = filter_var($this->redirectUrl, FILTER_VALIDATE_URL);
|
||||||
|
} else {
|
||||||
|
$this->isRedirectUrl = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function checkInfo()
|
||||||
|
{
|
||||||
|
if (isset($this->info['content_type'])) {
|
||||||
|
$this->contentType = $this->info['content_type'];
|
||||||
|
} else {
|
||||||
|
$this->contentType = '';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the Curl Code
|
||||||
|
*
|
||||||
|
* @return string The Curl Code
|
||||||
|
*/
|
||||||
|
public function getReturnCode()
|
||||||
|
{
|
||||||
|
return $this->returnCode;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Curl Content Type
|
||||||
|
*
|
||||||
|
* @return string the Curl Content Type
|
||||||
|
*/
|
||||||
|
public function getContentType()
|
||||||
|
{
|
||||||
|
return $this->contentType;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the Curl headers
|
||||||
|
*
|
||||||
|
* @return string the Curl headers
|
||||||
|
*/
|
||||||
|
public function getHeader()
|
||||||
|
{
|
||||||
|
return $this->header;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function isSuccess()
|
||||||
|
{
|
||||||
|
return $this->isSuccess;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getUrl()
|
||||||
|
{
|
||||||
|
return $this->url;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getRedirectUrl()
|
||||||
|
{
|
||||||
|
return $this->redirectUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getBody()
|
||||||
|
{
|
||||||
|
return $this->body;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function getInfo()
|
||||||
|
{
|
||||||
|
return $this->info;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function isRedirectUrl()
|
||||||
|
{
|
||||||
|
return $this->isRedirectUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return int
|
||||||
|
*/
|
||||||
|
public function getErrorNumber()
|
||||||
|
{
|
||||||
|
return $this->errorNumber;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getError()
|
||||||
|
{
|
||||||
|
return $this->error;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function isTimeout()
|
||||||
|
{
|
||||||
|
return $this->isTimeout;
|
||||||
|
}
|
||||||
|
}
|
|
@ -112,20 +112,20 @@ class Probe
|
||||||
logger("Probing for ".$host, LOGGER_DEBUG);
|
logger("Probing for ".$host, LOGGER_DEBUG);
|
||||||
$xrd = null;
|
$xrd = null;
|
||||||
|
|
||||||
$ret = Network::curl($ssl_url, false, $redirects, ['timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml']);
|
$curlResult = Network::curl($ssl_url, false, $redirects, ['timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml']);
|
||||||
if ($ret['success']) {
|
if ($curlResult->isSuccess()) {
|
||||||
$xml = $ret['body'];
|
$xml = $curlResult->getBody();
|
||||||
$xrd = XML::parseString($xml, false);
|
$xrd = XML::parseString($xml, false);
|
||||||
$host_url = 'https://'.$host;
|
$host_url = 'https://'.$host;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!is_object($xrd)) {
|
if (!is_object($xrd)) {
|
||||||
$ret = Network::curl($url, false, $redirects, ['timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml']);
|
$curlResult = Network::curl($url, false, $redirects, ['timeout' => $xrd_timeout, 'accept_content' => 'application/xrd+xml']);
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
logger("Probing timeout for ".$url, LOGGER_DEBUG);
|
logger("Probing timeout for " . $url, LOGGER_DEBUG);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$xml = $ret['body'];
|
$xml = $curlResult->getBody();
|
||||||
$xrd = XML::parseString($xml, false);
|
$xrd = XML::parseString($xml, false);
|
||||||
$host_url = 'http://'.$host;
|
$host_url = 'http://'.$host;
|
||||||
}
|
}
|
||||||
|
@ -742,11 +742,11 @@ class Probe
|
||||||
$xrd_timeout = Config::get('system', 'xrd_timeout', 20);
|
$xrd_timeout = Config::get('system', 'xrd_timeout', 20);
|
||||||
$redirects = 0;
|
$redirects = 0;
|
||||||
|
|
||||||
$ret = Network::curl($url, false, $redirects, ['timeout' => $xrd_timeout, 'accept_content' => $type]);
|
$curlResult = Network::curl($url, false, $redirects, ['timeout' => $xrd_timeout, 'accept_content' => $type]);
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$data = $ret['body'];
|
$data = $curlResult->getBody();
|
||||||
|
|
||||||
$webfinger = json_decode($data, true);
|
$webfinger = json_decode($data, true);
|
||||||
if (is_array($webfinger)) {
|
if (is_array($webfinger)) {
|
||||||
|
@ -809,11 +809,11 @@ class Probe
|
||||||
*/
|
*/
|
||||||
private static function pollNoscrape($noscrape_url, $data)
|
private static function pollNoscrape($noscrape_url, $data)
|
||||||
{
|
{
|
||||||
$ret = Network::curl($noscrape_url);
|
$curlResult = Network::curl($noscrape_url);
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$content = $ret['body'];
|
$content = $curlResult->getBody();
|
||||||
if (!$content) {
|
if (!$content) {
|
||||||
logger("Empty body for ".$noscrape_url, LOGGER_DEBUG);
|
logger("Empty body for ".$noscrape_url, LOGGER_DEBUG);
|
||||||
return false;
|
return false;
|
||||||
|
@ -1054,11 +1054,11 @@ class Probe
|
||||||
*/
|
*/
|
||||||
private static function pollHcard($hcard_url, $data, $dfrn = false)
|
private static function pollHcard($hcard_url, $data, $dfrn = false)
|
||||||
{
|
{
|
||||||
$ret = Network::curl($hcard_url);
|
$curlResult = Network::curl($hcard_url);
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$content = $ret['body'];
|
$content = $curlResult->getBody();
|
||||||
if (!$content) {
|
if (!$content) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1301,11 +1301,11 @@ class Probe
|
||||||
$pubkey = substr($pubkey, 5);
|
$pubkey = substr($pubkey, 5);
|
||||||
}
|
}
|
||||||
} elseif (normalise_link($pubkey) == 'http://') {
|
} elseif (normalise_link($pubkey) == 'http://') {
|
||||||
$ret = Network::curl($pubkey);
|
$curlResult = Network::curl($pubkey);
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$pubkey = $ret['body'];
|
$pubkey = $curlResult['body'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$key = explode(".", $pubkey);
|
$key = explode(".", $pubkey);
|
||||||
|
@ -1333,11 +1333,11 @@ class Probe
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch all additional data from the feed
|
// Fetch all additional data from the feed
|
||||||
$ret = Network::curl($data["poll"]);
|
$curlResult = Network::curl($data["poll"]);
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if (!empty($curlResult["errno"]) && ($curlResult['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$feed = $ret['body'];
|
$feed = $curlResult['body'];
|
||||||
$dummy1 = null;
|
$dummy1 = null;
|
||||||
$dummy2 = null;
|
$dummy2 = null;
|
||||||
$dummy2 = null;
|
$dummy2 = null;
|
||||||
|
@ -1543,11 +1543,11 @@ class Probe
|
||||||
*/
|
*/
|
||||||
private static function feed($url, $probe = true)
|
private static function feed($url, $probe = true)
|
||||||
{
|
{
|
||||||
$ret = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$feed = $ret['body'];
|
$feed = $curlResult->getBody();
|
||||||
$dummy1 = $dummy2 = $dummy3 = null;
|
$dummy1 = $dummy2 = $dummy3 = null;
|
||||||
$feed_data = Feed::import($feed, $dummy1, $dummy2, $dummy3, true);
|
$feed_data = Feed::import($feed, $dummy1, $dummy2, $dummy3, true);
|
||||||
|
|
||||||
|
|
|
@ -720,17 +720,18 @@ class Image
|
||||||
*
|
*
|
||||||
* @param string $filename Image filename
|
* @param string $filename Image filename
|
||||||
* @param boolean $fromcurl Check Content-Type header from curl request
|
* @param boolean $fromcurl Check Content-Type header from curl request
|
||||||
|
* @param string $header passed headers to take into account
|
||||||
*
|
*
|
||||||
* @return object
|
* @return object
|
||||||
*/
|
*/
|
||||||
public static function guessType($filename, $fromcurl = false)
|
public static function guessType($filename, $fromcurl = false, $header = '')
|
||||||
{
|
{
|
||||||
logger('Image: guessType: '.$filename . ($fromcurl?' from curl headers':''), LOGGER_DEBUG);
|
logger('Image: guessType: '.$filename . ($fromcurl?' from curl headers':''), LOGGER_DEBUG);
|
||||||
$type = null;
|
$type = null;
|
||||||
if ($fromcurl) {
|
if ($fromcurl) {
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
$headers=[];
|
$headers=[];
|
||||||
$h = explode("\n", Network::getCurl()->getHeaders());
|
$h = explode("\n", $header);
|
||||||
foreach ($h as $l) {
|
foreach ($h as $l) {
|
||||||
$data = array_map("trim", explode(":", trim($l), 2));
|
$data = array_map("trim", explode(":", trim($l), 2));
|
||||||
if (count($data) > 1) {
|
if (count($data) > 1) {
|
||||||
|
|
|
@ -58,12 +58,12 @@ class ActivityPub
|
||||||
*/
|
*/
|
||||||
public static function fetchContent($url)
|
public static function fetchContent($url)
|
||||||
{
|
{
|
||||||
$ret = Network::curl($url, false, $redirects, ['accept_content' => 'application/activity+json, application/ld+json']);
|
$curlResult = Network::curl($url, false, $redirects, ['accept_content' => 'application/activity+json, application/ld+json']);
|
||||||
if (!$ret['success'] || empty($ret['body'])) {
|
if (!$curlResult->isSuccess() || empty($curlResult->getBody())) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return json_decode($ret['body'], true);
|
return json_decode($curlResult->getBody(), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1170,10 +1170,10 @@ class DFRN
|
||||||
|
|
||||||
// At first try the Diaspora transport layer
|
// At first try the Diaspora transport layer
|
||||||
if (!$dissolve && !$legacy_transport) {
|
if (!$dissolve && !$legacy_transport) {
|
||||||
$ret = self::transmit($owner, $contact, $atom);
|
$curlResult = self::transmit($owner, $contact, $atom);
|
||||||
if ($ret >= 200) {
|
if ($curlResult >= 200) {
|
||||||
logger('Delivery via Diaspora transport layer was successful with status ' . $ret);
|
logger('Delivery via Diaspora transport layer was successful with status ' . $curlResult);
|
||||||
return $ret;
|
return $curlResult;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1211,16 +1211,16 @@ class DFRN
|
||||||
|
|
||||||
logger('dfrn_deliver: ' . $url);
|
logger('dfrn_deliver: ' . $url);
|
||||||
|
|
||||||
$ret = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
|
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return -2; // timed out
|
return -2; // timed out
|
||||||
}
|
}
|
||||||
|
|
||||||
$xml = $ret['body'];
|
$xml = $curlResult->getBody();
|
||||||
|
|
||||||
$curl_stat = Network::getCurl()->getCode();
|
$curl_stat = $curlResult->getReturnCode();
|
||||||
if (empty($curl_stat)) {
|
if (empty($curl_stat)) {
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return -3; // timed out
|
return -3; // timed out
|
||||||
|
@ -1368,17 +1368,19 @@ class DFRN
|
||||||
|
|
||||||
logger('dfrn_deliver: ' . "SENDING: " . print_r($postvars, true), LOGGER_DATA);
|
logger('dfrn_deliver: ' . "SENDING: " . print_r($postvars, true), LOGGER_DATA);
|
||||||
|
|
||||||
$xml = Network::post($contact['notify'], $postvars);
|
$postResult = Network::post($contact['notify'], $postvars);
|
||||||
|
|
||||||
|
$xml = $postResult->getBody();
|
||||||
|
|
||||||
logger('dfrn_deliver: ' . "RECEIVED: " . $xml, LOGGER_DATA);
|
logger('dfrn_deliver: ' . "RECEIVED: " . $xml, LOGGER_DATA);
|
||||||
|
|
||||||
$curl_stat = Network::getCurl()->getCode();
|
$curl_stat = $postResult->getReturnCode();
|
||||||
if (empty($curl_stat) || empty($xml)) {
|
if (empty($curl_stat) || empty($xml)) {
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return -9; // timed out
|
return -9; // timed out
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($curl_stat == 503) && stristr(Network::getCurl()->getHeaders(), 'retry-after')) {
|
if (($curl_stat == 503) && stristr($postResult->getHeader(), 'retry-after')) {
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return -10;
|
return -10;
|
||||||
}
|
}
|
||||||
|
@ -1467,16 +1469,17 @@ class DFRN
|
||||||
|
|
||||||
$content_type = ($public_batch ? "application/magic-envelope+xml" : "application/json");
|
$content_type = ($public_batch ? "application/magic-envelope+xml" : "application/json");
|
||||||
|
|
||||||
$xml = Network::post($dest_url, $envelope, ["Content-Type: ".$content_type]);
|
$postResult = Network::post($dest_url, $envelope, ["Content-Type: ".$content_type]);
|
||||||
|
$xml = $postResult->getBody();
|
||||||
|
|
||||||
$curl_stat = Network::getCurl()->getCode();
|
$curl_stat = $postResult->getReturnCode();
|
||||||
if (empty($curl_stat) || empty($xml)) {
|
if (empty($curl_stat) || empty($xml)) {
|
||||||
logger('Empty answer from ' . $contact['id'] . ' - ' . $dest_url);
|
logger('Empty answer from ' . $contact['id'] . ' - ' . $dest_url);
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return -9; // timed out
|
return -9; // timed out
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($curl_stat == 503) && (stristr(Network::getCurl()->getHeaders(), 'retry-after'))) {
|
if (($curl_stat == 503) && (stristr($postResult->getHeader(), 'retry-after'))) {
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return -10;
|
return -10;
|
||||||
}
|
}
|
||||||
|
|
|
@ -3079,8 +3079,8 @@ class Diaspora
|
||||||
if (!intval(Config::get("system", "diaspora_test"))) {
|
if (!intval(Config::get("system", "diaspora_test"))) {
|
||||||
$content_type = (($public_batch) ? "application/magic-envelope+xml" : "application/json");
|
$content_type = (($public_batch) ? "application/magic-envelope+xml" : "application/json");
|
||||||
|
|
||||||
Network::post($dest_url."/", $envelope, ["Content-Type: ".$content_type]);
|
$postResult = Network::post($dest_url."/", $envelope, ["Content-Type: ".$content_type]);
|
||||||
$return_code = Network::getCurl()->getCode();
|
$return_code = $postResult->getReturnCode();
|
||||||
} else {
|
} else {
|
||||||
logger("test_mode");
|
logger("test_mode");
|
||||||
return 200;
|
return 200;
|
||||||
|
@ -3089,7 +3089,7 @@ class Diaspora
|
||||||
|
|
||||||
logger("transmit: ".$logid."-".$guid." to ".$dest_url." returns: ".$return_code);
|
logger("transmit: ".$logid."-".$guid." to ".$dest_url." returns: ".$return_code);
|
||||||
|
|
||||||
if (!$return_code || (($return_code == 503) && (stristr(Network::getCurl()->getHeaders(), "retry-after")))) {
|
if (!$return_code || (($return_code == 503) && (stristr($postResult->getHeader(), "retry-after")))) {
|
||||||
if (!$no_queue && !empty($contact['contact-type']) && ($contact['contact-type'] != Contact::ACCOUNT_TYPE_RELAY)) {
|
if (!$no_queue && !empty($contact['contact-type']) && ($contact['contact-type'] != Contact::ACCOUNT_TYPE_RELAY)) {
|
||||||
logger("queue message");
|
logger("queue message");
|
||||||
// queue message for redelivery
|
// queue message for redelivery
|
||||||
|
|
|
@ -736,21 +736,21 @@ class OStatus
|
||||||
|
|
||||||
self::$conv_list[$conversation] = true;
|
self::$conv_list[$conversation] = true;
|
||||||
|
|
||||||
$conversation_data = Network::curl($conversation, false, $redirects, ['accept_content' => 'application/atom+xml, text/html']);
|
$curlResult = Network::curl($conversation, false, $redirects, ['accept_content' => 'application/atom+xml, text/html']);
|
||||||
|
|
||||||
if (!$conversation_data['success']) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$xml = '';
|
$xml = '';
|
||||||
|
|
||||||
if (stristr($conversation_data['header'], 'Content-Type: application/atom+xml')) {
|
if (stristr($curlResult->getHeader(), 'Content-Type: application/atom+xml')) {
|
||||||
$xml = $conversation_data['body'];
|
$xml = $curlResult->getBody();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($xml == '') {
|
if ($xml == '') {
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
if (!@$doc->loadHTML($conversation_data['body'])) {
|
if (!@$doc->loadHTML($curlResult->getBody())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$xpath = new DOMXPath($doc);
|
$xpath = new DOMXPath($doc);
|
||||||
|
@ -767,8 +767,8 @@ class OStatus
|
||||||
if ($file != '') {
|
if ($file != '') {
|
||||||
$conversation_atom = Network::curl($attribute['href']);
|
$conversation_atom = Network::curl($attribute['href']);
|
||||||
|
|
||||||
if ($conversation_atom['success']) {
|
if ($conversation_atom->isSuccess()) {
|
||||||
$xml = $conversation_atom['body'];
|
$xml = $conversation_atom->getBody();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -880,15 +880,15 @@ class OStatus
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$self_data = Network::curl($self);
|
$curlResult = Network::curl($self);
|
||||||
|
|
||||||
if (!$self_data['success']) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// We reformat the XML to make it better readable
|
// We reformat the XML to make it better readable
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
$doc->loadXML($self_data['body']);
|
$doc->loadXML($curlResult->getBody());
|
||||||
$doc->preserveWhiteSpace = false;
|
$doc->preserveWhiteSpace = false;
|
||||||
$doc->formatOutput = true;
|
$doc->formatOutput = true;
|
||||||
$xml = $doc->saveXML();
|
$xml = $doc->saveXML();
|
||||||
|
@ -925,22 +925,22 @@ class OStatus
|
||||||
}
|
}
|
||||||
|
|
||||||
$stored = false;
|
$stored = false;
|
||||||
$related_data = Network::curl($related, false, $redirects, ['accept_content' => 'application/atom+xml, text/html']);
|
$curlResult = Network::curl($related, false, $redirects, ['accept_content' => 'application/atom+xml, text/html']);
|
||||||
|
|
||||||
if (!$related_data['success']) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$xml = '';
|
$xml = '';
|
||||||
|
|
||||||
if (stristr($related_data['header'], 'Content-Type: application/atom+xml')) {
|
if (stristr($curlResult->getHeader(), 'Content-Type: application/atom+xml')) {
|
||||||
logger('Directly fetched XML for URI '.$related_uri, LOGGER_DEBUG);
|
logger('Directly fetched XML for URI ' . $related_uri, LOGGER_DEBUG);
|
||||||
$xml = $related_data['body'];
|
$xml = $curlResult->getBody();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($xml == '') {
|
if ($xml == '') {
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
if (!@$doc->loadHTML($related_data['body'])) {
|
if (!@$doc->loadHTML($curlResult->getBody())) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
$xpath = new DOMXPath($doc);
|
$xpath = new DOMXPath($doc);
|
||||||
|
@ -956,11 +956,11 @@ class OStatus
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if ($atom_file != '') {
|
if ($atom_file != '') {
|
||||||
$related_atom = Network::curl($atom_file);
|
$curlResult = Network::curl($atom_file);
|
||||||
|
|
||||||
if ($related_atom['success']) {
|
if ($curlResult->isSuccess()) {
|
||||||
logger('Fetched XML for URI '.$related_uri, LOGGER_DEBUG);
|
logger('Fetched XML for URI ' . $related_uri, LOGGER_DEBUG);
|
||||||
$xml = $related_atom['body'];
|
$xml = $curlResult->getBody();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -968,22 +968,22 @@ class OStatus
|
||||||
|
|
||||||
// Workaround for older GNU Social servers
|
// Workaround for older GNU Social servers
|
||||||
if (($xml == '') && strstr($related, '/notice/')) {
|
if (($xml == '') && strstr($related, '/notice/')) {
|
||||||
$related_atom = Network::curl(str_replace('/notice/', '/api/statuses/show/', $related).'.atom');
|
$curlResult = Network::curl(str_replace('/notice/', '/api/statuses/show/', $related).'.atom');
|
||||||
|
|
||||||
if ($related_atom['success']) {
|
if ($curlResult->isSuccess()) {
|
||||||
logger('GNU Social workaround to fetch XML for URI '.$related_uri, LOGGER_DEBUG);
|
logger('GNU Social workaround to fetch XML for URI ' . $related_uri, LOGGER_DEBUG);
|
||||||
$xml = $related_atom['body'];
|
$xml = $curlResult->getBody();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Even more worse workaround for GNU Social ;-)
|
// Even more worse workaround for GNU Social ;-)
|
||||||
if ($xml == '') {
|
if ($xml == '') {
|
||||||
$related_guess = OStatus::convertHref($related_uri);
|
$related_guess = OStatus::convertHref($related_uri);
|
||||||
$related_atom = Network::curl(str_replace('/notice/', '/api/statuses/show/', $related_guess).'.atom');
|
$curlResult = Network::curl(str_replace('/notice/', '/api/statuses/show/', $related_guess).'.atom');
|
||||||
|
|
||||||
if ($related_atom['success']) {
|
if ($curlResult->isSuccess()) {
|
||||||
logger('GNU Social workaround 2 to fetch XML for URI '.$related_uri, LOGGER_DEBUG);
|
logger('GNU Social workaround 2 to fetch XML for URI ' . $related_uri, LOGGER_DEBUG);
|
||||||
$xml = $related_atom['body'];
|
$xml = $curlResult->getBody();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -86,13 +86,14 @@ class PortableContact
|
||||||
|
|
||||||
logger('load: ' . $url, LOGGER_DEBUG);
|
logger('load: ' . $url, LOGGER_DEBUG);
|
||||||
|
|
||||||
$s = Network::fetchUrl($url);
|
$fetchresult = Network::fetchUrlFull($url);
|
||||||
|
$s = $fetchresult->getBody();
|
||||||
|
|
||||||
logger('load: returns ' . $s, LOGGER_DATA);
|
logger('load: returns ' . $s, LOGGER_DATA);
|
||||||
|
|
||||||
logger('load: return code: ' . Network::getCurl()->getCode(), LOGGER_DEBUG);
|
logger('load: return code: ' . $fetchresult->getReturnCode(), LOGGER_DEBUG);
|
||||||
|
|
||||||
if ((Network::getCurl()->getCode() > 299) || (! $s)) {
|
if (($fetchresult->getReturnCode() > 299) || (! $s)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -290,8 +291,8 @@ class PortableContact
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch the host-meta to check if this really is a server
|
// Fetch the host-meta to check if this really is a server
|
||||||
$serverret = Network::curl($server_url."/.well-known/host-meta");
|
$curlResult = Network::curl($server_url."/.well-known/host-meta");
|
||||||
if (!$serverret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -370,10 +371,10 @@ class PortableContact
|
||||||
$server = q("SELECT `noscrape`, `network` FROM `gserver` WHERE `nurl` = '%s' AND `noscrape` != ''", DBA::escape(normalise_link($server_url)));
|
$server = q("SELECT `noscrape`, `network` FROM `gserver` WHERE `nurl` = '%s' AND `noscrape` != ''", DBA::escape(normalise_link($server_url)));
|
||||||
|
|
||||||
if ($server) {
|
if ($server) {
|
||||||
$noscraperet = Network::curl($server[0]["noscrape"]."/".$gcontacts[0]["nick"]);
|
$curlResult = Network::curl($server[0]["noscrape"]."/".$gcontacts[0]["nick"]);
|
||||||
|
|
||||||
if ($noscraperet["success"] && ($noscraperet["body"] != "")) {
|
if ($curlResult->isSuccess() && ($curlResult->getBody() != "")) {
|
||||||
$noscrape = json_decode($noscraperet["body"], true);
|
$noscrape = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (is_array($noscrape)) {
|
if (is_array($noscrape)) {
|
||||||
$contact["network"] = $server[0]["network"];
|
$contact["network"] = $server[0]["network"];
|
||||||
|
@ -484,9 +485,9 @@ class PortableContact
|
||||||
|
|
||||||
GContact::update($contact);
|
GContact::update($contact);
|
||||||
|
|
||||||
$feedret = Network::curl($data["poll"]);
|
$curlResult = Network::curl($data["poll"]);
|
||||||
|
|
||||||
if (!$feedret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
$fields = ['last_failure' => DateTimeFormat::utcNow()];
|
$fields = ['last_failure' => DateTimeFormat::utcNow()];
|
||||||
DBA::update('gcontact', $fields, ['nurl' => normalise_link($profile)]);
|
DBA::update('gcontact', $fields, ['nurl' => normalise_link($profile)]);
|
||||||
|
|
||||||
|
@ -496,7 +497,7 @@ class PortableContact
|
||||||
|
|
||||||
$doc = new DOMDocument();
|
$doc = new DOMDocument();
|
||||||
/// @TODO Avoid error supression here
|
/// @TODO Avoid error supression here
|
||||||
@$doc->loadXML($feedret["body"]);
|
@$doc->loadXML($curlResult->getBody());
|
||||||
|
|
||||||
$xpath = new DOMXPath($doc);
|
$xpath = new DOMXPath($doc);
|
||||||
$xpath->registerNamespace('atom', "http://www.w3.org/2005/Atom");
|
$xpath->registerNamespace('atom', "http://www.w3.org/2005/Atom");
|
||||||
|
@ -645,12 +646,12 @@ class PortableContact
|
||||||
*/
|
*/
|
||||||
private static function fetchNodeinfo($server_url)
|
private static function fetchNodeinfo($server_url)
|
||||||
{
|
{
|
||||||
$serverret = Network::curl($server_url."/.well-known/nodeinfo");
|
$curlResult = Network::curl($server_url."/.well-known/nodeinfo");
|
||||||
if (!$serverret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$nodeinfo = json_decode($serverret['body'], true);
|
$nodeinfo = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!is_array($nodeinfo) || !isset($nodeinfo['links'])) {
|
if (!is_array($nodeinfo) || !isset($nodeinfo['links'])) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -698,13 +699,13 @@ class PortableContact
|
||||||
*/
|
*/
|
||||||
private static function parseNodeinfo1($nodeinfo_url)
|
private static function parseNodeinfo1($nodeinfo_url)
|
||||||
{
|
{
|
||||||
$serverret = Network::curl($nodeinfo_url);
|
$curlResult = Network::curl($nodeinfo_url);
|
||||||
|
|
||||||
if (!$serverret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$nodeinfo = json_decode($serverret['body'], true);
|
$nodeinfo = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!is_array($nodeinfo)) {
|
if (!is_array($nodeinfo)) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -782,12 +783,12 @@ class PortableContact
|
||||||
*/
|
*/
|
||||||
private static function parseNodeinfo2($nodeinfo_url)
|
private static function parseNodeinfo2($nodeinfo_url)
|
||||||
{
|
{
|
||||||
$serverret = Network::curl($nodeinfo_url);
|
$curlResult = Network::curl($nodeinfo_url);
|
||||||
if (!$serverret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$nodeinfo = json_decode($serverret['body'], true);
|
$nodeinfo = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!is_array($nodeinfo)) {
|
if (!is_array($nodeinfo)) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -997,38 +998,38 @@ class PortableContact
|
||||||
$server_url = str_replace("http://", "https://", $server_url);
|
$server_url = str_replace("http://", "https://", $server_url);
|
||||||
|
|
||||||
// We set the timeout to 20 seconds since this operation should be done in no time if the server was vital
|
// We set the timeout to 20 seconds since this operation should be done in no time if the server was vital
|
||||||
$serverret = Network::curl($server_url."/.well-known/host-meta", false, $redirects, ['timeout' => 20]);
|
$curlResult = Network::curl($server_url."/.well-known/host-meta", false, $redirects, ['timeout' => 20]);
|
||||||
|
|
||||||
// Quit if there is a timeout.
|
// Quit if there is a timeout.
|
||||||
// But we want to make sure to only quit if we are mostly sure that this server url fits.
|
// But we want to make sure to only quit if we are mostly sure that this server url fits.
|
||||||
if (DBA::isResult($gserver) && ($orig_server_url == $server_url) &&
|
if (DBA::isResult($gserver) && ($orig_server_url == $server_url) &&
|
||||||
(!empty($serverret["errno"]) && ($serverret['errno'] == CURLE_OPERATION_TIMEDOUT))) {
|
($curlResult->isTimeout())) {
|
||||||
logger("Connection to server ".$server_url." timed out.", LOGGER_DEBUG);
|
logger("Connection to server ".$server_url." timed out.", LOGGER_DEBUG);
|
||||||
DBA::update('gserver', ['last_failure' => DateTimeFormat::utcNow()], ['nurl' => normalise_link($server_url)]);
|
DBA::update('gserver', ['last_failure' => DateTimeFormat::utcNow()], ['nurl' => normalise_link($server_url)]);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Maybe the page is unencrypted only?
|
// Maybe the page is unencrypted only?
|
||||||
$xmlobj = @simplexml_load_string($serverret["body"], 'SimpleXMLElement', 0, "http://docs.oasis-open.org/ns/xri/xrd-1.0");
|
$xmlobj = @simplexml_load_string($curlResult->getBody(), 'SimpleXMLElement', 0, "http://docs.oasis-open.org/ns/xri/xrd-1.0");
|
||||||
if (!$serverret["success"] || ($serverret["body"] == "") || empty($xmlobj) || !is_object($xmlobj)) {
|
if (!$curlResult->isSuccess() || ($curlResult->getBody() == "") || empty($xmlobj) || !is_object($xmlobj)) {
|
||||||
$server_url = str_replace("https://", "http://", $server_url);
|
$server_url = str_replace("https://", "http://", $server_url);
|
||||||
|
|
||||||
// We set the timeout to 20 seconds since this operation should be done in no time if the server was vital
|
// We set the timeout to 20 seconds since this operation should be done in no time if the server was vital
|
||||||
$serverret = Network::curl($server_url."/.well-known/host-meta", false, $redirects, ['timeout' => 20]);
|
$curlResult = Network::curl($server_url."/.well-known/host-meta", false, $redirects, ['timeout' => 20]);
|
||||||
|
|
||||||
// Quit if there is a timeout
|
// Quit if there is a timeout
|
||||||
if (!empty($serverret["errno"]) && ($serverret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if ($curlResult->isTimeout()) {
|
||||||
logger("Connection to server ".$server_url." timed out.", LOGGER_DEBUG);
|
logger("Connection to server " . $server_url . " timed out.", LOGGER_DEBUG);
|
||||||
DBA::update('gserver', ['last_failure' => DateTimeFormat::utcNow()], ['nurl' => normalise_link($server_url)]);
|
DBA::update('gserver', ['last_failure' => DateTimeFormat::utcNow()], ['nurl' => normalise_link($server_url)]);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$xmlobj = @simplexml_load_string($serverret["body"], 'SimpleXMLElement', 0, "http://docs.oasis-open.org/ns/xri/xrd-1.0");
|
$xmlobj = @simplexml_load_string($curlResult->getBody(), 'SimpleXMLElement', 0, "http://docs.oasis-open.org/ns/xri/xrd-1.0");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$serverret["success"] || ($serverret["body"] == "") || empty($xmlobj) || !is_object($xmlobj)) {
|
if (!$curlResult->isSuccess() || ($curlResult->getBody() == "") || empty($xmlobj) || !is_object($xmlobj)) {
|
||||||
// Workaround for bad configured servers (known nginx problem)
|
// Workaround for bad configured servers (known nginx problem)
|
||||||
if (!empty($serverret["debug"]) && !in_array($serverret["debug"]["http_code"], ["403", "404"])) {
|
if (!empty($curlResult->getInfo()) && !in_array($curlResult->getInfo()["http_code"], ["403", "404"])) {
|
||||||
$failure = true;
|
$failure = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1051,10 +1052,10 @@ class PortableContact
|
||||||
|
|
||||||
// Look for poco
|
// Look for poco
|
||||||
if (!$failure) {
|
if (!$failure) {
|
||||||
$serverret = Network::curl($server_url."/poco");
|
$curlResult = Network::curl($server_url."/poco");
|
||||||
|
|
||||||
if ($serverret["success"]) {
|
if ($curlResult->isSuccess()) {
|
||||||
$data = json_decode($serverret["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (isset($data['totalResults'])) {
|
if (isset($data['totalResults'])) {
|
||||||
$registered_users = $data['totalResults'];
|
$registered_users = $data['totalResults'];
|
||||||
|
@ -1083,12 +1084,12 @@ class PortableContact
|
||||||
|
|
||||||
if (!$failure) {
|
if (!$failure) {
|
||||||
// Test for Diaspora, Hubzilla, Mastodon or older Friendica servers
|
// Test for Diaspora, Hubzilla, Mastodon or older Friendica servers
|
||||||
$serverret = Network::curl($server_url);
|
$curlResult = Network::curl($server_url);
|
||||||
|
|
||||||
if (!$serverret["success"] || ($serverret["body"] == "")) {
|
if (!$curlResult->isSuccess() || ($curlResult->getBody() == "")) {
|
||||||
$failure = true;
|
$failure = true;
|
||||||
} else {
|
} else {
|
||||||
$server = self::detectServerType($serverret["body"]);
|
$server = self::detectServerType($curlResult->getBody());
|
||||||
|
|
||||||
if (!empty($server)) {
|
if (!empty($server)) {
|
||||||
$platform = $server['platform'];
|
$platform = $server['platform'];
|
||||||
|
@ -1097,7 +1098,7 @@ class PortableContact
|
||||||
$site_name = $server['site_name'];
|
$site_name = $server['site_name'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$lines = explode("\n", $serverret["header"]);
|
$lines = explode("\n", $curlResult->getHeader());
|
||||||
|
|
||||||
if (count($lines)) {
|
if (count($lines)) {
|
||||||
foreach ($lines as $line) {
|
foreach ($lines as $line) {
|
||||||
|
@ -1125,35 +1126,35 @@ class PortableContact
|
||||||
// Test for Statusnet
|
// Test for Statusnet
|
||||||
// Will also return data for Friendica and GNU Social - but it will be overwritten later
|
// Will also return data for Friendica and GNU Social - but it will be overwritten later
|
||||||
// The "not implemented" is a special treatment for really, really old Friendica versions
|
// The "not implemented" is a special treatment for really, really old Friendica versions
|
||||||
$serverret = Network::curl($server_url."/api/statusnet/version.json");
|
$curlResult = Network::curl($server_url."/api/statusnet/version.json");
|
||||||
|
|
||||||
if ($serverret["success"] && ($serverret["body"] != '{"error":"not implemented"}') &&
|
if ($curlResult->isSuccess() && ($curlResult->getBody() != '{"error":"not implemented"}') &&
|
||||||
($serverret["body"] != '') && (strlen($serverret["body"]) < 30)) {
|
($curlResult->getBody() != '') && (strlen($curlResult->getBody()) < 30)) {
|
||||||
$platform = "StatusNet";
|
$platform = "StatusNet";
|
||||||
// Remove junk that some GNU Social servers return
|
// Remove junk that some GNU Social servers return
|
||||||
$version = str_replace(chr(239).chr(187).chr(191), "", $serverret["body"]);
|
$version = str_replace(chr(239).chr(187).chr(191), "", $curlResult->getBody());
|
||||||
$version = trim($version, '"');
|
$version = trim($version, '"');
|
||||||
$network = Protocol::OSTATUS;
|
$network = Protocol::OSTATUS;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test for GNU Social
|
// Test for GNU Social
|
||||||
$serverret = Network::curl($server_url."/api/gnusocial/version.json");
|
$curlResult = Network::curl($server_url."/api/gnusocial/version.json");
|
||||||
|
|
||||||
if ($serverret["success"] && ($serverret["body"] != '{"error":"not implemented"}') &&
|
if ($curlResult->isSuccess() && ($curlResult->getBody() != '{"error":"not implemented"}') &&
|
||||||
($serverret["body"] != '') && (strlen($serverret["body"]) < 30)) {
|
($curlResult->getBody() != '') && (strlen($curlResult->getBody()) < 30)) {
|
||||||
$platform = "GNU Social";
|
$platform = "GNU Social";
|
||||||
// Remove junk that some GNU Social servers return
|
// Remove junk that some GNU Social servers return
|
||||||
$version = str_replace(chr(239) . chr(187) . chr(191), "", $serverret["body"]);
|
$version = str_replace(chr(239) . chr(187) . chr(191), "", $curlResult->getBody());
|
||||||
$version = trim($version, '"');
|
$version = trim($version, '"');
|
||||||
$network = Protocol::OSTATUS;
|
$network = Protocol::OSTATUS;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test for Mastodon
|
// Test for Mastodon
|
||||||
$orig_version = $version;
|
$orig_version = $version;
|
||||||
$serverret = Network::curl($server_url . "/api/v1/instance");
|
$curlResult = Network::curl($server_url . "/api/v1/instance");
|
||||||
|
|
||||||
if ($serverret["success"] && ($serverret["body"] != '')) {
|
if ($curlResult->isSuccess() && ($curlResult->getBody() != '')) {
|
||||||
$data = json_decode($serverret["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (isset($data['version'])) {
|
if (isset($data['version'])) {
|
||||||
$platform = "Mastodon";
|
$platform = "Mastodon";
|
||||||
|
@ -1176,10 +1177,10 @@ class PortableContact
|
||||||
|
|
||||||
if (!$failure) {
|
if (!$failure) {
|
||||||
// Test for Hubzilla and Red
|
// Test for Hubzilla and Red
|
||||||
$serverret = Network::curl($server_url . "/siteinfo.json");
|
$curlResult = Network::curl($server_url . "/siteinfo.json");
|
||||||
|
|
||||||
if ($serverret["success"]) {
|
if ($curlResult->isSuccess()) {
|
||||||
$data = json_decode($serverret["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (isset($data['url'])) {
|
if (isset($data['url'])) {
|
||||||
$platform = $data['platform'];
|
$platform = $data['platform'];
|
||||||
|
@ -1213,10 +1214,10 @@ class PortableContact
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Test for Hubzilla, Redmatrix or Friendica
|
// Test for Hubzilla, Redmatrix or Friendica
|
||||||
$serverret = Network::curl($server_url."/api/statusnet/config.json");
|
$curlResult = Network::curl($server_url."/api/statusnet/config.json");
|
||||||
|
|
||||||
if ($serverret["success"]) {
|
if ($curlResult->isSuccess()) {
|
||||||
$data = json_decode($serverret["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (isset($data['site']['server'])) {
|
if (isset($data['site']['server'])) {
|
||||||
if (isset($data['site']['platform'])) {
|
if (isset($data['site']['platform'])) {
|
||||||
|
@ -1286,10 +1287,10 @@ class PortableContact
|
||||||
|
|
||||||
// Query statistics.json. Optional package for Diaspora, Friendica and Redmatrix
|
// Query statistics.json. Optional package for Diaspora, Friendica and Redmatrix
|
||||||
if (!$failure) {
|
if (!$failure) {
|
||||||
$serverret = Network::curl($server_url . "/statistics.json");
|
$curlResult = Network::curl($server_url . "/statistics.json");
|
||||||
|
|
||||||
if ($serverret["success"]) {
|
if ($curlResult->isSuccess()) {
|
||||||
$data = json_decode($serverret["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (isset($data['version'])) {
|
if (isset($data['version'])) {
|
||||||
$version = $data['version'];
|
$version = $data['version'];
|
||||||
|
@ -1350,14 +1351,14 @@ class PortableContact
|
||||||
// Check for noscrape
|
// Check for noscrape
|
||||||
// Friendica servers could be detected as OStatus servers
|
// Friendica servers could be detected as OStatus servers
|
||||||
if (!$failure && in_array($network, [Protocol::DFRN, Protocol::OSTATUS])) {
|
if (!$failure && in_array($network, [Protocol::DFRN, Protocol::OSTATUS])) {
|
||||||
$serverret = Network::curl($server_url . "/friendica/json");
|
$curlResult = Network::curl($server_url . "/friendica/json");
|
||||||
|
|
||||||
if (!$serverret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
$serverret = Network::curl($server_url . "/friendika/json");
|
$curlResult = Network::curl($server_url . "/friendika/json");
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($serverret["success"]) {
|
if ($curlResult->isSuccess()) {
|
||||||
$data = json_decode($serverret["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (isset($data['version'])) {
|
if (isset($data['version'])) {
|
||||||
$network = Protocol::DFRN;
|
$network = Protocol::DFRN;
|
||||||
|
@ -1442,13 +1443,13 @@ class PortableContact
|
||||||
{
|
{
|
||||||
logger("Discover relay data for server " . $server_url, LOGGER_DEBUG);
|
logger("Discover relay data for server " . $server_url, LOGGER_DEBUG);
|
||||||
|
|
||||||
$serverret = Network::curl($server_url . "/.well-known/x-social-relay");
|
$curlResult = Network::curl($server_url . "/.well-known/x-social-relay");
|
||||||
|
|
||||||
if (!$serverret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$data = json_decode($serverret['body'], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!is_array($data)) {
|
if (!is_array($data)) {
|
||||||
return;
|
return;
|
||||||
|
@ -1538,13 +1539,13 @@ class PortableContact
|
||||||
*/
|
*/
|
||||||
private static function fetchServerlist($poco)
|
private static function fetchServerlist($poco)
|
||||||
{
|
{
|
||||||
$serverret = Network::curl($poco . "/@server");
|
$curlResult = Network::curl($poco . "/@server");
|
||||||
|
|
||||||
if (!$serverret["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$serverlist = json_decode($serverret['body'], true);
|
$serverlist = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!is_array($serverlist)) {
|
if (!is_array($serverlist)) {
|
||||||
return;
|
return;
|
||||||
|
@ -1575,10 +1576,10 @@ class PortableContact
|
||||||
}
|
}
|
||||||
|
|
||||||
// Discover Friendica, Hubzilla and Diaspora servers
|
// Discover Friendica, Hubzilla and Diaspora servers
|
||||||
$serverdata = Network::fetchUrl("http://the-federation.info/pods.json");
|
$curlResult = Network::fetchUrl("http://the-federation.info/pods.json");
|
||||||
|
|
||||||
if (!empty($serverdata)) {
|
if (!empty($curlResult)) {
|
||||||
$servers = json_decode($serverdata, true);
|
$servers = json_decode($curlResult, true);
|
||||||
|
|
||||||
if (!empty($servers['pods'])) {
|
if (!empty($servers['pods'])) {
|
||||||
foreach ($servers['pods'] as $server) {
|
foreach ($servers['pods'] as $server) {
|
||||||
|
@ -1594,10 +1595,10 @@ class PortableContact
|
||||||
if (!empty($accesstoken)) {
|
if (!empty($accesstoken)) {
|
||||||
$api = 'https://instances.social/api/1.0/instances/list?count=0';
|
$api = 'https://instances.social/api/1.0/instances/list?count=0';
|
||||||
$header = ['Authorization: Bearer '.$accesstoken];
|
$header = ['Authorization: Bearer '.$accesstoken];
|
||||||
$serverdata = Network::curl($api, false, $redirects, ['headers' => $header]);
|
$curlResult = Network::curl($api, false, $redirects, ['headers' => $header]);
|
||||||
|
|
||||||
if ($serverdata['success']) {
|
if ($curlResult->isSuccess()) {
|
||||||
$servers = json_decode($serverdata['body'], true);
|
$servers = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
foreach ($servers['instances'] as $server) {
|
foreach ($servers['instances'] as $server) {
|
||||||
$url = (is_null($server['https_score']) ? 'http' : 'https') . '://' . $server['name'];
|
$url = (is_null($server['https_score']) ? 'http' : 'https') . '://' . $server['name'];
|
||||||
|
@ -1613,9 +1614,9 @@ class PortableContact
|
||||||
//if (!Config::get('system','ostatus_disabled')) {
|
//if (!Config::get('system','ostatus_disabled')) {
|
||||||
// $serverdata = "http://gstools.org/api/get_open_instances/";
|
// $serverdata = "http://gstools.org/api/get_open_instances/";
|
||||||
|
|
||||||
// $result = Network::curl($serverdata);
|
// $curlResult = Network::curl($serverdata);
|
||||||
// if ($result["success"]) {
|
// if ($curlResult->isSuccess()) {
|
||||||
// $servers = json_decode($result["body"], true);
|
// $servers = json_decode($result->getBody(), true);
|
||||||
|
|
||||||
// foreach($servers['data'] as $server)
|
// foreach($servers['data'] as $server)
|
||||||
// self::checkServer($server['instance_address']);
|
// self::checkServer($server['instance_address']);
|
||||||
|
@ -1643,10 +1644,10 @@ class PortableContact
|
||||||
|
|
||||||
logger("Fetch all users from the server " . $server["url"], LOGGER_DEBUG);
|
logger("Fetch all users from the server " . $server["url"], LOGGER_DEBUG);
|
||||||
|
|
||||||
$retdata = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
|
|
||||||
if ($retdata["success"] && !empty($retdata["body"])) {
|
if ($curlResult->isSuccess() && !empty($curlResult->getBody())) {
|
||||||
$data = json_decode($retdata["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!empty($data)) {
|
if (!empty($data)) {
|
||||||
self::discoverServer($data, 2);
|
self::discoverServer($data, 2);
|
||||||
|
@ -1666,11 +1667,11 @@ class PortableContact
|
||||||
|
|
||||||
$success = false;
|
$success = false;
|
||||||
|
|
||||||
$retdata = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
|
|
||||||
if ($retdata["success"] && !empty($retdata["body"])) {
|
if ($curlResult->isSuccess() && !empty($curlResult->getBody())) {
|
||||||
logger("Fetch all global contacts from the server " . $server["nurl"], LOGGER_DEBUG);
|
logger("Fetch all global contacts from the server " . $server["nurl"], LOGGER_DEBUG);
|
||||||
$data = json_decode($retdata["body"], true);
|
$data = json_decode($curlResult->getBody(), true);
|
||||||
|
|
||||||
if (!empty($data)) {
|
if (!empty($data)) {
|
||||||
$success = self::discoverServer($data);
|
$success = self::discoverServer($data);
|
||||||
|
@ -1766,10 +1767,10 @@ class PortableContact
|
||||||
// Fetch all contacts from a given user from the other server
|
// Fetch all contacts from a given user from the other server
|
||||||
$url = $server['poco'] . '/' . $username . '/?fields=displayName,urls,photos,updated,network,aboutMe,currentLocation,tags,gender,contactType,generation';
|
$url = $server['poco'] . '/' . $username . '/?fields=displayName,urls,photos,updated,network,aboutMe,currentLocation,tags,gender,contactType,generation';
|
||||||
|
|
||||||
$retdata = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
|
|
||||||
if (!empty($retdata['success'])) {
|
if ($curlResult->isSuccess()) {
|
||||||
$data = json_decode($retdata["body"], true);
|
$data = json_decode($curlResult["body"], true);
|
||||||
|
|
||||||
if (!empty($data)) {
|
if (!empty($data)) {
|
||||||
self::discoverServer($data, 3);
|
self::discoverServer($data, 3);
|
||||||
|
|
|
@ -133,13 +133,12 @@ class Salmon
|
||||||
$salmon = XML::fromArray($xmldata, $xml, false, $namespaces);
|
$salmon = XML::fromArray($xmldata, $xml, false, $namespaces);
|
||||||
|
|
||||||
// slap them
|
// slap them
|
||||||
Network::post($url, $salmon, [
|
$postResult = Network::post($url, $salmon, [
|
||||||
'Content-type: application/magic-envelope+xml',
|
'Content-type: application/magic-envelope+xml',
|
||||||
'Content-length: ' . strlen($salmon)
|
'Content-length: ' . strlen($salmon)
|
||||||
]);
|
]);
|
||||||
|
|
||||||
$a = get_app();
|
$return_code = $postResult->getReturnCode();
|
||||||
$return_code = Network::getCurl()->getCode();
|
|
||||||
|
|
||||||
// check for success, e.g. 2xx
|
// check for success, e.g. 2xx
|
||||||
|
|
||||||
|
@ -159,11 +158,11 @@ class Salmon
|
||||||
$salmon = XML::fromArray($xmldata, $xml, false, $namespaces);
|
$salmon = XML::fromArray($xmldata, $xml, false, $namespaces);
|
||||||
|
|
||||||
// slap them
|
// slap them
|
||||||
Network::post($url, $salmon, [
|
$postResult = Network::post($url, $salmon, [
|
||||||
'Content-type: application/magic-envelope+xml',
|
'Content-type: application/magic-envelope+xml',
|
||||||
'Content-length: ' . strlen($salmon)
|
'Content-length: ' . strlen($salmon)
|
||||||
]);
|
]);
|
||||||
$return_code = Network::getCurl()->getCode();
|
$return_code = $postResult->getReturnCode();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($return_code > 299) {
|
if ($return_code > 299) {
|
||||||
|
@ -182,10 +181,10 @@ class Salmon
|
||||||
$salmon = XML::fromArray($xmldata, $xml, false, $namespaces);
|
$salmon = XML::fromArray($xmldata, $xml, false, $namespaces);
|
||||||
|
|
||||||
// slap them
|
// slap them
|
||||||
Network::post($url, $salmon, [
|
$postResult = Network::post($url, $salmon, [
|
||||||
'Content-type: application/magic-envelope+xml',
|
'Content-type: application/magic-envelope+xml',
|
||||||
'Content-length: ' . strlen($salmon)]);
|
'Content-length: ' . strlen($salmon)]);
|
||||||
$return_code = Network::getCurl()->getCode();
|
$return_code = $postResult->getReturnCode();
|
||||||
}
|
}
|
||||||
|
|
||||||
logger('slapper for '.$url.' returned ' . $return_code);
|
logger('slapper for '.$url.' returned ' . $return_code);
|
||||||
|
@ -194,7 +193,7 @@ class Salmon
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (($return_code == 503) && (stristr(Network::getCurl()->getHeaders(), 'retry-after'))) {
|
if (($return_code == 503) && (stristr($postResult->getHeader(), 'retry-after'))) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -179,17 +179,17 @@ class ExAuth
|
||||||
|
|
||||||
$url = ($ssl ? 'https' : 'http') . '://' . $host . '/noscrape/' . $user;
|
$url = ($ssl ? 'https' : 'http') . '://' . $host . '/noscrape/' . $user;
|
||||||
|
|
||||||
$data = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
|
|
||||||
if (!is_array($data)) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($data['return_code'] != '200') {
|
if ($curlResult->getReturnCode() != 200) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$json = @json_decode($data['body']);
|
$json = @json_decode($curlResult->getBody());
|
||||||
if (!is_object($json)) {
|
if (!is_object($json)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -302,10 +302,9 @@ class HTTPSignature
|
||||||
|
|
||||||
$headers[] = 'Content-Type: application/activity+json';
|
$headers[] = 'Content-Type: application/activity+json';
|
||||||
|
|
||||||
Network::post($target, $content, $headers);
|
$postResult = Network::post($target, $content, $headers);
|
||||||
$return_code = Network::getCurl()->getCode();
|
|
||||||
|
|
||||||
logger('Transmit to ' . $target . ' returned ' . $return_code);
|
logger('Transmit to ' . $target . ' returned ' . $postResult->getReturnCode());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -7,31 +7,12 @@ namespace Friendica\Util;
|
||||||
use Friendica\Core\Addon;
|
use Friendica\Core\Addon;
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Core\Config;
|
use Friendica\Core\Config;
|
||||||
use Friendica\Network\Curl;
|
use Friendica\Network\CurlResult;
|
||||||
use DOMDocument;
|
use DOMDocument;
|
||||||
use DomXPath;
|
use DomXPath;
|
||||||
|
|
||||||
class Network
|
class Network
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @var Curl The latest Curl output
|
|
||||||
*/
|
|
||||||
private static $curl;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the latest Curl output
|
|
||||||
*
|
|
||||||
* @return Curl The latest Curl output
|
|
||||||
*/
|
|
||||||
public static function getCurl()
|
|
||||||
{
|
|
||||||
if (empty(self::$curl)) {
|
|
||||||
self::$curl = new Curl();
|
|
||||||
}
|
|
||||||
|
|
||||||
return self::$curl;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Curl wrapper
|
* Curl wrapper
|
||||||
*
|
*
|
||||||
|
@ -54,7 +35,7 @@ class Network
|
||||||
{
|
{
|
||||||
$ret = self::fetchUrlFull($url, $binary, $redirects, $timeout, $accept_content, $cookiejar);
|
$ret = self::fetchUrlFull($url, $binary, $redirects, $timeout, $accept_content, $cookiejar);
|
||||||
|
|
||||||
return $ret['body'];
|
return $ret->getBody();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -72,7 +53,7 @@ class Network
|
||||||
* @param string $accept_content supply Accept: header with 'accept_content' as the value
|
* @param string $accept_content supply Accept: header with 'accept_content' as the value
|
||||||
* @param string $cookiejar Path to cookie jar file
|
* @param string $cookiejar Path to cookie jar file
|
||||||
*
|
*
|
||||||
* @return array With all relevant information, 'body' contains the actual fetched content.
|
* @return CurlResult With all relevant information, 'body' contains the actual fetched content.
|
||||||
*/
|
*/
|
||||||
public static function fetchUrlFull($url, $binary = false, &$redirects = 0, $timeout = 0, $accept_content = null, $cookiejar = '')
|
public static function fetchUrlFull($url, $binary = false, &$redirects = 0, $timeout = 0, $accept_content = null, $cookiejar = '')
|
||||||
{
|
{
|
||||||
|
@ -102,12 +83,7 @@ class Network
|
||||||
* 'nobody' => only return the header
|
* 'nobody' => only return the header
|
||||||
* 'cookiejar' => path to cookie jar file
|
* 'cookiejar' => path to cookie jar file
|
||||||
*
|
*
|
||||||
* @return array an assoziative array with:
|
* @return CurlResult
|
||||||
* int 'return_code' => HTTP return code or 0 if timeout or failure
|
|
||||||
* boolean 'success' => boolean true (if HTTP 2xx result) or false
|
|
||||||
* string 'redirect_url' => in case of redirect, content was finally retrieved from this URL
|
|
||||||
* string 'header' => HTTP headers
|
|
||||||
* string 'body' => fetched content
|
|
||||||
*/
|
*/
|
||||||
public static function curl($url, $binary = false, &$redirects = 0, $opts = [])
|
public static function curl($url, $binary = false, &$redirects = 0, $opts = [])
|
||||||
{
|
{
|
||||||
|
@ -120,24 +96,24 @@ class Network
|
||||||
$parts = parse_url($url);
|
$parts = parse_url($url);
|
||||||
$path_parts = explode('/', defaults($parts, 'path', ''));
|
$path_parts = explode('/', defaults($parts, 'path', ''));
|
||||||
foreach ($path_parts as $part) {
|
foreach ($path_parts as $part) {
|
||||||
if (strlen($part) <> mb_strlen($part)) {
|
if (strlen($part) <> mb_strlen($part)) {
|
||||||
$parts2[] = rawurlencode($part);
|
$parts2[] = rawurlencode($part);
|
||||||
} else {
|
} else {
|
||||||
$parts2[] = $part;
|
$parts2[] = $part;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$parts['path'] = implode('/', $parts2);
|
$parts['path'] = implode('/', $parts2);
|
||||||
$url = self::unparseURL($parts);
|
$url = self::unparseURL($parts);
|
||||||
|
|
||||||
if (self::isUrlBlocked($url)) {
|
if (self::isUrlBlocked($url)) {
|
||||||
logger('domain of ' . $url . ' is blocked', LOGGER_DATA);
|
logger('domain of ' . $url . ' is blocked', LOGGER_DATA);
|
||||||
return $ret;
|
return CurlResult::createErrorCurl($url);
|
||||||
}
|
}
|
||||||
|
|
||||||
$ch = @curl_init($url);
|
$ch = @curl_init($url);
|
||||||
|
|
||||||
if (($redirects > 8) || (!$ch)) {
|
if (($redirects > 8) || (!$ch)) {
|
||||||
return $ret;
|
return CurlResult::createErrorCurl($url);
|
||||||
}
|
}
|
||||||
|
|
||||||
@curl_setopt($ch, CURLOPT_HEADER, true);
|
@curl_setopt($ch, CURLOPT_HEADER, true);
|
||||||
|
@ -232,91 +208,20 @@ class Network
|
||||||
$curl_info = @curl_getinfo($ch);
|
$curl_info = @curl_getinfo($ch);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (curl_errno($ch) !== CURLE_OK) {
|
$curlResponse = new CurlResult($url, $s, $curl_info, curl_errno($ch), curl_error($ch));
|
||||||
logger('error fetching ' . $url . ': ' . curl_error($ch), LOGGER_INFO);
|
|
||||||
}
|
|
||||||
|
|
||||||
$ret['errno'] = curl_errno($ch);
|
if ($curlResponse->isRedirectUrl()) {
|
||||||
|
$redirects++;
|
||||||
$base = $s;
|
logger('curl: redirect ' . $url . ' to ' . $curlResponse->getRedirectUrl());
|
||||||
$ret['info'] = $curl_info;
|
@curl_close($ch);
|
||||||
|
return self::curl($curlResponse->getRedirectUrl(), $binary, $redirects, $opts);
|
||||||
$http_code = $curl_info['http_code'];
|
|
||||||
|
|
||||||
logger($url . ': ' . $http_code . " " . $s, LOGGER_DATA);
|
|
||||||
$header = '';
|
|
||||||
|
|
||||||
// Pull out multiple headers, e.g. proxy and continuation headers
|
|
||||||
// allow for HTTP/2.x without fixing code
|
|
||||||
|
|
||||||
while (preg_match('/^HTTP\/[1-2].+? [1-5][0-9][0-9]/', $base)) {
|
|
||||||
$chunk = substr($base, 0, strpos($base, "\r\n\r\n") + 4);
|
|
||||||
$header .= $chunk;
|
|
||||||
$base = substr($base, strlen($chunk));
|
|
||||||
}
|
|
||||||
|
|
||||||
self::$curl = new Curl($http_code, (isset($curl_info['content_type']) ? $curl_info['content_type'] : ''), $header);
|
|
||||||
|
|
||||||
if ($http_code == 301 || $http_code == 302 || $http_code == 303 || $http_code == 307) {
|
|
||||||
$new_location_info = @parse_url($curl_info['redirect_url']);
|
|
||||||
$old_location_info = @parse_url($curl_info['url']);
|
|
||||||
|
|
||||||
$newurl = $curl_info['redirect_url'];
|
|
||||||
|
|
||||||
if (empty($new_location_info['path']) && !empty($new_location_info['host'])) {
|
|
||||||
$newurl = $new_location_info['scheme'] . '://' . $new_location_info['host'] . $old_location_info['path'];
|
|
||||||
}
|
|
||||||
|
|
||||||
$matches = [];
|
|
||||||
|
|
||||||
if (preg_match('/(Location:|URI:)(.*?)\n/i', $header, $matches)) {
|
|
||||||
$newurl = trim(array_pop($matches));
|
|
||||||
}
|
|
||||||
if (strpos($newurl, '/') === 0) {
|
|
||||||
$newurl = $old_location_info["scheme"]."://".$old_location_info["host"].$newurl;
|
|
||||||
}
|
|
||||||
$old_location_query = @parse_url($url, PHP_URL_QUERY);
|
|
||||||
|
|
||||||
if ($old_location_query != '') {
|
|
||||||
$newurl .= '?' . $old_location_query;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (filter_var($newurl, FILTER_VALIDATE_URL)) {
|
|
||||||
$redirects++;
|
|
||||||
@curl_close($ch);
|
|
||||||
return self::curl($newurl, $binary, $redirects, $opts);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
self::$curl->setCode($http_code);
|
|
||||||
if (isset($curl_info['content_type'])) {
|
|
||||||
self::$curl->setContentType($curl_info['content_type']);
|
|
||||||
}
|
|
||||||
|
|
||||||
$rc = intval($http_code);
|
|
||||||
$ret['return_code'] = $rc;
|
|
||||||
$ret['success'] = (($rc >= 200 && $rc <= 299) ? true : false);
|
|
||||||
$ret['redirect_url'] = $url;
|
|
||||||
|
|
||||||
if (!$ret['success']) {
|
|
||||||
$ret['error'] = curl_error($ch);
|
|
||||||
$ret['debug'] = $curl_info;
|
|
||||||
logger('error: '.$url.': '.$ret['return_code'].' - '.$ret['error'], LOGGER_DEBUG);
|
|
||||||
logger('debug: '.print_r($curl_info, true), LOGGER_DATA);
|
|
||||||
}
|
|
||||||
|
|
||||||
$ret['body'] = substr($s, strlen($header));
|
|
||||||
$ret['header'] = $header;
|
|
||||||
|
|
||||||
if (x($opts, 'debug')) {
|
|
||||||
$ret['debug'] = $curl_info;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@curl_close($ch);
|
@curl_close($ch);
|
||||||
|
|
||||||
$a->saveTimestamp($stamp1, 'network');
|
$a->saveTimestamp($stamp1, 'network');
|
||||||
|
|
||||||
return($ret);
|
return $curlResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -328,7 +233,7 @@ class Network
|
||||||
* @param integer $redirects Recursion counter for internal use - default = 0
|
* @param integer $redirects Recursion counter for internal use - default = 0
|
||||||
* @param integer $timeout The timeout in seconds, default system config value or 60 seconds
|
* @param integer $timeout The timeout in seconds, default system config value or 60 seconds
|
||||||
*
|
*
|
||||||
* @return string The content
|
* @return CurlResult The content
|
||||||
*/
|
*/
|
||||||
public static function post($url, $params, $headers = null, &$redirects = 0, $timeout = 0)
|
public static function post($url, $params, $headers = null, &$redirects = 0, $timeout = 0)
|
||||||
{
|
{
|
||||||
|
@ -336,14 +241,14 @@ class Network
|
||||||
|
|
||||||
if (self::isUrlBlocked($url)) {
|
if (self::isUrlBlocked($url)) {
|
||||||
logger('post_url: domain of ' . $url . ' is blocked', LOGGER_DATA);
|
logger('post_url: domain of ' . $url . ' is blocked', LOGGER_DATA);
|
||||||
return false;
|
return CurlResult::createErrorCurl($url);
|
||||||
}
|
}
|
||||||
|
|
||||||
$a = get_app();
|
$a = get_app();
|
||||||
$ch = curl_init($url);
|
$ch = curl_init($url);
|
||||||
|
|
||||||
if (($redirects > 8) || (!$ch)) {
|
if (($redirects > 8) || (!$ch)) {
|
||||||
return false;
|
return CurlResult::createErrorCurl($url);
|
||||||
}
|
}
|
||||||
|
|
||||||
logger('post_url: start ' . $url, LOGGER_DATA);
|
logger('post_url: start ' . $url, LOGGER_DATA);
|
||||||
|
@ -397,8 +302,6 @@ class Network
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
self::getCurl()->setCode(0);
|
|
||||||
|
|
||||||
// don't let curl abort the entire application
|
// don't let curl abort the entire application
|
||||||
// if it throws any errors.
|
// if it throws any errors.
|
||||||
|
|
||||||
|
@ -406,53 +309,23 @@ class Network
|
||||||
|
|
||||||
$base = $s;
|
$base = $s;
|
||||||
$curl_info = curl_getinfo($ch);
|
$curl_info = curl_getinfo($ch);
|
||||||
$http_code = $curl_info['http_code'];
|
|
||||||
|
|
||||||
logger('post_url: result ' . $http_code . ' - ' . $url, LOGGER_DATA);
|
$curlResponse = new CurlResult($url, $s, $curl_info, curl_errno($ch), curl_error($ch));
|
||||||
|
|
||||||
$header = '';
|
if ($curlResponse->isRedirectUrl()) {
|
||||||
|
$redirects++;
|
||||||
// Pull out multiple headers, e.g. proxy and continuation headers
|
logger('post_url: redirect ' . $url . ' to ' . $curlResponse->getRedirectUrl());
|
||||||
// allow for HTTP/2.x without fixing code
|
curl_close($ch);
|
||||||
|
return self::post($curlResponse->getRedirectUrl(), $params, $headers, $redirects, $timeout);
|
||||||
while (preg_match('/^HTTP\/[1-2].+? [1-5][0-9][0-9]/', $base)) {
|
|
||||||
$chunk = substr($base, 0, strpos($base, "\r\n\r\n") + 4);
|
|
||||||
$header .= $chunk;
|
|
||||||
$base = substr($base, strlen($chunk));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($http_code == 301 || $http_code == 302 || $http_code == 303 || $http_code == 307) {
|
|
||||||
$matches = [];
|
|
||||||
$new_location_info = @parse_url($curl_info['redirect_url']);
|
|
||||||
$old_location_info = @parse_url($curl_info['url']);
|
|
||||||
|
|
||||||
preg_match('/(Location:|URI:)(.*?)\n/', $header, $matches);
|
|
||||||
$newurl = trim(array_pop($matches));
|
|
||||||
|
|
||||||
if (strpos($newurl, '/') === 0) {
|
|
||||||
$newurl = $old_location_info["scheme"] . "://" . $old_location_info["host"] . $newurl;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (filter_var($newurl, FILTER_VALIDATE_URL)) {
|
|
||||||
$redirects++;
|
|
||||||
logger('post_url: redirect ' . $url . ' to ' . $newurl);
|
|
||||||
return self::post($newurl, $params, $headers, $redirects, $timeout);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
self::getCurl()->setCode($http_code);
|
|
||||||
|
|
||||||
$body = substr($s, strlen($header));
|
|
||||||
|
|
||||||
self::getCurl()->setHeaders($header);
|
|
||||||
|
|
||||||
curl_close($ch);
|
curl_close($ch);
|
||||||
|
|
||||||
$a->saveTimestamp($stamp1, 'network');
|
$a->saveTimestamp($stamp1, 'network');
|
||||||
|
|
||||||
logger('post_url: end ' . $url, LOGGER_DATA);
|
logger('post_url: end ' . $url, LOGGER_DATA);
|
||||||
|
|
||||||
return $body;
|
return $curlResponse;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -135,23 +135,23 @@ class ParseUrl
|
||||||
$siteinfo['url'] = $url;
|
$siteinfo['url'] = $url;
|
||||||
$siteinfo['type'] = 'link';
|
$siteinfo['type'] = 'link';
|
||||||
|
|
||||||
$data = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
if (!$data['success']) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return $siteinfo;
|
return $siteinfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the file is too large then exit
|
// If the file is too large then exit
|
||||||
if ($data['info']['download_content_length'] > 1000000) {
|
if ($curlResult->getInfo()['download_content_length'] > 1000000) {
|
||||||
return $siteinfo;
|
return $siteinfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
// If it isn't a HTML file then exit
|
// If it isn't a HTML file then exit
|
||||||
if (($data['info']['content_type'] != '') && !strstr(strtolower($data['info']['content_type']), 'html')) {
|
if (($curlResult->getContentType() != '') && !strstr(strtolower($curlResult->getContentType()), 'html')) {
|
||||||
return $siteinfo;
|
return $siteinfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
$header = $data['header'];
|
$header = $curlResult->getHeader();
|
||||||
$body = $data['body'];
|
$body = $curlResult->getBody();
|
||||||
|
|
||||||
if ($do_oembed) {
|
if ($do_oembed) {
|
||||||
$oembed_data = OEmbed::fetchURL($url);
|
$oembed_data = OEmbed::fetchURL($url);
|
||||||
|
|
|
@ -274,12 +274,12 @@ class DiscoverPoCo
|
||||||
|
|
||||||
$url = "http://gstools.org/api/users_search/".urlencode($search);
|
$url = "http://gstools.org/api/users_search/".urlencode($search);
|
||||||
|
|
||||||
$result = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
if (!$result["success"]) {
|
if (!$curlResult->isSuccess()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$contacts = json_decode($result["body"]);
|
$contacts = json_decode($curlResult->getBody());
|
||||||
|
|
||||||
if ($contacts->status == 'ERROR') {
|
if ($contacts->status == 'ERROR') {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -185,18 +185,17 @@ class OnePoll
|
||||||
. '&type=data&last_update=' . $last_update
|
. '&type=data&last_update=' . $last_update
|
||||||
. '&perm=' . $perm ;
|
. '&perm=' . $perm ;
|
||||||
|
|
||||||
$ret = Network::curl($url);
|
$curlResult = Network::curl($url);
|
||||||
|
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if (!$curlResult->isSuccess() && ($curlResult->getErrorNumber() == CURLE_OPERATION_TIMEDOUT)) {
|
||||||
// set the last-update so we don't keep polling
|
// set the last-update so we don't keep polling
|
||||||
DBA::update('contact', ['last-update' => DateTimeFormat::utcNow()], ['id' => $contact['id']]);
|
DBA::update('contact', ['last-update' => DateTimeFormat::utcNow()], ['id' => $contact['id']]);
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$handshake_xml = $ret['body'];
|
$handshake_xml = $curlResult->getBody();
|
||||||
|
$html_code = $curlResult->getReturnCode();
|
||||||
$html_code = Network::getCurl()->getCode();
|
|
||||||
|
|
||||||
logger('handshake with url ' . $url . ' returns xml: ' . $handshake_xml, LOGGER_DATA);
|
logger('handshake with url ' . $url . ' returns xml: ' . $handshake_xml, LOGGER_DATA);
|
||||||
|
|
||||||
|
@ -288,7 +287,7 @@ class OnePoll
|
||||||
$postvars['dfrn_version'] = DFRN_PROTOCOL_VERSION;
|
$postvars['dfrn_version'] = DFRN_PROTOCOL_VERSION;
|
||||||
$postvars['perm'] = 'rw';
|
$postvars['perm'] = 'rw';
|
||||||
|
|
||||||
$xml = Network::post($contact['poll'], $postvars);
|
$xml = Network::post($contact['poll'], $postvars)->getBody();
|
||||||
|
|
||||||
} elseif (($contact['network'] === Protocol::OSTATUS)
|
} elseif (($contact['network'] === Protocol::OSTATUS)
|
||||||
|| ($contact['network'] === Protocol::DIASPORA)
|
|| ($contact['network'] === Protocol::DIASPORA)
|
||||||
|
@ -319,17 +318,17 @@ class OnePoll
|
||||||
}
|
}
|
||||||
|
|
||||||
$cookiejar = tempnam(get_temppath(), 'cookiejar-onepoll-');
|
$cookiejar = tempnam(get_temppath(), 'cookiejar-onepoll-');
|
||||||
$ret = Network::curl($contact['poll'], false, $redirects, ['cookiejar' => $cookiejar]);
|
$curlResult = Network::curl($contact['poll'], false, $redirects, ['cookiejar' => $cookiejar]);
|
||||||
unlink($cookiejar);
|
unlink($cookiejar);
|
||||||
|
|
||||||
if (!empty($ret["errno"]) && ($ret['errno'] == CURLE_OPERATION_TIMEDOUT)) {
|
if (!$curlResult->isTimeout()) {
|
||||||
// set the last-update so we don't keep polling
|
// set the last-update so we don't keep polling
|
||||||
DBA::update('contact', ['last-update' => DateTimeFormat::utcNow()], ['id' => $contact['id']]);
|
DBA::update('contact', ['last-update' => DateTimeFormat::utcNow()], ['id' => $contact['id']]);
|
||||||
Contact::markForArchival($contact);
|
Contact::markForArchival($contact);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$xml = $ret['body'];
|
$xml = $curlResult->getBody();
|
||||||
|
|
||||||
} elseif ($contact['network'] === Protocol::MAIL) {
|
} elseif ($contact['network'] === Protocol::MAIL) {
|
||||||
logger("Mail: Fetching for ".$contact['addr'], LOGGER_DEBUG);
|
logger("Mail: Fetching for ".$contact['addr'], LOGGER_DEBUG);
|
||||||
|
|
|
@ -56,8 +56,8 @@ class PubSubPublish
|
||||||
|
|
||||||
logger('POST ' . print_r($headers, true) . "\n" . $params, LOGGER_DATA);
|
logger('POST ' . print_r($headers, true) . "\n" . $params, LOGGER_DATA);
|
||||||
|
|
||||||
Network::post($subscriber['callback_url'], $params, $headers);
|
$postResult = Network::post($subscriber['callback_url'], $params, $headers);
|
||||||
$ret = Network::getCurl()->getCode();
|
$ret = $postResult->getReturnCode();
|
||||||
|
|
||||||
$condition = ['id' => $subscriber['id']];
|
$condition = ['id' => $subscriber['id']];
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue