2014-12-24 15:58:24 -05:00
|
|
|
<?php
|
|
|
|
|
2016-08-24 21:17:58 -04:00
|
|
|
namespace Miniflux\Handler\Proxy;
|
2014-12-24 15:58:24 -05:00
|
|
|
|
2016-08-24 21:17:58 -04:00
|
|
|
use Miniflux\Helper;
|
2016-04-17 19:34:54 -04:00
|
|
|
use PicoFeed\Client\ClientException;
|
2015-02-01 22:54:57 +01:00
|
|
|
use PicoFeed\Config\Config as PicoFeedConfig;
|
|
|
|
use PicoFeed\Filter\Filter;
|
2014-12-24 15:58:24 -05:00
|
|
|
use PicoFeed\Client\Client;
|
2015-02-07 11:09:43 -05:00
|
|
|
use PicoFeed\Logging\Logger;
|
2014-12-24 15:58:24 -05:00
|
|
|
|
2015-05-17 13:33:13 -04:00
|
|
|
function rewrite_link($link)
|
2015-02-07 11:09:43 -05:00
|
|
|
{
|
2015-04-10 20:57:44 -04:00
|
|
|
if (Helper\is_secure_connection() && strpos($link, 'http:') === 0) {
|
2015-02-07 11:19:25 -05:00
|
|
|
$link = '?action=proxy&url='.rawurlencode($link);
|
2014-12-24 15:58:24 -05:00
|
|
|
}
|
2015-02-01 22:54:57 +01:00
|
|
|
|
|
|
|
return $link;
|
|
|
|
}
|
|
|
|
|
2015-05-17 13:33:13 -04:00
|
|
|
function rewrite_html($html, $website, $proxy_images, $cloak_referrer)
|
2015-02-01 22:54:57 +01:00
|
|
|
{
|
|
|
|
if ($html === '' // no content, no proxy
|
|
|
|
|| (! $cloak_referrer && ! $proxy_images) // neither cloaking nor proxing enabled
|
2015-04-10 20:57:44 -04:00
|
|
|
|| (! $cloak_referrer && $proxy_images && ! Helper\is_secure_connection())) { // only proxy enabled, but not connected via HTTPS
|
2015-02-01 22:54:57 +01:00
|
|
|
|
|
|
|
return $html;
|
2014-12-24 15:58:24 -05:00
|
|
|
}
|
2015-01-09 14:43:45 +01:00
|
|
|
|
2015-02-01 22:54:57 +01:00
|
|
|
$config = new PicoFeedConfig();
|
|
|
|
$config->setFilterImageProxyUrl('?action=proxy&url=%s');
|
2015-01-09 14:43:45 +01:00
|
|
|
|
2015-02-01 22:54:57 +01:00
|
|
|
if (! $cloak_referrer && $proxy_images) {
|
|
|
|
// image proxy mode only: https links do not need to be proxied, since
|
|
|
|
// they do not trigger mixed content warnings.
|
|
|
|
$config->setFilterImageProxyProtocol('http');
|
2016-04-17 19:44:45 -04:00
|
|
|
} elseif (! $proxy_images && $cloak_referrer && Helper\is_secure_connection()) {
|
2015-02-01 22:54:57 +01:00
|
|
|
// cloaking mode only: if a request from a HTTPS connection to a HTTP
|
|
|
|
// connection is made, the referrer will be omitted by the browser.
|
|
|
|
// Only the referrer for HTTPS to HTTPs requests needs to be cloaked.
|
|
|
|
$config->setFilterImageProxyProtocol('https');
|
|
|
|
}
|
|
|
|
|
|
|
|
$filter = Filter::html($html, $website);
|
|
|
|
$filter->setConfig($config);
|
|
|
|
|
|
|
|
return $filter->execute();
|
|
|
|
}
|
|
|
|
|
|
|
|
function download($url)
|
|
|
|
{
|
2015-05-17 13:26:51 -04:00
|
|
|
try {
|
2016-12-26 09:44:53 -05:00
|
|
|
if (DEBUG_MODE) {
|
2015-05-17 13:26:51 -04:00
|
|
|
Logger::enable();
|
|
|
|
}
|
2015-02-07 11:09:43 -05:00
|
|
|
|
2015-05-17 13:26:51 -04:00
|
|
|
$client = Client::getInstance();
|
2016-12-26 09:44:53 -05:00
|
|
|
$client->setUserAgent(HTTP_USER_AGENT);
|
2015-05-17 13:26:51 -04:00
|
|
|
$client->enablePassthroughMode();
|
|
|
|
$client->execute($url);
|
2016-12-26 09:44:53 -05:00
|
|
|
} catch (ClientException $e) {
|
|
|
|
}
|
2014-12-24 15:58:24 -05:00
|
|
|
}
|