summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2016-05-13 16:10:24 +0200
committerVincent Petry <pvince81@owncloud.com>2016-05-13 16:10:24 +0200
commit3db709d568ed783876d06dc14ac2a9a4899ae700 (patch)
treeaa7e1c70f0213d0b94ff8b0a43e79ddb437c220f
parent6938904b07cba1f6120f1ebc9b3eaae2164c53c0 (diff)
parentea0f09a7edbc298d27199b640b8cf173694838dc (diff)
downloadnextcloud-server-3db709d568ed783876d06dc14ac2a9a4899ae700.tar.gz
nextcloud-server-3db709d568ed783876d06dc14ac2a9a4899ae700.zip
Merge pull request #24600 from owncloud/http-client-lazy-config
only configure the http client once we start using it
-rw-r--r--lib/private/Http/Client/Client.php29
1 files changed, 23 insertions, 6 deletions
diff --git a/lib/private/Http/Client/Client.php b/lib/private/Http/Client/Client.php
index bd9e82ddae7..3f49b224d1e 100644
--- a/lib/private/Http/Client/Client.php
+++ b/lib/private/Http/Client/Client.php
@@ -39,6 +39,7 @@ class Client implements IClient {
private $config;
/** @var ICertificateManager */
private $certificateManager;
+ private $configured = false;
/**
* @param IConfig $config
@@ -51,13 +52,16 @@ class Client implements IClient {
$this->config = $config;
$this->client = $client;
$this->certificateManager = $certificateManager;
- $this->setDefaultOptions();
}
/**
* Sets the default options to the client
*/
private function setDefaultOptions() {
+ if ($this->configured) {
+ return;
+ }
+ $this->configured = true;
// Either use user bundle or the system bundle if nothing is specified
if ($this->certificateManager->listCertificates() !== []) {
$this->client->setDefaultOption('verify', $this->certificateManager->getAbsoluteBundlePath());
@@ -65,7 +69,7 @@ class Client implements IClient {
// If the instance is not yet setup we need to use the static path as
// $this->certificateManager->getAbsoluteBundlePath() tries to instantiiate
// a view
- if($this->config->getSystemValue('installed', false)) {
+ if ($this->config->getSystemValue('installed', false)) {
$this->client->setDefaultOption('verify', $this->certificateManager->getAbsoluteBundlePath(null));
} else {
$this->client->setDefaultOption('verify', \OC::$SERVERROOT . '/resources/config/ca-bundle.crt');
@@ -73,13 +77,14 @@ class Client implements IClient {
}
$this->client->setDefaultOption('headers/User-Agent', 'ownCloud Server Crawler');
- if($this->getProxyUri() !== '') {
+ if ($this->getProxyUri() !== '') {
$this->client->setDefaultOption('proxy', $this->getProxyUri());
}
}
/**
* Get the proxy URI
+ *
* @return string
*/
private function getProxyUri() {
@@ -87,10 +92,10 @@ class Client implements IClient {
$proxyUserPwd = $this->config->getSystemValue('proxyuserpwd', null);
$proxyUri = '';
- if(!is_null($proxyUserPwd)) {
- $proxyUri .= $proxyUserPwd.'@';
+ if (!is_null($proxyUserPwd)) {
+ $proxyUri .= $proxyUserPwd . '@';
}
- if(!is_null($proxyHost)) {
+ if (!is_null($proxyHost)) {
$proxyUri .= $proxyHost;
}
@@ -99,6 +104,7 @@ class Client implements IClient {
/**
* Sends a GET request
+ *
* @param string $uri
* @param array $options Array such as
* 'query' => [
@@ -126,6 +132,7 @@ class Client implements IClient {
* @throws \Exception If the request could not get completed
*/
public function get($uri, array $options = []) {
+ $this->setDefaultOptions();
$response = $this->client->get($uri, $options);
$isStream = isset($options['stream']) && $options['stream'];
return new Response($response, $isStream);
@@ -133,6 +140,7 @@ class Client implements IClient {
/**
* Sends a HEAD request
+ *
* @param string $uri
* @param array $options Array such as
* 'headers' => [
@@ -155,12 +163,14 @@ class Client implements IClient {
* @throws \Exception If the request could not get completed
*/
public function head($uri, $options = []) {
+ $this->setDefaultOptions();
$response = $this->client->head($uri, $options);
return new Response($response);
}
/**
* Sends a POST request
+ *
* @param string $uri
* @param array $options Array such as
* 'body' => [
@@ -188,12 +198,14 @@ class Client implements IClient {
* @throws \Exception If the request could not get completed
*/
public function post($uri, array $options = []) {
+ $this->setDefaultOptions();
$response = $this->client->post($uri, $options);
return new Response($response);
}
/**
* Sends a PUT request
+ *
* @param string $uri
* @param array $options Array such as
* 'body' => [
@@ -221,12 +233,14 @@ class Client implements IClient {
* @throws \Exception If the request could not get completed
*/
public function put($uri, array $options = []) {
+ $this->setDefaultOptions();
$response = $this->client->put($uri, $options);
return new Response($response);
}
/**
* Sends a DELETE request
+ *
* @param string $uri
* @param array $options Array such as
* 'body' => [
@@ -254,6 +268,7 @@ class Client implements IClient {
* @throws \Exception If the request could not get completed
*/
public function delete($uri, array $options = []) {
+ $this->setDefaultOptions();
$response = $this->client->delete($uri, $options);
return new Response($response);
}
@@ -261,6 +276,7 @@ class Client implements IClient {
/**
* Sends a options request
+ *
* @param string $uri
* @param array $options Array such as
* 'body' => [
@@ -288,6 +304,7 @@ class Client implements IClient {
* @throws \Exception If the request could not get completed
*/
public function options($uri, array $options = []) {
+ $this->setDefaultOptions();
$response = $this->client->options($uri, $options);
return new Response($response);
}