3 namespace Friendica\Factory;
6 use Friendica\BaseFactory;
7 use Friendica\Core\Config\IConfig;
8 use Friendica\Network\HTTPClient;
9 use Friendica\Network\IHTTPClient;
10 use Friendica\Util\Profiler;
11 use GuzzleHttp\Client;
12 use GuzzleHttp\RequestOptions;
13 use Psr\Http\Message\RequestInterface;
14 use Psr\Http\Message\ResponseInterface;
15 use Psr\Http\Message\UriInterface;
16 use Psr\Log\LoggerInterface;
18 class HTTPClientFactory extends BaseFactory
24 /** @var App\BaseURL */
27 public function __construct(LoggerInterface $logger, IConfig $config, Profiler $profiler, App\BaseURL $baseUrl)
29 parent::__construct($logger);
30 $this->config = $config;
31 $this->profiler = $profiler;
32 $this->baseUrl = $baseUrl;
35 public function createClient(): IHTTPClient
37 $proxy = $this->config->get('system', 'proxy');
40 $proxyuser = $this->config->get('system', 'proxyuser');
42 if (!empty($proxyuser)) {
43 $proxy = $proxyuser . '@' . $proxy;
47 $logger = $this->logger;
49 $onRedirect = function (
50 RequestInterface $request,
51 ResponseInterface $response,
54 $logger->notice('Curl redirect.', ['url' => $request->getUri(), 'to' => $uri, 'method' => $request->getMethod()]);
57 $userAgent = FRIENDICA_PLATFORM . " '" .
58 FRIENDICA_CODENAME . "' " .
59 FRIENDICA_VERSION . '-' .
60 DB_UPDATE_VERSION . '; ' .
61 $this->baseUrl->get();
63 $guzzle = new Client([
64 RequestOptions::ALLOW_REDIRECTS => [
66 'on_redirect' => $onRedirect,
67 'track_redirect' => true,
71 RequestOptions::HTTP_ERRORS => false,
72 // Without this setting it seems as if some webservers send compressed content
73 // This seems to confuse curl so that it shows this uncompressed.
74 /// @todo We could possibly set this value to "gzip" or something similar
75 RequestOptions::DECODE_CONTENT => '',
76 RequestOptions::FORCE_IP_RESOLVE => ($this->config->get('system', 'ipv4_resolve') ? 'v4' : null),
77 RequestOptions::CONNECT_TIMEOUT => 10,
78 RequestOptions::TIMEOUT => $this->config->get('system', 'curl_timeout', 60),
79 // by default we will allow self-signed certs
80 // but you can override this
81 RequestOptions::VERIFY => (bool)$this->config->get('system', 'verifyssl'),
82 RequestOptions::PROXY => $proxy,
83 RequestOptions::HEADERS => [
84 'User-Agent' => $userAgent,
88 return new HTTPClient($logger, $this->profiler, $this->config, $userAgent, $guzzle);