Zeile 6 | Zeile 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 93 | Zeile 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", "<script$1>$2</script$3>", $message); } $message = preg_replace("#<base(.*)>#is", "<base$1>", $message); $message = preg_replace("#<meta(.*)>#is", "<meta$1>", $message); $message = str_replace(array('<?php', '<!--', '-->', '?>'), array('<?php', '<!--', '-->', '?>'), $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 100 | Zeile 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 118 | Zeile 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", "<script$1>$2</script$3>", $message); } $message = preg_replace("#<base(.*)>#is", "<base$1>", $message); $message = preg_replace("#<meta(.*)>#is", "<meta$1>", $message); }
| |
// Run plugin hooks $message = $plugins->run_hooks("parse_message", $message);
| // Run plugin hooks $message = $plugins->run_hooks("parse_message", $message);
|
Zeile 139 | Zeile 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 158 | Zeile 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(" ", " ", $message);
| $message = my_wordwrap($message); $message = str_replace(" ", " ", $message);
|
Zeile 241 | Zeile 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 262 | Zeile 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 296 | Zeile 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('$', '$', $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 317 | Zeile 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 341 | Zeile 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 371 | Zeile 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 386 | Zeile 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 408 | Zeile 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 427 | Zeile 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 462 | Zeile 476 |
---|
// Assign pattern and replace values. $pattern = array("#\[quote=(?:"|\"|')?(.*?)[\"']?(?:"|\"|')?\](.*?)\[\/quote\](\r\n?|\n?)#si", "#\[quote\](.*?)\[\/quote\](\r\n?|\n?)#si");
|
// Assign pattern and replace values. $pattern = array("#\[quote=(?:"|\"|')?(.*?)[\"']?(?:"|\"|')?\](.*?)\[\/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 494 | Zeile 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 513 | Zeile 529 |
---|
{ return; }
|
{ return; }
|
| $str = str_replace('&', '&', $str);
|
$str = str_replace('<', '<', $str); $str = str_replace('>', '>', $str);
|
$str = str_replace('<', '<', $str); $str = str_replace('>', '>', $str);
|
$str = str_replace('&', '&', $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 543 | Zeile 567 |
---|
"<font", "color=\"", "</font>"
|
"<font", "color=\"", "</font>"
|
);
| );
|
$replace = array( "<span",
| $replace = array( "<span",
|
Zeile 561 | Zeile 585 |
---|
$code = preg_replace("#&\#([0-9]+);#si", "&#$1;", $code);
|
$code = preg_replace("#&\#([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})\"><\?php( | )(<br />?)#", "<code><span style=\"color: #$1\">", $code); }
if($added_end_tag)
|
{
|
{
|
$code = preg_replace("#<code><span style=\"color: \#0000BB\"><\?php( | )(<br />?)#", "<code><span style=\"color: #0000BB\">", $code);
| |
$code = str_replace("?></span></code>", "</span></code>", $code); }
|
$code = str_replace("?></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 612 | Zeile 642 |
---|
} }
|
} }
|
$name = preg_replace("#&\#([0-9]+);#si", "&#$1;", $name); $name = preg_replace("#&(?!\#[0-9]+;)#si", "&", $name); // Fix & but allow unicode
| $name = preg_replace("#&\#([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 631 | Zeile 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 691 | Zeile 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;
|