12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- <?php
- /**
- * Abstract class for the link transformations plugins
- */
- declare(strict_types=1);
- namespace PhpMyAdmin\Plugins\Transformations\Abs;
- use PhpMyAdmin\Plugins\TransformationsPlugin;
- use PhpMyAdmin\Sanitize;
- use stdClass;
- use function htmlspecialchars;
- /**
- * Provides common methods for all of the link transformations plugins.
- */
- abstract class TextLinkTransformationsPlugin extends TransformationsPlugin
- {
- /**
- * Gets the transformation description of the specific plugin
- *
- * @return string
- */
- public static function getInfo()
- {
- return __(
- 'Displays a link; the column contains the filename. The first option'
- . ' is a URL prefix like "https://www.example.com/". The second option'
- . ' is a title for the link.'
- );
- }
- /**
- * Does the actual work of each specific transformations plugin.
- *
- * @param string $buffer text to be transformed
- * @param array $options transformation options
- * @param stdClass|null $meta meta information
- *
- * @return string
- */
- public function applyTransformation($buffer, array $options = [], ?stdClass $meta = null)
- {
- $cfg = $GLOBALS['cfg'];
- $options = $this->getOptions($options, $cfg['DefaultTransformations']['TextLink']);
- $url = ($options[0] ?? '') . (isset($options[2]) && $options[2] ? '' : $buffer);
- /* Do not allow javascript links */
- if (! Sanitize::checkLink($url, true, true)) {
- return htmlspecialchars($url);
- }
- return '<a href="'
- . htmlspecialchars($url)
- . '" title="'
- . htmlspecialchars($options[1] ?? '')
- . '" target="_blank" rel="noopener noreferrer">'
- . htmlspecialchars($options[1] ?? $buffer)
- . '</a>';
- }
- /* ~~~~~~~~~~~~~~~~~~~~ Getters and Setters ~~~~~~~~~~~~~~~~~~~~ */
- /**
- * Gets the transformation name of the specific plugin
- *
- * @return string
- */
- public static function getName()
- {
- return 'TextLink';
- }
- }
|