mirror of
				https://github.com/e107inc/e107.git
				synced 2025-10-25 03:36:42 +02:00 
			
		
		
		
	* `strftime()` has been replaced with a polyfill based on `DateTime`. * Explicit type casts/assertions added where required by PHP 8.1 * `filter_var(…, FILTER_SANITIZE_STRING)` replaced with `strip_tags()` or HTML entity encoding of quotation marks, depending on a guess of what the intended "sanitization" was * `http_build_query()` usage type mismatches fixed * Removed usages of the `FILE_TEXT` constant * To avoid breaking PHP 5.6 compatibility (function return types), `e_session_db` no longer implements `SessionHandlerInterface`. Instead, the alternative non-OOP invocation of `session_set_save_handler()` is used instead to apply the session handler. * The shim for `strptime()` still calls the native function if available but now suppresses the deprecation warning. * `e_db_pdo` explicitly asks for `PDO::ATTR_STRINGIFY_FETCHES` to maintain consistent behavior with past versions of PHP. * `e_db_mysql` explicitly sets `mysqli_report(MYSQLI_REPORT_OFF)` to maintain consistent behavior with past versions of PHP. * Removed pointless random number generator seed from `banner` plugin * Workaround for `COUNT(*)` SQL query in `validatorClass::dbValidateArray()` without a proper API for avoiding SQL injection
		
			
				
	
	
		
			425 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			425 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| 
 | |
| 	/**
 | |
| 	 * Used for rendering content via the theme tablestyle() method.
 | |
| 	 * Previously known as 'e107table'
 | |
| 	 * @package e107
 | |
| 	 */
 | |
| 	class e_render
 | |
| 	{
 | |
| 
 | |
| 		public  $eMenuCount   = 0;
 | |
| 		public  $eMenuArea;
 | |
| 		public  $eMenuTotal   = array();
 | |
| 		public  $eSetStyle;
 | |
| 		private $themeClass   = 'theme';  // v2.3.0+
 | |
| 		private $legacyThemeClass;
 | |
| 		private $adminThemeClass;
 | |
| 		public  $adminarea    = false;
 | |
| 		private $uniqueId     = null;
 | |
| 		private $content      = array();
 | |
| 		private $contentTypes = array('header', 'footer', 'text', 'title', 'image', 'list');
 | |
| 		private $mainRenders  = array(); // all renderered with style = 'default' or 'main'.
 | |
| 		private $styleCount   = array();
 | |
| 		private $thm;
 | |
| 
 | |
| 
 | |
| 		public function _init($adminarea=false)
 | |
| 		{
 | |
| 			$this->adminarea = (bool) $adminarea;
 | |
| 
 | |
| 			$this->legacyThemeClass = e107::getPref('sitetheme') . '_theme'; // disabled at the moment.
 | |
| 			$this->adminThemeClass = e107::getPref('admintheme') . '_admintheme';    // Check for a class.
 | |
| 
 | |
| 			$this->load();
 | |
| 		}
 | |
| 
 | |
| 		// Called in header_default.php.
 | |
| 		public function init()
 | |
| 		{
 | |
| 
 | |
| 			if(empty($this->thm) || !method_exists($this->thm, 'init'))
 | |
| 			{
 | |
| 				if(deftrue('FONTAWESOME'))
 | |
| 				{
 | |
| 					e107::getParser()->setFontAwesome(FONTAWESOME);
 | |
| 				}
 | |
| 				if(deftrue('BOOTSTRAP'))
 | |
| 				{
 | |
| 					e107::getParser()->setBootstrap(BOOTSTRAP);
 | |
| 				}
 | |
| 				return null;
 | |
| 			}
 | |
| 
 | |
| 			ob_start(); // don't allow init() to echo.
 | |
| 			$this->thm->init();
 | |
| 			ob_end_clean();
 | |
| 		}
 | |
| 
 | |
| 		/**
 | |
| 		 * Load theme class if necessary.
 | |
| 		 *
 | |
| 		 * @return null
 | |
| 		 */
 | |
| 		private function load()
 | |
| 		{
 | |
| 
 | |
| 			if(!empty($this->thm))
 | |
| 			{
 | |
| 				return null;
 | |
| 			}
 | |
| 
 | |
| 			if(($this->adminarea === true))
 | |
| 			{
 | |
| 				/** @var e_theme_render $thm */
 | |
| 
 | |
| 				if(class_exists($this->adminThemeClass))
 | |
| 				{
 | |
| 					$this->thm = new $this->adminThemeClass();
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					echo "<h3>COULDN'T FIND ".$this->adminThemeClass." CLASS</h3>";
 | |
| 				}
 | |
| 
 | |
| 			}
 | |
| 			elseif(class_exists($this->themeClass)) // v2.3.0+
 | |
| 			{
 | |
| 
 | |
| 				if(ADMIN && $this->hasLegacyCode()) // debug - no translation needed.
 | |
| 				{
 | |
| 					echo "<div class='alert alert-danger'>Please place all theme code inside the <b>theme</b> class. </div>";
 | |
| 				}
 | |
| 
 | |
| 				/** @var e_theme_render $thm */
 | |
| 				$this->thm = new $this->themeClass();
 | |
| 
 | |
| 				if(ADMIN && !$this->thm instanceof e_theme_render)
 | |
| 				{
 | |
| 					// debug - no need to translate.
 | |
| 					echo "<div class='alert alert-danger'>class <b>" . $this->themeClass . "</b> is missing 'implements e_theme_render'. Make sure there is an init() method also!</div>";
 | |
| 				}
 | |
| 			}
 | |
| 			elseif(class_exists($this->legacyThemeClass)) // legacy v2.x
 | |
| 			{
 | |
| 				/** @var e_theme_render $thm */
 | |
| 				$this->thm = new $this->legacyThemeClass();
 | |
| 			}
 | |
| 
 | |
| 			return null;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Return content options for the main render that uses {SETSTYLE=default} or {SETSTYLE=main}
 | |
| 		 *
 | |
| 		 * @return array
 | |
| 		 */
 | |
| 		private function getMainRender()
 | |
| 		{
 | |
| 
 | |
| 			if(isset($this->mainRenders[0]))
 | |
| 			{
 | |
| 				return $this->mainRenders[0];
 | |
| 			}
 | |
| 
 | |
| 			return array();
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Return the first caption rendered with {SETSTYLE=default} or {SETSTYLE=main}
 | |
| 		 *
 | |
| 		 * @return string|null
 | |
| 		 */
 | |
| 		public function getMainCaption()
 | |
| 		{
 | |
| 
 | |
| 			if(isset($this->mainRenders[0]['caption']))
 | |
| 			{
 | |
| 				return $this->mainRenders[0]['caption'];
 | |
| 			}
 | |
| 
 | |
| 			return null;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		function getMagicShortcodes()
 | |
| 		{
 | |
| 
 | |
| 			$ret = array();
 | |
| 
 | |
| 			$val = $this->getMainRender();
 | |
| 
 | |
| 			$types = array('caption') + $this->contentTypes;
 | |
| 
 | |
| 			foreach($types as $var)
 | |
| 			{
 | |
| 				$sc = '{---' . strtoupper($var) . '---}';
 | |
| 				$ret[$sc] = isset($val[$var]) ? (string) $val[$var] : null;
 | |
| 			}
 | |
| 
 | |
| 			if($tmp = e107::callMethod('theme_shortcodes', 'sc_caption', varset($val['caption'])))
 | |
| 			{
 | |
| 				$ret['{---CAPTION---}'] = $tmp;
 | |
| 			}
 | |
| 
 | |
| 			$bread = e107::breadcrumb();
 | |
| 
 | |
| 			if($tmp = e107::callMethod('theme_shortcodes', 'sc_breadcrumb', $bread))
 | |
| 			{
 | |
| 				$ret['{---BREADCRUMB---}'] = $tmp;
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				$ret['{---BREADCRUMB---}'] = e107::getForm()->breadcrumb($bread, true);
 | |
| 			}
 | |
| 
 | |
| 			return $ret;
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		/**
 | |
| 		 * Set the style mode for use in tablestyle() method/function
 | |
| 		 *
 | |
| 		 * @param string $style
 | |
| 		 */
 | |
| 		public function setStyle($style)
 | |
| 		{
 | |
| 
 | |
| 			$this->eSetStyle = (string) $style;
 | |
| 		}
 | |
| 
 | |
| 		/**
 | |
| 		 * Set a unique id for use in tablestyle() method/function
 | |
| 		 *
 | |
| 		 * @param string $id
 | |
| 		 * @return e_render
 | |
| 		 */
 | |
| 		public function setUniqueId($id)
 | |
| 		{
 | |
| 
 | |
| 			$this->uniqueId = !empty($id) ? eHelper::dasherize($id) : null;
 | |
| 
 | |
| 			return $this;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Set Advanced Page/Menu content (beyond just $caption and $text)
 | |
| 		 *
 | |
| 		 * @param string|array $type header|footer|text|title|image|list
 | |
| 		 * @param string       $val
 | |
| 		 * @return bool|e_render
 | |
| 		 */
 | |
| 		public function setContent($type, $val)
 | |
| 		{
 | |
| 
 | |
| 			if(is_array($type))
 | |
| 			{
 | |
| 				foreach($this->contentTypes as $t)
 | |
| 				{
 | |
| 					$this->content[$t] = (string) $type[$t];
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			if(!in_array($type, $this->contentTypes, true))
 | |
| 			{
 | |
| 				return false;
 | |
| 			}
 | |
| 
 | |
| 			if($this->uniqueId !== null)
 | |
| 			{
 | |
| 				$key = $this->uniqueId;
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				$key = '_generic_';
 | |
| 				e107::getDebug()->log("Possible issue: Missing a Unique Tablerender ID. Use \$ns->setUniqueId() in the plugin script prior to setContent(). See 'source code' for more information."); // debug only, no LAN.
 | |
| 			}
 | |
| 
 | |
| 			$this->content[$key][$type] = (string) $val;
 | |
| 
 | |
| 			return $this;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Return the value of custom content
 | |
| 		 *
 | |
| 		 * @param string $type header|footer|text|title|image|list
 | |
| 		 * @return array
 | |
| 		 */
 | |
| 		public function getContent($type = '')
 | |
| 		{
 | |
| 
 | |
| 			$key = ($this->uniqueId !== null) ? $this->uniqueId : '_generic_';
 | |
| 
 | |
| 			if(empty($type))
 | |
| 			{
 | |
| 				return $this->content[$key];
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			return $this->content[$key][$type];
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Return the current value of {SETSTYLE}
 | |
| 		 *
 | |
| 		 * @return mixed
 | |
| 		 */
 | |
| 		public function getStyle()
 | |
| 		{
 | |
| 
 | |
| 			return $this->eSetStyle;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Return the currenty set uniqueId.
 | |
| 		 *
 | |
| 		 * @return mixed
 | |
| 		 */
 | |
| 		public function getUniqueId()
 | |
| 		{
 | |
| 
 | |
| 			return $this->uniqueId;
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * @param string  $caption caption text
 | |
| 		 * @param string  $text
 | |
| 		 * @param string  $mode    unique identifier
 | |
| 		 * @param boolean $return  : return the html instead of echo it.
 | |
| 		 * @return null
 | |
| 		 */
 | |
| 		public function tablerender($caption, $text, $mode = 'default', $return = false)
 | |
| 		{
 | |
| 
 | |
| 			$override_tablerender = e107::getSingleton('override', e_HANDLER . 'override_class.php')->override_check('tablerender');
 | |
| 
 | |
| 			if($override_tablerender)
 | |
| 			{
 | |
| 				$result = $override_tablerender($caption, $text, $mode, $return);
 | |
| 
 | |
| 				if($result === 'return')
 | |
| 				{
 | |
| 					return '';
 | |
| 				}
 | |
| 				extract($result);
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 			if($return)
 | |
| 			{
 | |
| 				if(!empty($text) && $this->eMenuArea)
 | |
| 				{
 | |
| 					$this->eMenuCount++;
 | |
| 				}
 | |
| 
 | |
| 				ob_start();
 | |
| 				$this->tablestyle($caption, $text, $mode);
 | |
| 
 | |
| 				return ob_get_clean();
 | |
| 
 | |
| 			}
 | |
| 
 | |
| 			if(!empty($text) && $this->eMenuArea)
 | |
| 			{
 | |
| 				$this->eMenuCount++;
 | |
| 			}
 | |
| 
 | |
| 			$this->tablestyle($caption, $text, $mode);
 | |
| 
 | |
| 			return '';
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		private function hasLegacyCode()
 | |
| 		{
 | |
| 
 | |
| 			$legacy = ['VIEWPORT', 'THEME_DISCLAIMER', 'IMODE', 'HTMLTAG', 'BODYTAG', 'COMMENTLINK', 'OTHERNEWS_LIMIT',
 | |
| 				'PRE_EXTENDEDSTRING', 'COMMENTOFFSTRING', 'CORE_CSS', 'TRACKBACKSTRING', 'TRACKBACKBEFORESTRING'];
 | |
| 
 | |
| 			foreach($legacy as $const)
 | |
| 			{
 | |
| 				if(defined($const))
 | |
| 				{
 | |
| 					return true;
 | |
| 				}
 | |
| 			}
 | |
| 
 | |
| 			return false;
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		/**
 | |
| 		 * Output the styled template.
 | |
| 		 *
 | |
| 		 * @param $caption
 | |
| 		 * @param $text
 | |
| 		 * @param $mode
 | |
| 		 */
 | |
| 		private function tablestyle($caption, $text, $mode)
 | |
| 		{
 | |
| 			$text = (string) $text;
 | |
| 
 | |
| 			// Automatic list detection .
 | |
| 			$isList = (strncmp(ltrim($text), '<ul', 3) === 0);
 | |
| 			$this->setContent('list', $isList);
 | |
| 
 | |
| 			$options = $this->getContent();
 | |
| 
 | |
| 			$options['uniqueId'] = (string) $this->uniqueId;
 | |
| 			$options['menuArea'] = (int) $this->eMenuArea;
 | |
| 			$options['menuCount'] = (int) $this->eMenuCount;
 | |
| 			$options['menuTotal'] = (int) varset($this->eMenuTotal[$this->eMenuArea]);
 | |
| 			$options['setStyle'] = (string) $this->eSetStyle;
 | |
| 
 | |
| 			$options['caption'] = e107::getParser()->toText($caption);
 | |
| 
 | |
| 			if($this->eSetStyle === 'default' || $this->eSetStyle === 'main')
 | |
| 			{
 | |
| 				$this->mainRenders[] = $options;
 | |
| 			}
 | |
| 
 | |
| 			if(!empty($this->eSetStyle))
 | |
| 			{
 | |
| 				if(!isset($this->styleCount[$this->eSetStyle]))
 | |
| 				{
 | |
| 					$this->styleCount[$this->eSetStyle] = 0;
 | |
| 				}
 | |
| 
 | |
| 				$this->styleCount[$this->eSetStyle]++;
 | |
| 			}
 | |
| 
 | |
| 			$options['styleCount'] = varset($this->styleCount[$this->eSetStyle]);
 | |
| 
 | |
| 
 | |
| 			//XXX Optional feature may be added if needed - define magic shortcodes inside $thm class. eg. function msc_custom();
 | |
| 
 | |
| 			if(!empty($this->thm) && is_object($this->thm))
 | |
| 			{
 | |
| 				$this->thm->tablestyle($caption, $text, $mode, $options);
 | |
| 			}
 | |
| 			elseif(function_exists('tablestyle'))
 | |
| 			{
 | |
| 				tablestyle($caption, $text, $mode, $options);
 | |
| 			}
 | |
| 
 | |
| 			$key = ($this->uniqueId !== null) ? $this->uniqueId : '_generic_';
 | |
| 			$this->content[$key] = array();
 | |
| 			$this->uniqueId = null;
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 	} |