Merge pull request #2751 from bdunogier/2.2-guzzle_subscribers_improvement

Improved Guzzle subscribers extensibility
This commit is contained in:
Jérémy Benoist 2017-05-09 17:10:03 +02:00 committed by GitHub
commit 0eb8220204
4 changed files with 49 additions and 12 deletions

View file

@ -54,7 +54,7 @@ class GrabySiteConfigBuilder implements SiteConfigBuilder
'loginUri' => $config->login_uri ?: null, 'loginUri' => $config->login_uri ?: null,
'usernameField' => $config->login_username_field ?: null, 'usernameField' => $config->login_username_field ?: null,
'passwordField' => $config->login_password_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, 'notLoggedInXpath' => $config->not_logged_in_xpath ?: null,
]; ];
@ -65,4 +65,30 @@ class GrabySiteConfigBuilder implements SiteConfigBuilder
return new SiteConfig($parameters); 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;
}
} }

View file

@ -13,8 +13,8 @@ use Psr\Log\LoggerInterface;
*/ */
class HttpClientFactory class HttpClientFactory
{ {
/** @var \GuzzleHttp\Event\SubscriberInterface */ /** @var [\GuzzleHttp\Event\SubscriberInterface] */
private $authenticatorSubscriber; private $subscribers = [];
/** @var \GuzzleHttp\Cookie\CookieJar */ /** @var \GuzzleHttp\Cookie\CookieJar */
private $cookieJar; private $cookieJar;
@ -25,14 +25,12 @@ class HttpClientFactory
/** /**
* HttpClientFactory constructor. * HttpClientFactory constructor.
* *
* @param \GuzzleHttp\Event\SubscriberInterface $authenticatorSubscriber
* @param \GuzzleHttp\Cookie\CookieJar $cookieJar * @param \GuzzleHttp\Cookie\CookieJar $cookieJar
* @param string $restrictedAccess this param is a kind of boolean. Values: 0 or 1 * @param string $restrictedAccess This param is a kind of boolean. Values: 0 or 1
* @param LoggerInterface $logger * @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->cookieJar = $cookieJar;
$this->restrictedAccess = $restrictedAccess; $this->restrictedAccess = $restrictedAccess;
$this->logger = $logger; $this->logger = $logger;
@ -53,8 +51,20 @@ class HttpClientFactory
$this->cookieJar->clear(); $this->cookieJar->clear();
// need to set the (shared) cookie jar // need to set the (shared) cookie jar
$client = new Client(['handler' => new SafeCurlHandler(), 'defaults' => ['cookies' => $this->cookieJar]]); $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; return $client;
} }
/**
* Adds a subscriber to the HTTP client.
*
* @param SubscriberInterface $subscriber
*/
public function addSubscriber(SubscriberInterface $subscriber)
{
$this->subscribers[] = $subscriber;
}
} }

View file

@ -71,10 +71,11 @@ services:
wallabag_core.guzzle.http_client_factory: wallabag_core.guzzle.http_client_factory:
class: Wallabag\CoreBundle\Helper\HttpClientFactory class: Wallabag\CoreBundle\Helper\HttpClientFactory
arguments: arguments:
- "@bd_guzzle_site_authenticator.authenticator_subscriber"
- "@wallabag_core.guzzle.cookie_jar" - "@wallabag_core.guzzle.cookie_jar"
- '@=service(''craue_config'').get(''restricted_access'')' - '@=service(''craue_config'').get(''restricted_access'')'
- '@logger' - '@logger'
calls:
- ["addSubscriber", ["@bd_guzzle_site_authenticator.authenticator_subscriber"]]
wallabag_core.guzzle.cookie_jar: wallabag_core.guzzle.cookie_jar:
class: GuzzleHttp\Cookie\FileCookieJar class: GuzzleHttp\Cookie\FileCookieJar

View file

@ -24,7 +24,7 @@ class GrabySiteConfigBuilderTest extends PHPUnit_Framework_TestCase
$grabySiteConfig->login_uri = 'http://example.com/login'; $grabySiteConfig->login_uri = 'http://example.com/login';
$grabySiteConfig->login_username_field = 'login'; $grabySiteConfig->login_username_field = 'login';
$grabySiteConfig->login_password_field = 'password'; $grabySiteConfig->login_password_field = 'password';
$grabySiteConfig->login_extra_fields = ['field' => 'value']; $grabySiteConfig->login_extra_fields = ['field=value'];
$grabySiteConfig->not_logged_in_xpath = '//div[@class="need-login"]'; $grabySiteConfig->not_logged_in_xpath = '//div[@class="need-login"]';
$grabyConfigBuilderMock $grabyConfigBuilderMock