Vergleich inc/class_parser.php - 1.2.0 - 1.2.2

  Keine Änderungen   Hinzugefügt   Modifiziert   Entfernt
Zeile 6Zeile 6
 * Website: http://www.mybboard.com
* License: http://www.mybboard.com/eula.html
*

 * Website: http://www.mybboard.com
* License: http://www.mybboard.com/eula.html
*

 * $Id: class_parser.php 2190 2006-09-02 21:33:01Z Tikitiki $

 * $Id: class_parser.php 2447 2006-11-27 04:18:13Z CraKteR $

 */

/*

 */

/*

Zeile 93Zeile 93
			$message = $this->parse_badwords($message);
}


			$message = $this->parse_badwords($message);
}


 
		if($options['allow_html'] != "yes")
{
$message = $this->parse_html($message);
}
else
{
// Strip out any script tags if HTML is enabled
if($options['allow_html'] == "yes")
{
while(preg_match("#<script(.*)>(.*)</script(.*)>#is", $message))
{
$message = preg_replace("#<script(.*)>(.*)</script(.*)>#is", "&lt;script$1&gt;$2&lt;/script$3&gt;", $message);
}
$message = preg_replace("#<base(.*)>#is", "&lt;base$1&gt;", $message);
$message = preg_replace("#<meta(.*)>#is", "&lt;meta$1&gt;", $message);
$message = str_replace(array('<?php', '<!--', '-->', '?>'), array('&lt;?php', '&lt;!--', '--&gt;', '?&gt;'), $message);
}
}


		// If MyCode needs to be replaced, first filter out [code] and [php] tags.
if($options['allow_mycode'] != "no")
{

		// If MyCode needs to be replaced, first filter out [code] and [php] tags.
if($options['allow_mycode'] != "no")
{

Zeile 100Zeile 119
			preg_match_all("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", $message, $code_matches, PREG_SET_ORDER);
$message = preg_replace("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", "{{mybb-code}}\n", $message);
}

			preg_match_all("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", $message, $code_matches, PREG_SET_ORDER);
$message = preg_replace("#\[(code|php)\](.*?)\[/\\1\](\r\n?|\n?)#si", "{{mybb-code}}\n", $message);
}


if($options['allow_html'] != "yes")
{
$message = $this->parse_html($message);
}



// Always fix bad Javascript in the message.
$message = $this->fix_javascript($message);




		// If we can, parse smiliesa
if($options['allow_smilies'] != "no")
{

		// If we can, parse smiliesa
if($options['allow_smilies'] != "no")
{

Zeile 118Zeile 135
			$message = $this->parse_mycode($message, $options);
}


			$message = $this->parse_mycode($message, $options);
}


		// Strip out any script tags if HTML is enabled
if($options['allow_html'] == "yes")
{
while(preg_match("#<script(.*)>(.*)</script(.*)>#is", $message))
{
$message = preg_replace("#<script(.*)>(.*)</script(.*)>#is", "&lt;script$1&gt;$2&lt;/script$3&gt;", $message);
}
$message = preg_replace("#<base(.*)>#is", "&lt;base$1&gt", $message);
$message = preg_replace("#<meta(.*)>#is", "&lt;meta$1&gt", $message);
}

 
		// Run plugin hooks
$message = $plugins->run_hooks("parse_message", $message);


		// Run plugin hooks
$message = $plugins->run_hooks("parse_message", $message);


Zeile 139Zeile 146
				foreach($code_matches as $text)
{
// Fix up HTML inside the code tags so it is clean

				foreach($code_matches as $text)
{
// Fix up HTML inside the code tags so it is clean

					$text[2] = $this->parse_html($text[2]);




					if($options['allow_html'] != "no")
{
$text[2] = $this->parse_html($text[2]);
}

					
if(strtolower($text[1]) == "code")
{

					
if(strtolower($text[1]) == "code")
{

Zeile 158Zeile 168
		{
$message = nl2br($message);
$message = str_replace("</div><br />", "</div>", $message);

		{
$message = nl2br($message);
$message = str_replace("</div><br />", "</div>", $message);

 
			$message = preg_replace("#<(/?)p>\s*(<br />?)#", "<$1p>", $message);

		}

		}

		// Always fix bad Javascript in the message.
$message = $this->fix_javascript($message);


	



		$message = my_wordwrap($message);

$message = str_replace(" ", "&nbsp;&nbsp;", $message);

		$message = my_wordwrap($message);

$message = str_replace(" ", "&nbsp;&nbsp;", $message);

Zeile 241Zeile 250
		$standard_mycode['size']['replacement'] = "<span style=\"font-size: $1;\">$2</span>";

$standard_mycode['size_int']['regex'] = "#\[size=([0-9\+\-]+?)\](.*?)\[/size\]#si";

		$standard_mycode['size']['replacement'] = "<span style=\"font-size: $1;\">$2</span>";

$standard_mycode['size_int']['regex'] = "#\[size=([0-9\+\-]+?)\](.*?)\[/size\]#si";

		$standard_mycode['size_int']['replacement'] = "<font size=\"$1\">$2</font>";

		$standard_mycode['size_int']['replacement'] = "<span style=\"font-size: $1em;\">$2</span>";


$standard_mycode['font']['regex'] = "#\[font=([a-z ]+?)\](.+?)\[/font\]#si";
$standard_mycode['font']['replacement'] = "<span style=\"font-family: $1;\">$2</span>";


$standard_mycode['font']['regex'] = "#\[font=([a-z ]+?)\](.+?)\[/font\]#si";
$standard_mycode['font']['replacement'] = "<span style=\"font-family: $1;\">$2</span>";

Zeile 262Zeile 271
				$custom_mycode[$key]['regex'] = "#".$mycode['regex']."#si";
}
$mycode = array_merge($standard_mycode, $custom_mycode);

				$custom_mycode[$key]['regex'] = "#".$mycode['regex']."#si";
}
$mycode = array_merge($standard_mycode, $custom_mycode);

		}
else

		}
else

		{
$mycode = $standard_mycode;
}

// Assign the MyCode to the cache.
foreach($mycode as $code)

		{
$mycode = $standard_mycode;
}

// Assign the MyCode to the cache.
foreach($mycode as $code)

		{

		{

			$this->mycode_cache['find'][] = $code['regex'];
$this->mycode_cache['replacement'][] = $code['replacement'];
}

			$this->mycode_cache['find'][] = $code['regex'];
$this->mycode_cache['replacement'][] = $code['replacement'];
}

Zeile 296Zeile 305
		// Parse quotes first
$message = $this->mycode_parse_quotes($message);


		// Parse quotes first
$message = $this->mycode_parse_quotes($message);


		$message = $this->mycode_auto_url($message);		

		$message = $this->mycode_auto_url($message);





 
		$message = str_replace('$', '&#36;', $message);


		// Replace the rest
$message = preg_replace($this->mycode_cache['find'], $this->mycode_cache['replacement'], $message);


		// Replace the rest
$message = preg_replace($this->mycode_cache['find'], $this->mycode_cache['replacement'], $message);


Zeile 317Zeile 328
		if($options['allow_imgcode'] != "no")
{
$message = preg_replace("#\[img\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$2')\n", $message);

		if($options['allow_imgcode'] != "no")
{
$message = preg_replace("#\[img\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$2')\n", $message);

			$message = preg_replace("#\[img=([0-9]{1,3})x([0-9]{1,3})\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$4', array('$2', '$3'));", $message);
}

			$message = preg_replace("#\[img=([0-9]{1,3})x([0-9]{1,3})\](\r\n?|\n?)(https?://([^<>\"']+?))\[/img\]#ise", "\$this->mycode_parse_img('$4', array('$1', '$2'));", $message);
}


// Replace "me" code and slaps if we have a username
if($options['me_username'])


// Replace "me" code and slaps if we have a username
if($options['me_username'])

Zeile 341Zeile 352
		$this->smilies_cache = array();

$smilies = $cache->read("smilies");

		$this->smilies_cache = array();

$smilies = $cache->read("smilies");

		foreach($smilies as $sid => $smilie)
{
$this->smilies_cache[$smilie['find']] = "<img src=\"{$this->base_url}{$smilie['image']}\" style=\"vertical-align: middle;\" border=\"0\" alt=\"{$smilie['name']}\" title=\"{$smilie['name']}\" />";
}




		if(is_array($smilies))
{
foreach($smilies as $sid => $smilie)
{
$this->smilies_cache[$smilie['find']] = "<img src=\"{$this->base_url}{$smilie['image']}\" style=\"vertical-align: middle;\" border=\"0\" alt=\"{$smilie['name']}\" title=\"{$smilie['name']}\" />";
}
}

	}

/**

	}

/**

Zeile 371Zeile 385
					$find = $this->parse_html($find);
}
$message = str_replace($find, $replace, $message);

					$find = $this->parse_html($find);
}
$message = str_replace($find, $replace, $message);

			}
}
return $message;
}

			}
}
return $message;
}


/**
* Generates a cache of badwords filters.


/**
* Generates a cache of badwords filters.

Zeile 386Zeile 400
		global $cache;
$this->badwords_cache = array();
$this->badwords_cache = $cache->read("badwords");

		global $cache;
$this->badwords_cache = array();
$this->badwords_cache = $cache->read("badwords");

	}

/**

	}

/**

	 * Parses a list of filtered/badwords in the specified message.
*
* @param string The message to be parsed.

	 * Parses a list of filtered/badwords in the specified message.
*
* @param string The message to be parsed.

Zeile 408Zeile 422
			{
if(!$badword['replacement']) $badword['replacement'] = "*****";
$badword['badword'] = preg_quote($badword['badword']);

			{
if(!$badword['replacement']) $badword['replacement'] = "*****";
$badword['badword'] = preg_quote($badword['badword']);

				$message = preg_replace("#\b".$badword['badword']."\b#i", $badword['replacement'], $message);

				$message = preg_replace("#(\W|^)".$badword['badword']."(\W|$)#i", "\\1".$badword['replacement']."\\2", $message);

			}
}
if($options['strip_tags'] == "yes")

			}
}
if($options['strip_tags'] == "yes")

Zeile 427Zeile 441
	function fix_javascript($message)
{
$js_array = array(

	function fix_javascript($message)
{
$js_array = array(

			"#(j)(avascript)#i",
"#(a)(lert)#i",
"#(o)(nmouseover)#i",
"#(o)(nmouseout)#i",
"#(o)(nmousedown)#i",
"#(o)(nmousemove)#i",
"#(o)(nmouseup)#i",
"#(o)(nclick)#i",
"#(o)(ndblclick)#i",
"#(o)(nload)#i",
"#(o)(nsubmit)#i",
"#(o)(nblur)#i",
"#(o)(nchange)#i",
"#(o)(nfocus)#i",
"#(o)(nselect)#i",
"#(o)(nunload)#i",
"#(o)(nkeypress)#i"
);

			"#(j)(avascript\:)#i",
"#(o)(nmouseover\s?=)#i",
"#(o)(nmouseout\s?=)#i",
"#(o)(nmousedown\s?=)#i",
"#(o)(nmousemove\s?=)#i",
"#(o)(nmouseup\s?=)#i",
"#(o)(nclick\s?=)#i",
"#(o)(ndblclick\s?=)#i",
"#(o)(nload\s?=)#i",
"#(o)(nsubmit\s?=)#i",
"#(o)(nblur\s?=)#i",
"#(o)(nchange\s?=)#i",
"#(o)(nfocus\s?=)#i",
"#(o)(nselect\s?=)#i",
"#(o)(nunload\s?=)#i",
"#(o)(nkeypress\s?=)#i"
);


		$message = preg_replace($js_array, "$1<strong></strong>$2", $message);

		$message = preg_replace($js_array, "$1<strong></strong>$2", $message);

		return $message;



return $message;

	}

/**

	}

/**

Zeile 462Zeile 476
		// Assign pattern and replace values.
$pattern = array("#\[quote=(?:&quot;|\"|')?(.*?)[\"']?(?:&quot;|\"|')?\](.*?)\[\/quote\](\r\n?|\n?)#si",
"#\[quote\](.*?)\[\/quote\](\r\n?|\n?)#si");

		// Assign pattern and replace values.
$pattern = array("#\[quote=(?:&quot;|\"|')?(.*?)[\"']?(?:&quot;|\"|')?\](.*?)\[\/quote\](\r\n?|\n?)#si",
"#\[quote\](.*?)\[\/quote\](\r\n?|\n?)#si");

 
						 





		$replace = array("<div class=\"quote_header\">".htmlentities('\\1')." $lang->wrote\n</div><div class=\"quote_body\">$2</div>\n",
"<div class=\"quote_header\">$lang->quote\n</div><div class=\"quote_body\">$1</div>\n");

		$replace = array("</p>\n<div class=\"quote_header\">".htmlentities('\\1')." $lang->wrote\n</div><div class=\"quote_body\">$2</div>\n<p>\n",
"</p>\n<div class=\"quote_header\">$lang->quote\n</div><div class=\"quote_body\">$1</div>\n<p>\n");


while(preg_match($pattern[0], $message) or preg_match($pattern[1], $message))
{


while(preg_match($pattern[0], $message) or preg_match($pattern[1], $message))
{

Zeile 494Zeile 509
	{
global $lang;
$code = trim($code);

	{
global $lang;
$code = trim($code);

		return "<div class=\"code_header\">".$lang->code."\n</div><div class=\"code_body\"><div dir=\"ltr\"><code>".$code."</code></div></div>\n";


		$code = preg_replace('#\$([0-9])#', '\\\$\\1', $code);
return "</p>\n<div class=\"code_header\">".$lang->code."\n</div><div class=\"code_body\"><div dir=\"ltr\"><code>".$code."</code></div></div>\n<p>\n";

	}

/**

	}

/**

Zeile 513Zeile 529
		{
return;
}

		{
return;
}

 
		$str = str_replace('&amp;', '&', $str);

		$str = str_replace('&lt;', '<', $str);
$str = str_replace('&gt;', '>', $str);

		$str = str_replace('&lt;', '<', $str);
$str = str_replace('&gt;', '>', $str);

		$str = str_replace('&amp;', '&', $str);

 
		$original = $str;

		$original = $str;

 


		// See if open and close tags are provided.

		// See if open and close tags are provided.

		$added_open_close = false;

		$added_open_tag = false;

		if(!preg_match("#^\s*<\?#si", $str))
{

		if(!preg_match("#^\s*<\?#si", $str))
{

			$added_open_close = true;
$str = "<?php \n".$str." \n?>";








			$added_open_tag = true;
$str = "<?php \n".$str;
}

$added_end_tag = false;
if(!preg_match("#\?>\s*$#si", $str))
{
$added_end_tag = true;
$str = $str." \n?>";

		}
// If the PHP version < 4.2, catch highlight_string() output.
if(version_compare(PHP_VERSION, "4.2.0", "<"))

		}
// If the PHP version < 4.2, catch highlight_string() output.
if(version_compare(PHP_VERSION, "4.2.0", "<"))

		{

		{

			ob_start();
@highlight_string($str);
$code = ob_get_contents();

			ob_start();
@highlight_string($str);
$code = ob_get_contents();

Zeile 543Zeile 567
				"<font",
"color=\"",
"</font>"

				"<font",
"color=\"",
"</font>"

			);

			);


$replace = array(
"<span",


$replace = array(
"<span",

Zeile 561Zeile 585
		$code = preg_replace("#&amp;\#([0-9]+);#si", "&#$1;", $code);



		$code = preg_replace("#&amp;\#([0-9]+);#si", "&#$1;", $code);



		if($added_open_close == true)






		if($added_open_tag)
{
$code = preg_replace("#<code><span style=\"color: \#([A-Z0-9]{6})\">&lt;\?php( |&nbsp;)(<br />?)#", "<code><span style=\"color: #$1\">", $code);
}

if($added_end_tag)

		{

		{

			$code = preg_replace("#<code><span style=\"color: \#0000BB\">&lt;\?php( |&nbsp;)(<br />?)#", "<code><span style=\"color: #0000BB\">", $code);

 
			$code = str_replace("?&gt;</span></code>", "</span></code>", $code);
}


			$code = str_replace("?&gt;</span></code>", "</span></code>", $code);
}


 
		$code = preg_replace("#<span style=\"color: \#([A-Z0-9]{6})\"></span>#", "", $code);

		$code = str_replace("<code>", "<div dir=\"ltr\"><code>", $code);
$code = str_replace("</code>", "</code></div>", $code);

		$code = str_replace("<code>", "<div dir=\"ltr\"><code>", $code);
$code = str_replace("</code>", "</code></div>", $code);

		$code = preg_replace("#\s*$#", "", $code);


		$code = preg_replace("# *$#", "", $code);
$code = preg_replace('#\$([0-9])#', '\\\$\\1', $code);


// Send back the code all nice and pretty


// Send back the code all nice and pretty

		return "<div class=\"code_header\">$lang->php_code\n</div><div class=\"code_body\">".$code."</div>\n";

		return "</p>\n<div class=\"code_header\">$lang->php_code\n</div><div class=\"code_body\">".$code."</div>\n<p>\n";

	}

/**

	}

/**

Zeile 612Zeile 642
			}
}


			}
}


		$name = preg_replace("#&amp;\#([0-9]+);#si", "&#$1;", $name);
$name = preg_replace("#&(?!\#[0-9]+;)#si", "&amp;", $name); // Fix & but allow unicode

		$name = preg_replace("#&amp;\#([0-9]+);#si", "&#$1;", $name); // Fix & but allow unicode		


		$link = "<a href=\"$fullurl\" target=\"_blank\">$name</a>";
return $link;
}

		$link = "<a href=\"$fullurl\" target=\"_blank\">$name</a>";
return $link;
}

Zeile 631Zeile 660
		$url = str_replace("\r", "", $url);
if($dimensions[0] > 0 && $dimensions[1] > 0)
{

		$url = str_replace("\r", "", $url);
if($dimensions[0] > 0 && $dimensions[1] > 0)
{

			return "<img src=\"{$url}\" width=\"{$dimensions[0]}\" height=\{$dimensions[1]}\" border=\"0\" alt=\"\" />";

			return "<img src=\"{$url}\" width=\"{$dimensions[0]}\" height=\"{$dimensions[1]}\" border=\"0\" alt=\"\" />";

		}
else
{

		}
else
{

Zeile 691Zeile 720

if($type)
{


if($type)
{

			$list = "<ol type=\"$type\">$message</ol>";

			$list = "</p>\n<ol type=\"$type\">$message</ol>\n<p>";

		}
else
{

		}
else
{

			$list = "<ul>$message</ul>";

			$list = "</p>\n<ul>$message</ul>\n</p>";

		}
$list = preg_replace("#<(ol type=\"$type\"|ul)>\s*</li>#", "<$1>", $list);
return $list;

		}
$list = preg_replace("#<(ol type=\"$type\"|ul)>\s*</li>#", "<$1>", $list);
return $list;