2018-07-21 18:15:07 +02:00
|
|
|
<?php
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* This file is part of RSS-Bridge, a PHP project capable of generating RSS and
|
|
|
|
* Atom feeds for websites that don't have one.
|
|
|
|
*
|
|
|
|
* For the full license information, please view the UNLICENSE file distributed
|
|
|
|
* with this source code.
|
|
|
|
*
|
|
|
|
* @package Core
|
|
|
|
* @license http://unlicense.org/ UNLICENSE
|
|
|
|
* @link https://github.com/rss-bridge/rss-bridge
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A generator class for a single bridge card on the home page of RSS-Bridge.
|
|
|
|
*
|
|
|
|
* This class generates the HTML content for a single bridge card for the home
|
|
|
|
* page of RSS-Bridge.
|
|
|
|
*
|
|
|
|
* @todo Return error if a caller creates an object of this class.
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
final class BridgeCard {
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Build a HTML document string of buttons for each of the provided formats
|
|
|
|
*
|
|
|
|
* @param array $formats A list of format names
|
|
|
|
* @return string The document string
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
private static function buildFormatButtons($formats) {
|
|
|
|
$buttons = '';
|
|
|
|
|
|
|
|
foreach($formats as $name) {
|
|
|
|
$buttons .= '<button type="submit" name="format" value="'
|
|
|
|
. $name
|
|
|
|
. '">'
|
|
|
|
. $name
|
|
|
|
. '</button>'
|
|
|
|
. PHP_EOL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $buttons;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Get the form header for a bridge card
|
|
|
|
*
|
|
|
|
* @param string $bridgeName The bridge name
|
|
|
|
* @param bool $isHttps If disabled, adds a warning to the form
|
|
|
|
* @return string The form header
|
|
|
|
*/
|
2019-06-21 19:08:59 +02:00
|
|
|
private static function getFormHeader($bridgeName, $isHttps = false, $parameterName = '') {
|
2018-07-21 18:15:07 +02:00
|
|
|
$form = <<<EOD
|
|
|
|
<form method="GET" action="?">
|
|
|
|
<input type="hidden" name="action" value="display" />
|
|
|
|
<input type="hidden" name="bridge" value="{$bridgeName}" />
|
|
|
|
EOD;
|
|
|
|
|
2019-06-21 19:08:59 +02:00
|
|
|
if(!empty($parameterName)) {
|
|
|
|
$form .= <<<EOD
|
|
|
|
<input type="hidden" name="context" value="{$parameterName}" />
|
|
|
|
EOD;
|
|
|
|
}
|
|
|
|
|
2018-07-21 18:15:07 +02:00
|
|
|
if(!$isHttps) {
|
|
|
|
$form .= '<div class="secure-warning">Warning :
|
|
|
|
This bridge is not fetching its content through a secure connection</div>';
|
|
|
|
}
|
|
|
|
|
|
|
|
return $form;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Get the form body for a bridge
|
|
|
|
*
|
|
|
|
* @param string $bridgeName The bridge name
|
|
|
|
* @param array $formats A list of supported formats
|
|
|
|
* @param bool $isActive Indicates if a bridge is enabled or not
|
|
|
|
* @param bool $isHttps Indicates if a bridge uses HTTPS or not
|
|
|
|
* @param string $parameterName Sets the bridge context for the current form
|
|
|
|
* @param array $parameters The bridge parameters
|
|
|
|
* @return string The form body
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
private static function getForm($bridgeName,
|
|
|
|
$formats,
|
|
|
|
$isActive = false,
|
|
|
|
$isHttps = false,
|
|
|
|
$parameterName = '',
|
|
|
|
$parameters = array()) {
|
2019-06-21 19:08:59 +02:00
|
|
|
$form = self::getFormHeader($bridgeName, $isHttps, $parameterName);
|
2018-07-21 18:15:07 +02:00
|
|
|
|
2018-09-15 16:39:50 +02:00
|
|
|
if(count($parameters) > 0) {
|
|
|
|
|
|
|
|
$form .= '<div class="parameters">';
|
|
|
|
|
|
|
|
foreach($parameters as $id => $inputEntry) {
|
|
|
|
if(!isset($inputEntry['exampleValue']))
|
|
|
|
$inputEntry['exampleValue'] = '';
|
|
|
|
|
|
|
|
if(!isset($inputEntry['defaultValue']))
|
|
|
|
$inputEntry['defaultValue'] = '';
|
|
|
|
|
|
|
|
$idArg = 'arg-'
|
|
|
|
. urlencode($bridgeName)
|
|
|
|
. '-'
|
|
|
|
. urlencode($parameterName)
|
|
|
|
. '-'
|
|
|
|
. urlencode($id);
|
|
|
|
|
|
|
|
$form .= '<label for="'
|
|
|
|
. $idArg
|
|
|
|
. '">'
|
|
|
|
. filter_var($inputEntry['name'], FILTER_SANITIZE_STRING)
|
|
|
|
. '</label>'
|
|
|
|
. PHP_EOL;
|
|
|
|
|
|
|
|
if(!isset($inputEntry['type']) || $inputEntry['type'] === 'text') {
|
2018-11-18 16:59:13 +01:00
|
|
|
$form .= self::getTextInput($inputEntry, $idArg, $id);
|
2018-09-15 16:39:50 +02:00
|
|
|
} elseif($inputEntry['type'] === 'number') {
|
2018-11-18 16:59:13 +01:00
|
|
|
$form .= self::getNumberInput($inputEntry, $idArg, $id);
|
2018-09-15 16:39:50 +02:00
|
|
|
} else if($inputEntry['type'] === 'list') {
|
2018-11-18 16:59:13 +01:00
|
|
|
$form .= self::getListInput($inputEntry, $idArg, $id);
|
2018-09-15 16:39:50 +02:00
|
|
|
} elseif($inputEntry['type'] === 'checkbox') {
|
2018-11-18 16:59:13 +01:00
|
|
|
$form .= self::getCheckboxInput($inputEntry, $idArg, $id);
|
2018-09-15 16:39:50 +02:00
|
|
|
}
|
2019-10-31 21:09:44 +01:00
|
|
|
|
|
|
|
if(isset($inputEntry['title']))
|
|
|
|
$form .= '<i class="info" title="' . filter_var($inputEntry['title'], FILTER_SANITIZE_STRING) . '">i</i>';
|
|
|
|
else
|
2020-10-26 08:11:58 +01:00
|
|
|
$form .= '<i class="no-info"></i>';
|
2018-07-21 18:15:07 +02:00
|
|
|
}
|
2018-09-15 16:39:50 +02:00
|
|
|
|
|
|
|
$form .= '</div>';
|
|
|
|
|
2018-07-21 18:15:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if($isActive) {
|
2018-11-18 16:59:13 +01:00
|
|
|
$form .= self::buildFormatButtons($formats);
|
2018-07-21 18:15:07 +02:00
|
|
|
} else {
|
|
|
|
$form .= '<span style="font-weight: bold;">Inactive</span>';
|
|
|
|
}
|
|
|
|
|
|
|
|
return $form . '</form>' . PHP_EOL;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Get input field attributes
|
|
|
|
*
|
|
|
|
* @param array $entry The current entry
|
|
|
|
* @return string The input field attributes
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
private static function getInputAttributes($entry) {
|
|
|
|
$retVal = '';
|
|
|
|
|
|
|
|
if(isset($entry['required']) && $entry['required'] === true)
|
|
|
|
$retVal .= ' required';
|
|
|
|
|
|
|
|
if(isset($entry['pattern']))
|
|
|
|
$retVal .= ' pattern="' . $entry['pattern'] . '"';
|
|
|
|
|
|
|
|
return $retVal;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Get text input
|
|
|
|
*
|
|
|
|
* @param array $entry The current entry
|
|
|
|
* @param string $id The field ID
|
|
|
|
* @param string $name The field name
|
|
|
|
* @return string The text input field
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
private static function getTextInput($entry, $id, $name) {
|
|
|
|
return '<input '
|
2018-11-18 16:59:13 +01:00
|
|
|
. self::getInputAttributes($entry)
|
2018-07-21 18:15:07 +02:00
|
|
|
. ' id="'
|
|
|
|
. $id
|
|
|
|
. '" type="text" value="'
|
|
|
|
. filter_var($entry['defaultValue'], FILTER_SANITIZE_STRING)
|
|
|
|
. '" placeholder="'
|
|
|
|
. filter_var($entry['exampleValue'], FILTER_SANITIZE_STRING)
|
|
|
|
. '" name="'
|
|
|
|
. $name
|
2018-09-15 16:39:50 +02:00
|
|
|
. '" />'
|
2018-07-21 18:15:07 +02:00
|
|
|
. PHP_EOL;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Get number input
|
|
|
|
*
|
|
|
|
* @param array $entry The current entry
|
|
|
|
* @param string $id The field ID
|
|
|
|
* @param string $name The field name
|
|
|
|
* @return string The number input field
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
private static function getNumberInput($entry, $id, $name) {
|
|
|
|
return '<input '
|
2018-11-18 16:59:13 +01:00
|
|
|
. self::getInputAttributes($entry)
|
2018-07-21 18:15:07 +02:00
|
|
|
. ' id="'
|
|
|
|
. $id
|
|
|
|
. '" type="number" value="'
|
|
|
|
. filter_var($entry['defaultValue'], FILTER_SANITIZE_NUMBER_INT)
|
|
|
|
. '" placeholder="'
|
|
|
|
. filter_var($entry['exampleValue'], FILTER_SANITIZE_NUMBER_INT)
|
|
|
|
. '" name="'
|
|
|
|
. $name
|
2018-09-15 16:39:50 +02:00
|
|
|
. '" />'
|
2018-07-21 18:15:07 +02:00
|
|
|
. PHP_EOL;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Get list input
|
|
|
|
*
|
|
|
|
* @param array $entry The current entry
|
|
|
|
* @param string $id The field ID
|
|
|
|
* @param string $name The field name
|
|
|
|
* @return string The list input field
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
private static function getListInput($entry, $id, $name) {
|
2019-01-22 19:12:37 +01:00
|
|
|
if(isset($entry['required']) && $entry['required'] === true) {
|
2019-01-22 18:11:52 +01:00
|
|
|
Debug::log('The "required" attribute is not supported for lists.');
|
|
|
|
unset($entry['required']);
|
|
|
|
}
|
|
|
|
|
2018-07-21 18:15:07 +02:00
|
|
|
$list = '<select '
|
2018-11-18 16:59:13 +01:00
|
|
|
. self::getInputAttributes($entry)
|
2018-07-21 18:15:07 +02:00
|
|
|
. ' id="'
|
|
|
|
. $id
|
|
|
|
. '" name="'
|
|
|
|
. $name
|
|
|
|
. '" >';
|
|
|
|
|
|
|
|
foreach($entry['values'] as $name => $value) {
|
|
|
|
if(is_array($value)) {
|
|
|
|
$list .= '<optgroup label="' . htmlentities($name) . '">';
|
|
|
|
foreach($value as $subname => $subvalue) {
|
|
|
|
if($entry['defaultValue'] === $subname
|
|
|
|
|| $entry['defaultValue'] === $subvalue) {
|
|
|
|
$list .= '<option value="'
|
|
|
|
. $subvalue
|
|
|
|
. '" selected>'
|
|
|
|
. $subname
|
|
|
|
. '</option>';
|
|
|
|
} else {
|
|
|
|
$list .= '<option value="'
|
|
|
|
. $subvalue
|
|
|
|
. '">'
|
|
|
|
. $subname
|
|
|
|
. '</option>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$list .= '</optgroup>';
|
|
|
|
} else {
|
|
|
|
if($entry['defaultValue'] === $name
|
|
|
|
|| $entry['defaultValue'] === $value) {
|
|
|
|
$list .= '<option value="'
|
|
|
|
. $value
|
|
|
|
. '" selected>'
|
|
|
|
. $name
|
|
|
|
. '</option>';
|
|
|
|
} else {
|
|
|
|
$list .= '<option value="'
|
|
|
|
. $value
|
|
|
|
. '">'
|
|
|
|
. $name
|
|
|
|
. '</option>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-15 16:39:50 +02:00
|
|
|
$list .= '</select>';
|
2018-07-21 18:15:07 +02:00
|
|
|
|
|
|
|
return $list;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Get checkbox input
|
|
|
|
*
|
|
|
|
* @param array $entry The current entry
|
|
|
|
* @param string $id The field ID
|
|
|
|
* @param string $name The field name
|
|
|
|
* @return string The checkbox input field
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
private static function getCheckboxInput($entry, $id, $name) {
|
2019-01-22 19:12:37 +01:00
|
|
|
if(isset($entry['required']) && $entry['required'] === true) {
|
2019-01-22 18:11:52 +01:00
|
|
|
Debug::log('The "required" attribute is not supported for checkboxes.');
|
|
|
|
unset($entry['required']);
|
|
|
|
}
|
|
|
|
|
2018-07-21 18:15:07 +02:00
|
|
|
return '<input '
|
2018-11-18 16:59:13 +01:00
|
|
|
. self::getInputAttributes($entry)
|
2018-07-21 18:15:07 +02:00
|
|
|
. ' id="'
|
|
|
|
. $id
|
|
|
|
. '" type="checkbox" name="'
|
|
|
|
. $name
|
|
|
|
. '" '
|
2018-10-20 13:14:46 +02:00
|
|
|
. ($entry['defaultValue'] === 'checked' ? 'checked' : '')
|
2018-09-15 16:39:50 +02:00
|
|
|
. ' />'
|
2018-07-21 18:15:07 +02:00
|
|
|
. PHP_EOL;
|
|
|
|
}
|
|
|
|
|
2018-11-16 21:48:59 +01:00
|
|
|
/**
|
|
|
|
* Gets a single bridge card
|
|
|
|
*
|
|
|
|
* @param string $bridgeName The bridge name
|
|
|
|
* @param array $formats A list of formats
|
|
|
|
* @param bool $isActive Indicates if the bridge is active or not
|
|
|
|
* @return string The bridge card
|
|
|
|
*/
|
2018-07-21 18:15:07 +02:00
|
|
|
static function displayBridgeCard($bridgeName, $formats, $isActive = true){
|
|
|
|
|
2019-06-18 18:55:29 +02:00
|
|
|
$bridgeFac = new \BridgeFactory();
|
|
|
|
$bridgeFac->setWorkingDir(PATH_LIB_BRIDGES);
|
|
|
|
|
|
|
|
$bridge = $bridgeFac->create($bridgeName);
|
2018-07-21 18:15:07 +02:00
|
|
|
|
|
|
|
if($bridge == false)
|
|
|
|
return '';
|
|
|
|
|
|
|
|
$isHttps = strpos($bridge->getURI(), 'https') === 0;
|
|
|
|
|
|
|
|
$uri = $bridge->getURI();
|
|
|
|
$name = $bridge->getName();
|
2018-08-21 17:46:47 +02:00
|
|
|
$icon = $bridge->getIcon();
|
2018-07-21 18:15:07 +02:00
|
|
|
$description = $bridge->getDescription();
|
|
|
|
$parameters = $bridge->getParameters();
|
|
|
|
|
|
|
|
if(defined('PROXY_URL') && PROXY_BYBRIDGE) {
|
|
|
|
$parameters['global']['_noproxy'] = array(
|
|
|
|
'name' => 'Disable proxy (' . ((defined('PROXY_NAME') && PROXY_NAME) ? PROXY_NAME : PROXY_URL) . ')',
|
|
|
|
'type' => 'checkbox'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(CUSTOM_CACHE_TIMEOUT) {
|
|
|
|
$parameters['global']['_cache_timeout'] = array(
|
|
|
|
'name' => 'Cache timeout in seconds',
|
|
|
|
'type' => 'number',
|
|
|
|
'defaultValue' => $bridge->getCacheTimeout()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$card = <<<CARD
|
|
|
|
<section id="bridge-{$bridgeName}" data-ref="{$bridgeName}">
|
|
|
|
<h2><a href="{$uri}">{$name}</a></h2>
|
|
|
|
<p class="description">{$description}</p>
|
|
|
|
<input type="checkbox" class="showmore-box" id="showmore-{$bridgeName}" />
|
|
|
|
<label class="showmore" for="showmore-{$bridgeName}">Show more</label>
|
|
|
|
CARD;
|
|
|
|
|
|
|
|
// If we don't have any parameter for the bridge, we print a generic form to load it.
|
2021-02-05 06:17:30 +01:00
|
|
|
if (count($parameters) === 0) {
|
2018-11-18 16:59:13 +01:00
|
|
|
$card .= self::getForm($bridgeName, $formats, $isActive, $isHttps);
|
2018-07-21 18:15:07 +02:00
|
|
|
|
2021-02-05 06:17:30 +01:00
|
|
|
// Display form with cache timeout and/or noproxy options (if enabled) when bridge has no parameters
|
|
|
|
} else if (count($parameters) === 1 && array_key_exists('global', $parameters)) {
|
|
|
|
$card .= self::getForm($bridgeName, $formats, $isActive, $isHttps, '', $parameters['global']);
|
|
|
|
|
2018-07-21 18:15:07 +02:00
|
|
|
} else {
|
|
|
|
|
|
|
|
foreach($parameters as $parameterName => $parameter) {
|
|
|
|
if(!is_numeric($parameterName) && $parameterName === 'global')
|
|
|
|
continue;
|
|
|
|
|
|
|
|
if(array_key_exists('global', $parameters))
|
|
|
|
$parameter = array_merge($parameter, $parameters['global']);
|
|
|
|
|
|
|
|
if(!is_numeric($parameterName))
|
|
|
|
$card .= '<h5>' . $parameterName . '</h5>' . PHP_EOL;
|
|
|
|
|
2018-11-18 16:59:13 +01:00
|
|
|
$card .= self::getForm($bridgeName, $formats, $isActive, $isHttps, $parameterName, $parameter);
|
2018-07-21 18:15:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$card .= '<label class="showless" for="showmore-' . $bridgeName . '">Show less</label>';
|
|
|
|
$card .= '<p class="maintainer">' . $bridge->getMaintainer() . '</p>';
|
|
|
|
$card .= '</section>';
|
|
|
|
|
|
|
|
return $card;
|
|
|
|
}
|
|
|
|
}
|