'loginUri' => $config->login_uri ?: null,
'usernameField' => $config->login_username_field ?: null,
'passwordField' => $config->login_password_field ?: null,
- 'extraFields' => is_array($config->login_extra_fields) ? $config->login_extra_fields : [],
+ 'extraFields' => $this->processExtraFields($config->login_extra_fields),
'notLoggedInXpath' => $config->not_logged_in_xpath ?: null,
];
return new SiteConfig($parameters);
}
+
+ /**
+ * Processes login_extra_fields config, transforming an '=' separated array of strings
+ * into a key/value array.
+ *
+ * @param array|mixed $extraFieldsStrings
+ *
+ * @return array
+ */
+ protected function processExtraFields($extraFieldsStrings)
+ {
+ if (!is_array($extraFieldsStrings)) {
+ return [];
+ }
+
+ $extraFields = [];
+ foreach ($extraFieldsStrings as $extraField) {
+ if (strpos($extraField, '=') === false) {
+ continue;
+ }
+ list($fieldName, $fieldValue) = explode('=', $extraField, 2);
+ $extraFields[$fieldName] = $fieldValue;
+ }
+
+ return $extraFields;
+ }
}
*/
class HttpClientFactory
{
- /** @var \GuzzleHttp\Event\SubscriberInterface */
- private $authenticatorSubscriber;
+ /** @var [\GuzzleHttp\Event\SubscriberInterface] */
+ private $subscribers = [];
/** @var \GuzzleHttp\Cookie\CookieJar */
private $cookieJar;
/**
* HttpClientFactory constructor.
*
- * @param \GuzzleHttp\Event\SubscriberInterface $authenticatorSubscriber
- * @param \GuzzleHttp\Cookie\CookieJar $cookieJar
- * @param string $restrictedAccess this param is a kind of boolean. Values: 0 or 1
- * @param LoggerInterface $logger
+ * @param \GuzzleHttp\Cookie\CookieJar $cookieJar
+ * @param string $restrictedAccess This param is a kind of boolean. Values: 0 or 1
+ * @param LoggerInterface $logger
*/
- public function __construct(SubscriberInterface $authenticatorSubscriber, CookieJar $cookieJar, $restrictedAccess, LoggerInterface $logger)
+ public function __construct(CookieJar $cookieJar, $restrictedAccess, LoggerInterface $logger)
{
- $this->authenticatorSubscriber = $authenticatorSubscriber;
$this->cookieJar = $cookieJar;
$this->restrictedAccess = $restrictedAccess;
$this->logger = $logger;
$this->cookieJar->clear();
// need to set the (shared) cookie jar
$client = new Client(['handler' => new SafeCurlHandler(), 'defaults' => ['cookies' => $this->cookieJar]]);
- $client->getEmitter()->attach($this->authenticatorSubscriber);
+ foreach ($this->subscribers as $subscriber) {
+ $client->getEmitter()->attach($subscriber);
+ }
return $client;
}
+
+ /**
+ * Adds a subscriber to the HTTP client.
+ *
+ * @param SubscriberInterface $subscriber
+ */
+ public function addSubscriber(SubscriberInterface $subscriber)
+ {
+ $this->subscribers[] = $subscriber;
+ }
}
wallabag_core.guzzle.http_client_factory:
class: Wallabag\CoreBundle\Helper\HttpClientFactory
arguments:
- - "@bd_guzzle_site_authenticator.authenticator_subscriber"
- "@wallabag_core.guzzle.cookie_jar"
- '@=service(''craue_config'').get(''restricted_access'')'
- '@logger'
+ calls:
+ - ["addSubscriber", ["@bd_guzzle_site_authenticator.authenticator_subscriber"]]
wallabag_core.guzzle.cookie_jar:
class: GuzzleHttp\Cookie\FileCookieJar