123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249 |
- <?php
- /*
- TODO :
- - manage SSL detection because if library isn't loaded, some bridge crash !
- - factorize the annotation system
- - factorize to adapter : Format, Bridge, Cache (actually code is almost the same)
- - implement annotation cache for entrance page
- - Cache : I think logic must be change as least to avoid to reconvert object from json in FileCache case.
- - add namespace to avoid futur problem ?
- - see FIXME mentions in the code
- - implement header('X-Cached-Version: '.date(DATE_ATOM, filemtime($cachefile)));
- */
- date_default_timezone_set('UTC');
- error_reporting(0);
- //ini_set('display_errors','1'); error_reporting(E_ALL); // For debugging only.
- // extensions check
- if (!extension_loaded('openssl'))
- die('"openssl" extension not loaded. Please check "php.ini"');
- // FIXME : beta test UA spoofing, please report any blacklisting by PHP-fopen-unfriendly websites
- ini_set('user_agent', 'Mozilla/5.0 (X11; Linux x86_64; rv:30.0) Gecko/20121202 Firefox/30.0 (rss-bridge/0.1; +https://github.com/sebsauvage/rss-bridge)');
- // -------
- // default whitelist
- $whitelist_file = './whitelist.txt';
- $whitelist_default = array(
- "BandcampBridge",
- "CryptomeBridge",
- "DansTonChatBridge",
- "DuckDuckGoBridge",
- "FlickrExploreBridge",
- "GooglePlusPostBridge",
- "GoogleSearchBridge",
- "IdenticaBridge",
- "InstagramBridge",
- "OpenClassroomsBridge",
- "PinterestBridge",
- "ScmbBridge",
- "TwitterBridge",
- "WikipediaENBridge",
- "WikipediaEOBridge",
- "WikipediaFRBridge",
- "YoutubeBridge");
- if (!file_exists($whitelist_file)) {
- $whitelist_selection = $whitelist_default;
- $whitelist_write = implode("\n", $whitelist_default);
- file_put_contents($whitelist_file, $whitelist_write);
- }
- else {
- $whitelist_selection = explode("\n", file_get_contents($whitelist_file));
- }
- // whitelist control function
- function BridgeWhitelist( $whitelist, $name ) {
- if(in_array("$name", $whitelist) or in_array("$name.php", $whitelist))
- return TRUE;
- else
- return FALSE;
- }
- try{
- require_once __DIR__ . '/lib/RssBridge.php';
- Bridge::setDir(__DIR__ . '/bridges/');
- Format::setDir(__DIR__ . '/formats/');
- Cache::setDir(__DIR__ . '/caches/');
- if( isset($_REQUEST) && isset($_REQUEST['action']) ){
- switch($_REQUEST['action']){
- case 'display':
- if( isset($_REQUEST['bridge']) ){
- unset($_REQUEST['action']);
- $bridge = $_REQUEST['bridge'];
- unset($_REQUEST['bridge']);
- $format = $_REQUEST['format'];
- unset($_REQUEST['format']);
- // whitelist control
- if(!BridgeWhitelist($whitelist_selection, $bridge)) {
- throw new \HttpException('This bridge is not whitelisted', 401);
- die;
- }
- $cache = Cache::create('FileCache');
- // Data retrieval
- $bridge = Bridge::create($bridge);
- if(isset($_REQUEST["disable_cache"])) {
- } else {
- $bridge->setCache($cache); // just add disable cache to your query to disable caching
- }
- $bridge->setDatas($_REQUEST);
- // Data transformation
- $format = Format::create($format);
- $format
- ->setDatas($bridge->getDatas())
- ->setExtraInfos(array(
- 'name' => $bridge->getName(),
- 'uri' => $bridge->getURI(),
- ))
- ->display();
- die;
- }
- break;
- }
- }
- }
- catch(HttpException $e){
- header('HTTP/1.1 ' . $e->getCode() . ' ' . Http::getMessageForCode($e->getCode()));
- header('Content-Type: text/plain');
- die($e->getMessage());
- }
- catch(\Exception $e){
- die($e->getMessage());
- }
- function getHelperButtonFormat($value, $name){
- return '<button type="submit" name="format" value="' . $value . '">' . $name . '</button>';
- }
- function getHelperButtonsFormat($formats){
- $buttons = '';
- foreach( $formats as $name => $infos )
- {
- if ( isset($infos['name']) )
- {
- $buttons .= getHelperButtonFormat($name, $infos['name']) . PHP_EOL;
- }
- }
- return $buttons;
- }
- function displayBridgeCard($bridgeReference, $bridgeInformations, $formats, $isActive = true)
- {
- $name = isset($bridgeInformations['homepage']) ? '<a href="'.$bridgeInformations['homepage'].'">'.$bridgeInformations['name'].'</a>' : $bridgeInformations['name'];
- $description = isset($bridgeInformations['description']) ? $bridgeInformations['description'] : 'No description provided';
- $card = <<<CARD
- <section id="bridge-{$bridgeReference}" data-ref="{$bridgeReference}">
- <h2>{$name}</h2>
- <p class="description">
- {$description}
- </p>
- CARD;
- if( isset($bridgeInformations['use']) && count($bridgeInformations['use']) > 0 )
- {
- $card .= '<ol class="list-use">' . PHP_EOL;
- foreach($bridgeInformations['use'] as $anUseNum => $anUse)
- {
- $card .= '<li data-use="' . $anUseNum . '">' . PHP_EOL;
- $card .= '<form method="GET" action="?">
- <input type="hidden" name="action" value="display" />
- <input type="hidden" name="bridge" value="' . $bridgeReference . '" />' . PHP_EOL;
- foreach($anUse as $argName => $argDescription)
- {
- $idArg = 'arg-' . $bridgeReference . '-' . $anUseNum . '-' . $argName;
- $card .= '<input id="' . $idArg . '" type="text" value="" placeholder="' . $argDescription . '" name="' . $argName . '" />' . PHP_EOL;
- }
- $card .= '<br />';
- if ($isActive)
- {
- $card .= getHelperButtonsFormat($formats);
- }
- else
- {
- $card .= '<span style="font-weight: bold;">Inactive</span>';
- }
- $card .= '</form></li>' . PHP_EOL;
- }
- $card .= '</ol>' . PHP_EOL;
- }
- else
- {
- $card .= '<form method="GET" action="?">
- <input type="hidden" name="action" value="display" />
- <input type="hidden" name="bridge" value="' . $bridgeReference . '" />' . PHP_EOL;
- if ($isActive)
- {
- $card .= getHelperButtonsFormat($formats);
- }
- else
- {
- $card .= '<span style="font-weight: bold;">Inactive</span>';
- }
- $card .= '</form>' . PHP_EOL;
- }
- $card .= isset($bridgeInformations['maintainer']) ? '<span class="maintainer">'.$bridgeInformations['maintainer'].'</span>' : '';
- $card .= '</section>';
- return $card;
- }
- $bridges = Bridge::searchInformation();
- $formats = Format::searchInformation();
- ?>
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="utf-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
- <meta name="description" content="Rss-bridge" />
- <title>RSS-Bridge</title>
- <link href="css/style.css" rel="stylesheet">
- <!--[if IE]>
- <script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script>
- <![endif]-->
- </head>
- <body>
- <header>
- <h1>RSS-Bridge</h1>
- <h2>·Reconnecting the Web·</h2>
- </header>
- <?php
- $activeFoundBridgeCount = 0;
- $showInactive = isset($_REQUEST['show_inactive']) && $_REQUEST['show_inactive'] == 1;
- $inactiveBridges = '';
- foreach($bridges as $bridgeReference => $bridgeInformations)
- {
- if(BridgeWhitelist($whitelist_selection, $bridgeReference))
- {
- echo displayBridgeCard($bridgeReference, $bridgeInformations, $formats);
- $activeFoundBridgeCount++;
- }
- elseif ($showInactive)
- {
- // inactive bridges
- $inactiveBridges .= displayBridgeCard($bridgeReference, $bridgeInformations, $formats, false) . PHP_EOL;
- }
- }
- echo '<hr />' . $inactiveBridges;
- ?>
- <footer>
- <?= $activeFoundBridgeCount; ?>/<?= count($bridges) ?> active bridges (<a href="?show_inactive=1">Show inactive</a>)<br />
- <a href="https://github.com/sebsauvage/rss-bridge">RSS-Bridge alpha 0.1 ~ Public Domain</a>
- </footer>
- </body>
- </html>
|