mirror of
https://github.com/wallabag/wallabag.git
synced 2025-01-10 17:05:26 +00:00
Use httplug
This commit is contained in:
parent
92a6683562
commit
bf9ace0643
10 changed files with 329 additions and 373 deletions
|
@ -34,6 +34,7 @@ class AppKernel extends Kernel
|
||||||
new FOS\JsRoutingBundle\FOSJsRoutingBundle(),
|
new FOS\JsRoutingBundle\FOSJsRoutingBundle(),
|
||||||
new BD\GuzzleSiteAuthenticatorBundle\BDGuzzleSiteAuthenticatorBundle(),
|
new BD\GuzzleSiteAuthenticatorBundle\BDGuzzleSiteAuthenticatorBundle(),
|
||||||
new OldSound\RabbitMqBundle\OldSoundRabbitMqBundle(),
|
new OldSound\RabbitMqBundle\OldSoundRabbitMqBundle(),
|
||||||
|
new Http\HttplugBundle\HttplugBundle(),
|
||||||
|
|
||||||
// wallabag bundles
|
// wallabag bundles
|
||||||
new Wallabag\CoreBundle\WallabagCoreBundle(),
|
new Wallabag\CoreBundle\WallabagCoreBundle(),
|
||||||
|
|
|
@ -370,3 +370,22 @@ jms_serializer:
|
||||||
sensio_framework_extra:
|
sensio_framework_extra:
|
||||||
router:
|
router:
|
||||||
annotations: false
|
annotations: false
|
||||||
|
|
||||||
|
httplug:
|
||||||
|
clients:
|
||||||
|
wallabag_core:
|
||||||
|
factory: 'wallabag_core.http_client_factory'
|
||||||
|
plugins: ['httplug.plugin.logger']
|
||||||
|
wallabag_core.entry.download_images:
|
||||||
|
factory: 'httplug.factory.auto'
|
||||||
|
plugins: ['httplug.plugin.logger']
|
||||||
|
wallabag_import.pocket.client:
|
||||||
|
factory: 'httplug.factory.auto'
|
||||||
|
plugins:
|
||||||
|
- 'httplug.plugin.logger'
|
||||||
|
- header_defaults:
|
||||||
|
headers:
|
||||||
|
'content-type': 'application/json'
|
||||||
|
'X-Accept': 'application/json'
|
||||||
|
discovery:
|
||||||
|
client: false
|
||||||
|
|
|
@ -66,8 +66,9 @@
|
||||||
"simplepie/simplepie": "~1.5",
|
"simplepie/simplepie": "~1.5",
|
||||||
"willdurand/hateoas-bundle": "~1.3",
|
"willdurand/hateoas-bundle": "~1.3",
|
||||||
"liip/theme-bundle": "^1.4.6",
|
"liip/theme-bundle": "^1.4.6",
|
||||||
"lexik/form-filter-bundle": "^5.0",
|
"lexik/form-filter-bundle": "^5.0.4",
|
||||||
"j0k3r/graby": "^1.0",
|
"j0k3r/graby": "^2.0",
|
||||||
|
"php-http/guzzle5-adapter": "^2.0",
|
||||||
"friendsofsymfony/user-bundle": "2.0.*",
|
"friendsofsymfony/user-bundle": "2.0.*",
|
||||||
"friendsofsymfony/oauth-server-bundle": "^1.5",
|
"friendsofsymfony/oauth-server-bundle": "^1.5",
|
||||||
"stof/doctrine-extensions-bundle": "^1.2",
|
"stof/doctrine-extensions-bundle": "^1.2",
|
||||||
|
@ -89,7 +90,8 @@
|
||||||
"bdunogier/guzzle-site-authenticator": "^1.0.0",
|
"bdunogier/guzzle-site-authenticator": "^1.0.0",
|
||||||
"defuse/php-encryption": "^2.1",
|
"defuse/php-encryption": "^2.1",
|
||||||
"html2text/html2text": "^4.1",
|
"html2text/html2text": "^4.1",
|
||||||
"pragmarx/recovery": "^0.1.0"
|
"pragmarx/recovery": "^0.1.0",
|
||||||
|
"php-http/httplug-bundle": "^1.14"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"doctrine/doctrine-fixtures-bundle": "~3.0",
|
"doctrine/doctrine-fixtures-bundle": "~3.0",
|
||||||
|
@ -101,7 +103,9 @@
|
||||||
"phpstan/phpstan": "^0.11.0",
|
"phpstan/phpstan": "^0.11.0",
|
||||||
"phpstan/phpstan-phpunit": "^0.11.0",
|
"phpstan/phpstan-phpunit": "^0.11.0",
|
||||||
"phpstan/phpstan-symfony": "^0.11.0",
|
"phpstan/phpstan-symfony": "^0.11.0",
|
||||||
"phpstan/phpstan-doctrine": "^0.11.0"
|
"phpstan/phpstan-doctrine": "^0.11.0",
|
||||||
|
"php-http/mock-client": "^1.0",
|
||||||
|
"guzzlehttp/psr7": "^1.0"
|
||||||
},
|
},
|
||||||
"suggest": {
|
"suggest": {
|
||||||
"ext-imagick": "To keep GIF animation when downloading image is enabled"
|
"ext-imagick": "To keep GIF animation when downloading image is enabled"
|
||||||
|
|
|
@ -2,8 +2,13 @@
|
||||||
|
|
||||||
namespace Wallabag\CoreBundle\Helper;
|
namespace Wallabag\CoreBundle\Helper;
|
||||||
|
|
||||||
use GuzzleHttp\Client;
|
use Http\Client\Common\HttpMethodsClient;
|
||||||
use GuzzleHttp\Message\Response;
|
use Http\Client\Common\Plugin\ErrorPlugin;
|
||||||
|
use Http\Client\Common\PluginClient;
|
||||||
|
use Http\Client\HttpClient;
|
||||||
|
use Http\Discovery\MessageFactoryDiscovery;
|
||||||
|
use Http\Message\MessageFactory;
|
||||||
|
use Psr\Http\Message\ResponseInterface;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
use Symfony\Component\DomCrawler\Crawler;
|
use Symfony\Component\DomCrawler\Crawler;
|
||||||
use Symfony\Component\Finder\Finder;
|
use Symfony\Component\Finder\Finder;
|
||||||
|
@ -19,9 +24,9 @@ class DownloadImages
|
||||||
private $mimeGuesser;
|
private $mimeGuesser;
|
||||||
private $wallabagUrl;
|
private $wallabagUrl;
|
||||||
|
|
||||||
public function __construct(Client $client, $baseFolder, $wallabagUrl, LoggerInterface $logger)
|
public function __construct(HttpClient $client, $baseFolder, $wallabagUrl, LoggerInterface $logger, MessageFactory $messageFactory = null)
|
||||||
{
|
{
|
||||||
$this->client = $client;
|
$this->client = new HttpMethodsClient(new PluginClient($client, [new ErrorPlugin()]), $messageFactory ?: MessageFactoryDiscovery::find());
|
||||||
$this->baseFolder = $baseFolder;
|
$this->baseFolder = $baseFolder;
|
||||||
$this->wallabagUrl = rtrim($wallabagUrl, '/');
|
$this->wallabagUrl = rtrim($wallabagUrl, '/');
|
||||||
$this->logger = $logger;
|
$this->logger = $logger;
|
||||||
|
@ -135,7 +140,7 @@ class DownloadImages
|
||||||
$localPath = $folderPath . '/' . $hashImage . '.' . $ext;
|
$localPath = $folderPath . '/' . $hashImage . '.' . $ext;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$im = imagecreatefromstring($res->getBody());
|
$im = imagecreatefromstring((string) $res->getBody());
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
$im = false;
|
$im = false;
|
||||||
}
|
}
|
||||||
|
@ -306,14 +311,14 @@ class DownloadImages
|
||||||
/**
|
/**
|
||||||
* Retrieve and validate the extension from the response of the url of the image.
|
* Retrieve and validate the extension from the response of the url of the image.
|
||||||
*
|
*
|
||||||
* @param Response $res Guzzle Response
|
* @param ResponseInterface $res Http Response
|
||||||
* @param string $imagePath Path from the src image from the content (used for log only)
|
* @param string $imagePath Path from the src image from the content (used for log only)
|
||||||
*
|
*
|
||||||
* @return string|false Extension name or false if validation failed
|
* @return string|false Extension name or false if validation failed
|
||||||
*/
|
*/
|
||||||
private function getExtensionFromResponse(Response $res, $imagePath)
|
private function getExtensionFromResponse(ResponseInterface $res, $imagePath)
|
||||||
{
|
{
|
||||||
$ext = $this->mimeGuesser->guess($res->getHeader('content-type'));
|
$ext = $this->mimeGuesser->guess(current($res->getHeader('content-type')));
|
||||||
$this->logger->debug('DownloadImages: Checking extension', ['ext' => $ext, 'header' => $res->getHeader('content-type')]);
|
$this->logger->debug('DownloadImages: Checking extension', ['ext' => $ext, 'header' => $res->getHeader('content-type')]);
|
||||||
|
|
||||||
// ok header doesn't have the extension, try a different way
|
// ok header doesn't have the extension, try a different way
|
||||||
|
|
|
@ -2,16 +2,18 @@
|
||||||
|
|
||||||
namespace Wallabag\CoreBundle\Helper;
|
namespace Wallabag\CoreBundle\Helper;
|
||||||
|
|
||||||
use Graby\Ring\Client\SafeCurlHandler;
|
use GuzzleHttp\Client as GuzzleClient;
|
||||||
use GuzzleHttp\Client;
|
|
||||||
use GuzzleHttp\Cookie\CookieJar;
|
use GuzzleHttp\Cookie\CookieJar;
|
||||||
use GuzzleHttp\Event\SubscriberInterface;
|
use GuzzleHttp\Event\SubscriberInterface;
|
||||||
|
use Http\Adapter\Guzzle5\Client as GuzzleAdapter;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
use Http\Client\HttpClient;
|
||||||
|
use Http\HttplugBundle\ClientFactory\ClientFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builds and configures the Guzzle HTTP client.
|
* Builds and configures the HTTP client.
|
||||||
*/
|
*/
|
||||||
class HttpClientFactory
|
class HttpClientFactory implements ClientFactory
|
||||||
{
|
{
|
||||||
/** @var [\GuzzleHttp\Event\SubscriberInterface] */
|
/** @var [\GuzzleHttp\Event\SubscriberInterface] */
|
||||||
private $subscribers = [];
|
private $subscribers = [];
|
||||||
|
@ -36,29 +38,6 @@ class HttpClientFactory
|
||||||
$this->logger = $logger;
|
$this->logger = $logger;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return \GuzzleHttp\Client|null
|
|
||||||
*/
|
|
||||||
public function buildHttpClient()
|
|
||||||
{
|
|
||||||
$this->logger->log('debug', 'Restricted access config enabled?', ['enabled' => (int) $this->restrictedAccess]);
|
|
||||||
|
|
||||||
if (0 === (int) $this->restrictedAccess) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// we clear the cookie to avoid websites who use cookies for analytics
|
|
||||||
$this->cookieJar->clear();
|
|
||||||
// need to set the (shared) cookie jar
|
|
||||||
$client = new Client(['handler' => new SafeCurlHandler(), 'defaults' => ['cookies' => $this->cookieJar]]);
|
|
||||||
|
|
||||||
foreach ($this->subscribers as $subscriber) {
|
|
||||||
$client->getEmitter()->attach($subscriber);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $client;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a subscriber to the HTTP client.
|
* Adds a subscriber to the HTTP client.
|
||||||
*
|
*
|
||||||
|
@ -68,4 +47,30 @@ class HttpClientFactory
|
||||||
{
|
{
|
||||||
$this->subscribers[] = $subscriber;
|
$this->subscribers[] = $subscriber;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Input an array of configuration to be able to create a HttpClient.
|
||||||
|
*
|
||||||
|
* @param array $config
|
||||||
|
*
|
||||||
|
* @return HttpClient
|
||||||
|
*/
|
||||||
|
public function createClient(array $config = [])
|
||||||
|
{
|
||||||
|
$this->logger->log('debug', 'Restricted access config enabled?', ['enabled' => (int) $this->restrictedAccess]);
|
||||||
|
|
||||||
|
if (0 === (int) $this->restrictedAccess) {
|
||||||
|
return new GuzzleAdapter(new GuzzleClient());
|
||||||
|
}
|
||||||
|
|
||||||
|
// we clear the cookie to avoid websites who use cookies for analytics
|
||||||
|
$this->cookieJar->clear();
|
||||||
|
// need to set the (shared) cookie jar
|
||||||
|
$guzzle = new GuzzleClient(['defaults' => ['cookies' => $this->cookieJar]]);
|
||||||
|
foreach ($this->subscribers as $subscriber) {
|
||||||
|
$guzzle->getEmitter()->attach($subscriber);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new GuzzleAdapter($guzzle);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,7 +42,7 @@ services:
|
||||||
-
|
-
|
||||||
error_message: '%wallabag_core.fetching_error_message%'
|
error_message: '%wallabag_core.fetching_error_message%'
|
||||||
error_message_title: '%wallabag_core.fetching_error_message_title%'
|
error_message_title: '%wallabag_core.fetching_error_message_title%'
|
||||||
- "@wallabag_core.guzzle.http_client"
|
- "@wallabag_core.http_client"
|
||||||
- "@wallabag_core.graby.config_builder"
|
- "@wallabag_core.graby.config_builder"
|
||||||
calls:
|
calls:
|
||||||
- [ setLogger, [ "@logger" ] ]
|
- [ setLogger, [ "@logger" ] ]
|
||||||
|
@ -55,9 +55,8 @@ services:
|
||||||
- {}
|
- {}
|
||||||
- "@logger"
|
- "@logger"
|
||||||
|
|
||||||
wallabag_core.guzzle.http_client:
|
wallabag_core.http_client:
|
||||||
class: GuzzleHttp\ClientInterface
|
alias: 'httplug.client.wallabag_core'
|
||||||
factory: ["@wallabag_core.guzzle.http_client_factory", buildHttpClient]
|
|
||||||
|
|
||||||
wallabag_core.guzzle_authenticator.config_builder:
|
wallabag_core.guzzle_authenticator.config_builder:
|
||||||
class: Wallabag\CoreBundle\GuzzleSiteAuthenticator\GrabySiteConfigBuilder
|
class: Wallabag\CoreBundle\GuzzleSiteAuthenticator\GrabySiteConfigBuilder
|
||||||
|
@ -73,7 +72,7 @@ services:
|
||||||
bd_guzzle_site_authenticator.site_config_builder:
|
bd_guzzle_site_authenticator.site_config_builder:
|
||||||
alias: wallabag_core.guzzle_authenticator.config_builder
|
alias: wallabag_core.guzzle_authenticator.config_builder
|
||||||
|
|
||||||
wallabag_core.guzzle.http_client_factory:
|
wallabag_core.http_client_factory:
|
||||||
class: Wallabag\CoreBundle\Helper\HttpClientFactory
|
class: Wallabag\CoreBundle\Helper\HttpClientFactory
|
||||||
arguments:
|
arguments:
|
||||||
- "@wallabag_core.guzzle.cookie_jar"
|
- "@wallabag_core.guzzle.cookie_jar"
|
||||||
|
@ -212,7 +211,7 @@ services:
|
||||||
- "@logger"
|
- "@logger"
|
||||||
|
|
||||||
wallabag_core.entry.download_images.client:
|
wallabag_core.entry.download_images.client:
|
||||||
class: GuzzleHttp\Client
|
alias: 'httplug.client.wallabag_core.entry.download_images'
|
||||||
|
|
||||||
wallabag_core.helper.crypto_proxy:
|
wallabag_core.helper.crypto_proxy:
|
||||||
class: Wallabag\CoreBundle\Helper\CryptoProxy
|
class: Wallabag\CoreBundle\Helper\CryptoProxy
|
||||||
|
|
|
@ -2,13 +2,22 @@
|
||||||
|
|
||||||
namespace Wallabag\ImportBundle\Import;
|
namespace Wallabag\ImportBundle\Import;
|
||||||
|
|
||||||
use GuzzleHttp\Client;
|
use Http\Client\Common\HttpMethodsClient;
|
||||||
use GuzzleHttp\Exception\RequestException;
|
use Http\Client\Common\Plugin\ErrorPlugin;
|
||||||
|
use Http\Client\Common\PluginClient;
|
||||||
|
use Http\Client\HttpClient;
|
||||||
|
use Http\Discovery\MessageFactoryDiscovery;
|
||||||
|
use Http\Message\MessageFactory;
|
||||||
|
use Http\Client\Exception\RequestException;
|
||||||
use Wallabag\CoreBundle\Entity\Entry;
|
use Wallabag\CoreBundle\Entity\Entry;
|
||||||
|
use Psr\Http\Message\ResponseInterface;
|
||||||
|
|
||||||
class PocketImport extends AbstractImport
|
class PocketImport extends AbstractImport
|
||||||
{
|
{
|
||||||
const NB_ELEMENTS = 5000;
|
const NB_ELEMENTS = 5000;
|
||||||
|
/**
|
||||||
|
* @var HttpMethodsClient
|
||||||
|
*/
|
||||||
private $client;
|
private $client;
|
||||||
private $accessToken;
|
private $accessToken;
|
||||||
|
|
||||||
|
@ -55,24 +64,18 @@ class PocketImport extends AbstractImport
|
||||||
*/
|
*/
|
||||||
public function getRequestToken($redirectUri)
|
public function getRequestToken($redirectUri)
|
||||||
{
|
{
|
||||||
$request = $this->client->createRequest('POST', 'https://getpocket.com/v3/oauth/request',
|
|
||||||
[
|
|
||||||
'body' => json_encode([
|
|
||||||
'consumer_key' => $this->user->getConfig()->getPocketConsumerKey(),
|
|
||||||
'redirect_uri' => $redirectUri,
|
|
||||||
]),
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$response = $this->client->send($request);
|
$response = $this->client->post('https://getpocket.com/v3/oauth/request', [], json_encode([
|
||||||
|
'consumer_key' => $this->user->getConfig()->getPocketConsumerKey(),
|
||||||
|
'redirect_uri' => $redirectUri,
|
||||||
|
]));
|
||||||
} catch (RequestException $e) {
|
} catch (RequestException $e) {
|
||||||
$this->logger->error(sprintf('PocketImport: Failed to request token: %s', $e->getMessage()), ['exception' => $e]);
|
$this->logger->error(sprintf('PocketImport: Failed to request token: %s', $e->getMessage()), ['exception' => $e]);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return $response->json()['code'];
|
return $this->jsonDecode($response)['code'];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -85,24 +88,19 @@ class PocketImport extends AbstractImport
|
||||||
*/
|
*/
|
||||||
public function authorize($code)
|
public function authorize($code)
|
||||||
{
|
{
|
||||||
$request = $this->client->createRequest('POST', 'https://getpocket.com/v3/oauth/authorize',
|
|
||||||
[
|
|
||||||
'body' => json_encode([
|
|
||||||
'consumer_key' => $this->user->getConfig()->getPocketConsumerKey(),
|
|
||||||
'code' => $code,
|
|
||||||
]),
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$response = $this->client->send($request);
|
$response = $this->client->post('https://getpocket.com/v3/oauth/authorize', [], json_encode([
|
||||||
|
'consumer_key' => $this->user->getConfig()->getPocketConsumerKey(),
|
||||||
|
'code' => $code,
|
||||||
|
]));
|
||||||
} catch (RequestException $e) {
|
} catch (RequestException $e) {
|
||||||
$this->logger->error(sprintf('PocketImport: Failed to authorize client: %s', $e->getMessage()), ['exception' => $e]);
|
$this->logger->error(sprintf('PocketImport: Failed to authorize client: %s', $e->getMessage()), ['exception' => $e]);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->accessToken = $response->json()['access_token'];
|
$this->accessToken = $this->jsonDecode($response)['access_token'];
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -114,29 +112,23 @@ class PocketImport extends AbstractImport
|
||||||
{
|
{
|
||||||
static $run = 0;
|
static $run = 0;
|
||||||
|
|
||||||
$request = $this->client->createRequest('POST', 'https://getpocket.com/v3/get',
|
|
||||||
[
|
|
||||||
'body' => json_encode([
|
|
||||||
'consumer_key' => $this->user->getConfig()->getPocketConsumerKey(),
|
|
||||||
'access_token' => $this->accessToken,
|
|
||||||
'detailType' => 'complete',
|
|
||||||
'state' => 'all',
|
|
||||||
'sort' => 'newest',
|
|
||||||
'count' => self::NB_ELEMENTS,
|
|
||||||
'offset' => $offset,
|
|
||||||
]),
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$response = $this->client->send($request);
|
$response = $this->client->post('https://getpocket.com/v3/get', [], json_encode([
|
||||||
|
'consumer_key' => $this->user->getConfig()->getPocketConsumerKey(),
|
||||||
|
'access_token' => $this->accessToken,
|
||||||
|
'detailType' => 'complete',
|
||||||
|
'state' => 'all',
|
||||||
|
'sort' => 'newest',
|
||||||
|
'count' => self::NB_ELEMENTS,
|
||||||
|
'offset' => $offset,
|
||||||
|
]));
|
||||||
} catch (RequestException $e) {
|
} catch (RequestException $e) {
|
||||||
$this->logger->error(sprintf('PocketImport: Failed to import: %s', $e->getMessage()), ['exception' => $e]);
|
$this->logger->error(sprintf('PocketImport: Failed to import: %s', $e->getMessage()), ['exception' => $e]);
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$entries = $response->json();
|
$entries = $this->jsonDecode($response);
|
||||||
|
|
||||||
if ($this->producer) {
|
if ($this->producer) {
|
||||||
$this->parseEntriesForProducer($entries['list']);
|
$this->parseEntriesForProducer($entries['list']);
|
||||||
|
@ -159,13 +151,14 @@ class PocketImport extends AbstractImport
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the Guzzle client.
|
* Set the Http client.
|
||||||
*
|
*
|
||||||
* @param Client $client
|
* @param HttpClient $client
|
||||||
|
* @param MessageFactory|null $messageFactory
|
||||||
*/
|
*/
|
||||||
public function setClient(Client $client)
|
public function setClient(HttpClient $client, MessageFactory $messageFactory = null)
|
||||||
{
|
{
|
||||||
$this->client = $client;
|
$this->client = new HttpMethodsClient(new PluginClient($client, [new ErrorPlugin()]), $messageFactory ?: MessageFactoryDiscovery::find());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -252,4 +245,15 @@ class PocketImport extends AbstractImport
|
||||||
|
|
||||||
return $importedEntry;
|
return $importedEntry;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected function jsonDecode(ResponseInterface $response)
|
||||||
|
{
|
||||||
|
$data = \json_decode((string) $response->getBody(), true);
|
||||||
|
|
||||||
|
if (JSON_ERROR_NONE !== json_last_error()) {
|
||||||
|
throw new \InvalidArgumentException('Unable to parse JSON data: ' . json_last_error_msg());
|
||||||
|
}
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,13 +7,7 @@ services:
|
||||||
class: Wallabag\ImportBundle\Import\ImportChain
|
class: Wallabag\ImportBundle\Import\ImportChain
|
||||||
|
|
||||||
wallabag_import.pocket.client:
|
wallabag_import.pocket.client:
|
||||||
class: GuzzleHttp\Client
|
alias: 'httplug.client.wallabag_import.pocket.client'
|
||||||
arguments:
|
|
||||||
-
|
|
||||||
defaults:
|
|
||||||
headers:
|
|
||||||
content-type: "application/json"
|
|
||||||
X-Accept: "application/json"
|
|
||||||
|
|
||||||
wallabag_import.pocket.import:
|
wallabag_import.pocket.import:
|
||||||
class: Wallabag\ImportBundle\Import\PocketImport
|
class: Wallabag\ImportBundle\Import\PocketImport
|
||||||
|
|
|
@ -3,9 +3,10 @@
|
||||||
namespace Tests\Wallabag\CoreBundle\Helper;
|
namespace Tests\Wallabag\CoreBundle\Helper;
|
||||||
|
|
||||||
use GuzzleHttp\Client;
|
use GuzzleHttp\Client;
|
||||||
use GuzzleHttp\Message\Response;
|
|
||||||
use GuzzleHttp\Stream\Stream;
|
use GuzzleHttp\Stream\Stream;
|
||||||
use GuzzleHttp\Subscriber\Mock;
|
use GuzzleHttp\Subscriber\Mock;
|
||||||
|
use Http\Mock\Client as HttpMockClient;
|
||||||
|
use GuzzleHttp\Psr7\Response;
|
||||||
use Monolog\Handler\TestHandler;
|
use Monolog\Handler\TestHandler;
|
||||||
use Monolog\Logger;
|
use Monolog\Logger;
|
||||||
use PHPUnit\Framework\TestCase;
|
use PHPUnit\Framework\TestCase;
|
||||||
|
@ -32,18 +33,14 @@ class DownloadImagesTest extends TestCase
|
||||||
*/
|
*/
|
||||||
public function testProcessHtml($html, $url)
|
public function testProcessHtml($html, $url)
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
|
||||||
$mock = new Mock([
|
$httpMockClient->addResponse(new Response(200, ['content-type' => 'image/png'], file_get_contents(__DIR__ . '/../fixtures/unnamed.png')));
|
||||||
new Response(200, ['content-type' => 'image/png'], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/unnamed.png'))),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$logHandler = new TestHandler();
|
$logHandler = new TestHandler();
|
||||||
$logger = new Logger('test', [$logHandler]);
|
$logger = new Logger('test', [$logHandler]);
|
||||||
|
|
||||||
$download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
$download = new DownloadImages($httpMockClient, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
||||||
|
|
||||||
$res = $download->processHtml(123, $html, $url);
|
$res = $download->processHtml(123, $html, $url);
|
||||||
|
|
||||||
|
@ -53,18 +50,13 @@ class DownloadImagesTest extends TestCase
|
||||||
|
|
||||||
public function testProcessHtmlWithBadImage()
|
public function testProcessHtmlWithBadImage()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['content-type' => 'application/json'], ''));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(200, ['content-type' => 'application/json'], Stream::factory('')),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$logHandler = new TestHandler();
|
$logHandler = new TestHandler();
|
||||||
$logger = new Logger('test', [$logHandler]);
|
$logger = new Logger('test', [$logHandler]);
|
||||||
|
|
||||||
$download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
$download = new DownloadImages($httpMockClient, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
||||||
$res = $download->processHtml(123, '<div><img src="http://i.imgur.com/T9qgcHc.jpg" /></div>', 'http://imgur.com/gallery/WxtWY');
|
$res = $download->processHtml(123, '<div><img src="http://i.imgur.com/T9qgcHc.jpg" /></div>', 'http://imgur.com/gallery/WxtWY');
|
||||||
|
|
||||||
$this->assertContains('http://i.imgur.com/T9qgcHc.jpg', $res, 'Image were not replace because of content-type');
|
$this->assertContains('http://i.imgur.com/T9qgcHc.jpg', $res, 'Image were not replace because of content-type');
|
||||||
|
@ -85,18 +77,13 @@ class DownloadImagesTest extends TestCase
|
||||||
*/
|
*/
|
||||||
public function testProcessSingleImage($header, $extension)
|
public function testProcessSingleImage($header, $extension)
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['content-type' => $header], file_get_contents(__DIR__ . '/../fixtures/unnamed.png')));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(200, ['content-type' => $header], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/unnamed.png'))),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$logHandler = new TestHandler();
|
$logHandler = new TestHandler();
|
||||||
$logger = new Logger('test', [$logHandler]);
|
$logger = new Logger('test', [$logHandler]);
|
||||||
|
|
||||||
$download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
$download = new DownloadImages($httpMockClient, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
||||||
$res = $download->processSingleImage(123, 'T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
|
$res = $download->processSingleImage(123, 'T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
|
||||||
|
|
||||||
$this->assertContains('/assets/images/9/b/9b0ead26/ebe60399.' . $extension, $res);
|
$this->assertContains('/assets/images/9/b/9b0ead26/ebe60399.' . $extension, $res);
|
||||||
|
@ -104,18 +91,13 @@ class DownloadImagesTest extends TestCase
|
||||||
|
|
||||||
public function testProcessSingleImageWithBadUrl()
|
public function testProcessSingleImageWithBadUrl()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(404, []));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(404, []),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$logHandler = new TestHandler();
|
$logHandler = new TestHandler();
|
||||||
$logger = new Logger('test', [$logHandler]);
|
$logger = new Logger('test', [$logHandler]);
|
||||||
|
|
||||||
$download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
$download = new DownloadImages($httpMockClient, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
||||||
$res = $download->processSingleImage(123, 'T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
|
$res = $download->processSingleImage(123, 'T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
|
||||||
|
|
||||||
$this->assertFalse($res, 'Image can not be found, so it will not be replaced');
|
$this->assertFalse($res, 'Image can not be found, so it will not be replaced');
|
||||||
|
@ -123,18 +105,13 @@ class DownloadImagesTest extends TestCase
|
||||||
|
|
||||||
public function testProcessSingleImageWithBadImage()
|
public function testProcessSingleImageWithBadImage()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['content-type' => 'image/png'], ''));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(200, ['content-type' => 'image/png'], Stream::factory('')),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$logHandler = new TestHandler();
|
$logHandler = new TestHandler();
|
||||||
$logger = new Logger('test', [$logHandler]);
|
$logger = new Logger('test', [$logHandler]);
|
||||||
|
|
||||||
$download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
$download = new DownloadImages($httpMockClient, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
||||||
$res = $download->processSingleImage(123, 'http://i.imgur.com/T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
|
$res = $download->processSingleImage(123, 'http://i.imgur.com/T9qgcHc.jpg', 'http://imgur.com/gallery/WxtWY');
|
||||||
|
|
||||||
$this->assertFalse($res, 'Image can not be loaded, so it will not be replaced');
|
$this->assertFalse($res, 'Image can not be loaded, so it will not be replaced');
|
||||||
|
@ -142,18 +119,13 @@ class DownloadImagesTest extends TestCase
|
||||||
|
|
||||||
public function testProcessSingleImageFailAbsolute()
|
public function testProcessSingleImageFailAbsolute()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['content-type' => 'image/png'], file_get_contents(__DIR__ . '/../fixtures/unnamed.png')));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(200, ['content-type' => 'image/png'], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/unnamed.png'))),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$logHandler = new TestHandler();
|
$logHandler = new TestHandler();
|
||||||
$logger = new Logger('test', [$logHandler]);
|
$logger = new Logger('test', [$logHandler]);
|
||||||
|
|
||||||
$download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
$download = new DownloadImages($httpMockClient, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
||||||
$res = $download->processSingleImage(123, '/i.imgur.com/T9qgcHc.jpg', 'imgur.com/gallery/WxtWY');
|
$res = $download->processSingleImage(123, '/i.imgur.com/T9qgcHc.jpg', 'imgur.com/gallery/WxtWY');
|
||||||
|
|
||||||
$this->assertFalse($res, 'Absolute image can not be determined, so it will not be replaced');
|
$this->assertFalse($res, 'Absolute image can not be determined, so it will not be replaced');
|
||||||
|
@ -161,18 +133,13 @@ class DownloadImagesTest extends TestCase
|
||||||
|
|
||||||
public function testProcessRealImage()
|
public function testProcessRealImage()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['content-type' => null], file_get_contents(__DIR__ . '/../fixtures/image-no-content-type.jpg')));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(200, ['content-type' => null], Stream::factory(file_get_contents(__DIR__ . '/../fixtures/image-no-content-type.jpg'))),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$logHandler = new TestHandler();
|
$logHandler = new TestHandler();
|
||||||
$logger = new Logger('test', [$logHandler]);
|
$logger = new Logger('test', [$logHandler]);
|
||||||
|
|
||||||
$download = new DownloadImages($client, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
$download = new DownloadImages($httpMockClient, sys_get_temp_dir() . '/wallabag_test', 'http://wallabag.io/', $logger);
|
||||||
|
|
||||||
$res = $download->processSingleImage(
|
$res = $download->processSingleImage(
|
||||||
123,
|
123,
|
||||||
|
|
|
@ -2,10 +2,8 @@
|
||||||
|
|
||||||
namespace Tests\Wallabag\ImportBundle\Import;
|
namespace Tests\Wallabag\ImportBundle\Import;
|
||||||
|
|
||||||
use GuzzleHttp\Client;
|
use Http\Mock\Client as HttpMockClient;
|
||||||
use GuzzleHttp\Message\Response;
|
use GuzzleHttp\Psr7\Response;
|
||||||
use GuzzleHttp\Stream\Stream;
|
|
||||||
use GuzzleHttp\Subscriber\Mock;
|
|
||||||
use M6Web\Component\RedisMock\RedisMockFactory;
|
use M6Web\Component\RedisMock\RedisMockFactory;
|
||||||
use Monolog\Handler\TestHandler;
|
use Monolog\Handler\TestHandler;
|
||||||
use Monolog\Logger;
|
use Monolog\Logger;
|
||||||
|
@ -38,16 +36,11 @@ class PocketImportTest extends TestCase
|
||||||
|
|
||||||
public function testOAuthRequest()
|
public function testOAuthRequest()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['code' => 'wunderbar_code'])));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['code' => 'wunderbar_code']))),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport();
|
$pocketImport = $this->getPocketImport();
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
|
|
||||||
$code = $pocketImport->getRequestToken('http://0.0.0.0/redirect');
|
$code = $pocketImport->getRequestToken('http://0.0.0.0/redirect');
|
||||||
|
|
||||||
|
@ -56,16 +49,11 @@ class PocketImportTest extends TestCase
|
||||||
|
|
||||||
public function testOAuthRequestBadResponse()
|
public function testOAuthRequestBadResponse()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(403));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(403),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport();
|
$pocketImport = $this->getPocketImport();
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
|
|
||||||
$code = $pocketImport->getRequestToken('http://0.0.0.0/redirect');
|
$code = $pocketImport->getRequestToken('http://0.0.0.0/redirect');
|
||||||
|
|
||||||
|
@ -78,16 +66,11 @@ class PocketImportTest extends TestCase
|
||||||
|
|
||||||
public function testOAuthAuthorize()
|
public function testOAuthAuthorize()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['access_token' => 'wunderbar_token'])));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['access_token' => 'wunderbar_token']))),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport();
|
$pocketImport = $this->getPocketImport();
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
|
|
||||||
$res = $pocketImport->authorize('wunderbar_code');
|
$res = $pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
|
@ -97,16 +80,11 @@ class PocketImportTest extends TestCase
|
||||||
|
|
||||||
public function testOAuthAuthorizeBadResponse()
|
public function testOAuthAuthorizeBadResponse()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(403));
|
||||||
$mock = new Mock([
|
|
||||||
new Response(403),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport();
|
$pocketImport = $this->getPocketImport();
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
|
|
||||||
$res = $pocketImport->authorize('wunderbar_code');
|
$res = $pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
|
@ -122,94 +100,90 @@ class PocketImportTest extends TestCase
|
||||||
*/
|
*/
|
||||||
public function testImport()
|
public function testImport()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['access_token' => 'wunderbar_token'])));
|
||||||
$mock = new Mock([
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], <<<'JSON'
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['access_token' => 'wunderbar_token']))),
|
{
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory('
|
"status": 1,
|
||||||
{
|
"list": {
|
||||||
"status": 1,
|
"229279689": {
|
||||||
"list": {
|
"item_id": "229279689",
|
||||||
"229279689": {
|
"resolved_id": "229279689",
|
||||||
"item_id": "229279689",
|
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
||||||
"resolved_id": "229279689",
|
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
||||||
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
"favorite": "1",
|
||||||
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
"status": "1",
|
||||||
"favorite": "1",
|
"time_added": "1473020899",
|
||||||
"status": "1",
|
"time_updated": "1473020899",
|
||||||
"time_added": "1473020899",
|
"time_read": "0",
|
||||||
"time_updated": "1473020899",
|
"time_favorited": "0",
|
||||||
"time_read": "0",
|
"sort_id": 0,
|
||||||
"time_favorited": "0",
|
"resolved_title": "The Massive Ryder Cup Preview",
|
||||||
"sort_id": 0,
|
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
||||||
"resolved_title": "The Massive Ryder Cup Preview",
|
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
||||||
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
"is_article": "1",
|
||||||
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
"is_index": "0",
|
||||||
"is_article": "1",
|
"has_video": "1",
|
||||||
"is_index": "0",
|
"has_image": "1",
|
||||||
"has_video": "1",
|
"word_count": "3197",
|
||||||
"has_image": "1",
|
"images": {
|
||||||
"word_count": "3197",
|
"1": {
|
||||||
"images": {
|
"item_id": "229279689",
|
||||||
"1": {
|
"image_id": "1",
|
||||||
"item_id": "229279689",
|
"src": "http://a.espncdn.com/combiner/i?img=/photo/2012/0927/grant_g_ryder_cr_640.jpg&w=640&h=360",
|
||||||
"image_id": "1",
|
"width": "0",
|
||||||
"src": "http://a.espncdn.com/combiner/i?img=/photo/2012/0927/grant_g_ryder_cr_640.jpg&w=640&h=360",
|
"height": "0",
|
||||||
"width": "0",
|
"credit": "Jamie Squire/Getty Images",
|
||||||
"height": "0",
|
"caption": ""
|
||||||
"credit": "Jamie Squire/Getty Images",
|
|
||||||
"caption": ""
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"videos": {
|
|
||||||
"1": {
|
|
||||||
"item_id": "229279689",
|
|
||||||
"video_id": "1",
|
|
||||||
"src": "http://www.youtube.com/v/Er34PbFkVGk?version=3&hl=en_US&rel=0",
|
|
||||||
"width": "420",
|
|
||||||
"height": "315",
|
|
||||||
"type": "1",
|
|
||||||
"vid": "Er34PbFkVGk"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"tags": {
|
|
||||||
"grantland": {
|
|
||||||
"item_id": "1147652870",
|
|
||||||
"tag": "grantland"
|
|
||||||
},
|
|
||||||
"Ryder Cup": {
|
|
||||||
"item_id": "1147652870",
|
|
||||||
"tag": "Ryder Cup"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"229279690": {
|
"videos": {
|
||||||
"item_id": "229279689",
|
"1": {
|
||||||
"resolved_id": "229279689",
|
"item_id": "229279689",
|
||||||
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
"video_id": "1",
|
||||||
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
"src": "http://www.youtube.com/v/Er34PbFkVGk?version=3&hl=en_US&rel=0",
|
||||||
"favorite": "1",
|
"width": "420",
|
||||||
"status": "1",
|
"height": "315",
|
||||||
"time_added": "1473020899",
|
"type": "1",
|
||||||
"time_updated": "1473020899",
|
"vid": "Er34PbFkVGk"
|
||||||
"time_read": "0",
|
}
|
||||||
"time_favorited": "0",
|
},
|
||||||
"sort_id": 1,
|
"tags": {
|
||||||
"resolved_title": "The Massive Ryder Cup Preview",
|
"grantland": {
|
||||||
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
"item_id": "1147652870",
|
||||||
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
"tag": "grantland"
|
||||||
"is_article": "1",
|
},
|
||||||
"is_index": "0",
|
"Ryder Cup": {
|
||||||
"has_video": "0",
|
"item_id": "1147652870",
|
||||||
"has_image": "0",
|
"tag": "Ryder Cup"
|
||||||
"word_count": "3197"
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"229279690": {
|
||||||
|
"item_id": "229279689",
|
||||||
|
"resolved_id": "229279689",
|
||||||
|
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
||||||
|
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
||||||
|
"favorite": "1",
|
||||||
|
"status": "1",
|
||||||
|
"time_added": "1473020899",
|
||||||
|
"time_updated": "1473020899",
|
||||||
|
"time_read": "0",
|
||||||
|
"time_favorited": "0",
|
||||||
|
"sort_id": 1,
|
||||||
|
"resolved_title": "The Massive Ryder Cup Preview",
|
||||||
|
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
||||||
|
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
||||||
|
"is_article": "1",
|
||||||
|
"is_index": "0",
|
||||||
|
"has_video": "0",
|
||||||
|
"has_image": "0",
|
||||||
|
"word_count": "3197"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
')),
|
}
|
||||||
]);
|
JSON
|
||||||
|
));
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport('ConsumerKey', 1);
|
$pocketImport = $this->getPocketImport('ConsumerKey', 1);
|
||||||
|
|
||||||
|
@ -240,7 +214,7 @@ class PocketImportTest extends TestCase
|
||||||
->method('updateEntry')
|
->method('updateEntry')
|
||||||
->willReturn($entry);
|
->willReturn($entry);
|
||||||
|
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
$pocketImport->authorize('wunderbar_code');
|
$pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
$res = $pocketImport->import();
|
$res = $pocketImport->import();
|
||||||
|
@ -254,56 +228,52 @@ class PocketImportTest extends TestCase
|
||||||
*/
|
*/
|
||||||
public function testImportAndMarkAllAsRead()
|
public function testImportAndMarkAllAsRead()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['access_token' => 'wunderbar_token'])));
|
||||||
$mock = new Mock([
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], <<<'JSON'
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['access_token' => 'wunderbar_token']))),
|
{
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory('
|
"status": 1,
|
||||||
{
|
"list": {
|
||||||
"status": 1,
|
"229279689": {
|
||||||
"list": {
|
"item_id": "229279689",
|
||||||
"229279689": {
|
"resolved_id": "229279689",
|
||||||
"item_id": "229279689",
|
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
||||||
"resolved_id": "229279689",
|
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
||||||
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview",
|
"favorite": "1",
|
||||||
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
"status": "1",
|
||||||
"favorite": "1",
|
"time_added": "1473020899",
|
||||||
"status": "1",
|
"time_updated": "1473020899",
|
||||||
"time_added": "1473020899",
|
"time_read": "0",
|
||||||
"time_updated": "1473020899",
|
"time_favorited": "0",
|
||||||
"time_read": "0",
|
"sort_id": 0,
|
||||||
"time_favorited": "0",
|
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
||||||
"sort_id": 0,
|
"is_article": "1",
|
||||||
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
"has_video": "1",
|
||||||
"is_article": "1",
|
"has_image": "1",
|
||||||
"has_video": "1",
|
"word_count": "3197"
|
||||||
"has_image": "1",
|
},
|
||||||
"word_count": "3197"
|
"229279690": {
|
||||||
},
|
"item_id": "229279689",
|
||||||
"229279690": {
|
"resolved_id": "229279689",
|
||||||
"item_id": "229279689",
|
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview/2",
|
||||||
"resolved_id": "229279689",
|
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
||||||
"given_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview/2",
|
"favorite": "1",
|
||||||
"given_title": "The Massive Ryder Cup Preview - The Triangle Blog - Grantland",
|
"status": "0",
|
||||||
"favorite": "1",
|
"time_added": "1473020899",
|
||||||
"status": "0",
|
"time_updated": "1473020899",
|
||||||
"time_added": "1473020899",
|
"time_read": "0",
|
||||||
"time_updated": "1473020899",
|
"time_favorited": "0",
|
||||||
"time_read": "0",
|
"sort_id": 1,
|
||||||
"time_favorited": "0",
|
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
||||||
"sort_id": 1,
|
"is_article": "1",
|
||||||
"excerpt": "The list of things I love about the Ryder Cup is so long that it could fill a (tedious) novel, and golf fans can probably guess most of them.",
|
"has_video": "0",
|
||||||
"is_article": "1",
|
"has_image": "0",
|
||||||
"has_video": "0",
|
"word_count": "3197"
|
||||||
"has_image": "0",
|
|
||||||
"word_count": "3197"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
')),
|
}
|
||||||
]);
|
JSON
|
||||||
|
));
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport('ConsumerKey', 2);
|
$pocketImport = $this->getPocketImport('ConsumerKey', 2);
|
||||||
|
|
||||||
|
@ -335,7 +305,7 @@ class PocketImportTest extends TestCase
|
||||||
->method('updateEntry')
|
->method('updateEntry')
|
||||||
->willReturn($entry);
|
->willReturn($entry);
|
||||||
|
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
$pocketImport->authorize('wunderbar_code');
|
$pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
$res = $pocketImport->setMarkAsRead(true)->import();
|
$res = $pocketImport->setMarkAsRead(true)->import();
|
||||||
|
@ -349,7 +319,7 @@ class PocketImportTest extends TestCase
|
||||||
*/
|
*/
|
||||||
public function testImportWithRabbit()
|
public function testImportWithRabbit()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
|
||||||
$body = <<<'JSON'
|
$body = <<<'JSON'
|
||||||
{
|
{
|
||||||
|
@ -374,19 +344,16 @@ class PocketImportTest extends TestCase
|
||||||
}
|
}
|
||||||
JSON;
|
JSON;
|
||||||
|
|
||||||
$mock = new Mock([
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['access_token' => 'wunderbar_token'])));
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['access_token' => 'wunderbar_token']))),
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], <<<JSON
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory('
|
{
|
||||||
{
|
"status": 1,
|
||||||
"status": 1,
|
"list": {
|
||||||
"list": {
|
"229279690": $body
|
||||||
"229279690": ' . $body . '
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
')),
|
}
|
||||||
]);
|
JSON
|
||||||
|
));
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport();
|
$pocketImport = $this->getPocketImport();
|
||||||
|
|
||||||
|
@ -420,7 +387,7 @@ JSON;
|
||||||
->method('publish')
|
->method('publish')
|
||||||
->with(json_encode($bodyAsArray));
|
->with(json_encode($bodyAsArray));
|
||||||
|
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
$pocketImport->setProducer($producer);
|
$pocketImport->setProducer($producer);
|
||||||
$pocketImport->authorize('wunderbar_code');
|
$pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
|
@ -435,7 +402,7 @@ JSON;
|
||||||
*/
|
*/
|
||||||
public function testImportWithRedis()
|
public function testImportWithRedis()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
|
||||||
$body = <<<'JSON'
|
$body = <<<'JSON'
|
||||||
{
|
{
|
||||||
|
@ -460,19 +427,16 @@ JSON;
|
||||||
}
|
}
|
||||||
JSON;
|
JSON;
|
||||||
|
|
||||||
$mock = new Mock([
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['access_token' => 'wunderbar_token'])));
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['access_token' => 'wunderbar_token']))),
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], <<<JSON
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory('
|
{
|
||||||
{
|
"status": 1,
|
||||||
"status": 1,
|
"list": {
|
||||||
"list": {
|
"229279690": $body
|
||||||
"229279690": ' . $body . '
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
')),
|
}
|
||||||
]);
|
JSON
|
||||||
|
));
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport();
|
$pocketImport = $this->getPocketImport();
|
||||||
|
|
||||||
|
@ -499,7 +463,7 @@ JSON;
|
||||||
$queue = new RedisQueue($redisMock, 'pocket');
|
$queue = new RedisQueue($redisMock, 'pocket');
|
||||||
$producer = new Producer($queue);
|
$producer = new Producer($queue);
|
||||||
|
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
$pocketImport->setProducer($producer);
|
$pocketImport->setProducer($producer);
|
||||||
$pocketImport->authorize('wunderbar_code');
|
$pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
|
@ -513,17 +477,13 @@ JSON;
|
||||||
|
|
||||||
public function testImportBadResponse()
|
public function testImportBadResponse()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
|
||||||
$mock = new Mock([
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['access_token' => 'wunderbar_token'])));
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['access_token' => 'wunderbar_token']))),
|
$httpMockClient->addResponse(new Response(403));
|
||||||
new Response(403),
|
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport();
|
$pocketImport = $this->getPocketImport();
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
$pocketImport->authorize('wunderbar_code');
|
$pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
$res = $pocketImport->import();
|
$res = $pocketImport->import();
|
||||||
|
@ -537,25 +497,23 @@ JSON;
|
||||||
|
|
||||||
public function testImportWithExceptionFromGraby()
|
public function testImportWithExceptionFromGraby()
|
||||||
{
|
{
|
||||||
$client = new Client();
|
$httpMockClient = new HttpMockClient();
|
||||||
|
|
||||||
$mock = new Mock([
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], json_encode(['access_token' => 'wunderbar_token'])));
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory(json_encode(['access_token' => 'wunderbar_token']))),
|
$httpMockClient->addResponse(new Response(200, ['Content-Type' => 'application/json'], <<<'JSON'
|
||||||
new Response(200, ['Content-Type' => 'application/json'], Stream::factory('
|
{
|
||||||
{
|
"status": 1,
|
||||||
"status": 1,
|
"list": {
|
||||||
"list": {
|
"229279689": {
|
||||||
"229279689": {
|
"status": "1",
|
||||||
"status": "1",
|
"favorite": "1",
|
||||||
"favorite": "1",
|
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview"
|
||||||
"resolved_url": "http://www.grantland.com/blog/the-triangle/post/_/id/38347/ryder-cup-preview"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
')),
|
}
|
||||||
]);
|
|
||||||
|
|
||||||
$client->getEmitter()->attach($mock);
|
JSON
|
||||||
|
));
|
||||||
|
|
||||||
$pocketImport = $this->getPocketImport('ConsumerKey', 1);
|
$pocketImport = $this->getPocketImport('ConsumerKey', 1);
|
||||||
|
|
||||||
|
@ -579,7 +537,7 @@ JSON;
|
||||||
->method('updateEntry')
|
->method('updateEntry')
|
||||||
->will($this->throwException(new \Exception()));
|
->will($this->throwException(new \Exception()));
|
||||||
|
|
||||||
$pocketImport->setClient($client);
|
$pocketImport->setClient($httpMockClient);
|
||||||
$pocketImport->authorize('wunderbar_code');
|
$pocketImport->authorize('wunderbar_code');
|
||||||
|
|
||||||
$res = $pocketImport->import();
|
$res = $pocketImport->import();
|
||||||
|
|
Loading…
Reference in a new issue