Empty commit

This commit is contained in:
Git 2013-04-05 08:00:43 +00:00
parent 337914b0dc
commit f3d8caee38
10 changed files with 140 additions and 92 deletions

View File

@ -2,6 +2,7 @@
class IRC_DB extends DB_MYSQL { class IRC_DB extends DB_MYSQL {
function halt($Msg) { function halt($Msg) {
global $Bot; global $Bot;
global $DB;
$Bot->send_to($Bot->get_channel(),'The database is currently unavailable try again later'); $Bot->send_to($Bot->get_channel(),'The database is currently unavailable try again later');
} }
} }
@ -177,6 +178,25 @@ protected function listen() {
if(isset($this->Identified[$Nick[1]])) { if(isset($this->Identified[$Nick[1]])) {
unset($this->Identified[$Nick[1]]); unset($this->Identified[$Nick[1]]);
} }
if (isset($this->DisabledUsers[$Nick[1]])) {
$DB->query("DELETE FROM disable_list WHERE Nick = '" . $Nick[1] . "'");
unset($this->DisabledUsers[$Nick[1]]);
}
}
if (preg_match("/:([^!]+)![^\s]* PART #what.cd-disabled/", $this->Data, $Nick)) {
if (isset($this->DisabledUsers[$Nick[1]])) {
$DB->query("DELETE FROM disable_list WHERE Nick = '" . $Nick[1] . "'");
unset($this->DisabledUsers[$Nick[1]]);
}
}
if (preg_match("/:([^!]+)![^\s]* KICK #what.cd-disabled.* /", $this->Data, $Nick)) {
if (isset($this->DisabledUsers[$Nick[1]])) {
$Nick = explode(" ", $Nick[0]);
$DB->query("DELETE FROM disable_list WHERE Nick = '" . $Nick[3] . "'");
unset($this->DisabledUsers[$Nick[1]]);
}
} }
if(preg_match("/End of message of the day./", $this->Data)) { if(preg_match("/End of message of the day./", $this->Data)) {

View File

@ -92,7 +92,7 @@ class TEXT {
*/ */
public function __construct ($TOC = false) { public function __construct ($TOC = false) {
$this->TOC = (bool) $TOC; $this->TOC = (bool) $TOC;
foreach($this->Smileys as $Key=>$Val) { foreach ($this->Smileys as $Key=>$Val) {
$this->Smileys[$Key] = '<img border="0" src="'.STATIC_SERVER.'common/smileys/'.$Val.'" alt="" />'; $this->Smileys[$Key] = '<img border="0" src="'.STATIC_SERVER.'common/smileys/'.$Val.'" alt="" />';
} }
reset($this->Smileys); reset($this->Smileys);
@ -166,7 +166,7 @@ private function valid_url ($Str, $Extension = '', $Inline = false) {
$Regex .= '(:[0-9]{1,5})?'; // port $Regex .= '(:[0-9]{1,5})?'; // port
$Regex .= '\/?'; // slash? $Regex .= '\/?'; // slash?
$Regex .= '(\/?[0-9a-z\-_.,&=@~%\/:;()+|!#]+)*'; // /file $Regex .= '(\/?[0-9a-z\-_.,&=@~%\/:;()+|!#]+)*'; // /file
if(!empty($Extension)) { if (!empty($Extension)) {
$Regex.=$Extension; $Regex.=$Extension;
} }
@ -185,16 +185,16 @@ private function valid_url ($Str, $Extension = '', $Inline = false) {
public function local_url ($Str) { public function local_url ($Str) {
$URLInfo = parse_url($Str); $URLInfo = parse_url($Str);
if(!$URLInfo) { return false; } if (!$URLInfo) { return false; }
$Host = $URLInfo['host']; $Host = $URLInfo['host'];
// If for some reason your site does not require subdomains or contains a directory in the SITE_URL, revert to the line below. // If for some reason your site does not require subdomains or contains a directory in the SITE_URL, revert to the line below.
//if($Host == NONSSL_SITE_URL || $Host == SSL_SITE_URL || $Host == 'www.'.NONSSL_SITE_URL) { //if ($Host == NONSSL_SITE_URL || $Host == SSL_SITE_URL || $Host == 'www.'.NONSSL_SITE_URL) {
if(empty($URLInfo['port']) && preg_match('/(\S+\.)*'.NONSSL_SITE_URL.'/', $Host)) { if (empty($URLInfo['port']) && preg_match('/(\S+\.)*'.NONSSL_SITE_URL.'/', $Host)) {
$URL = $URLInfo['path']; $URL = $URLInfo['path'];
if(!empty($URLInfo['query'])) { if (!empty($URLInfo['query'])) {
$URL.='?'.$URLInfo['query']; $URL.='?'.$URLInfo['query'];
} }
if(!empty($URLInfo['fragment'])) { if (!empty($URLInfo['fragment'])) {
$URL.='#'.$URLInfo['fragment']; $URL.='#'.$URLInfo['fragment'];
} }
return $URL; return $URL;
@ -249,7 +249,7 @@ private function parse ($Str) {
$Array = array(); $Array = array();
$ArrayPos = 0; $ArrayPos = 0;
while($i<$Len) { while ($i < $Len) {
$Block = ''; $Block = '';
// 1) Find the next tag (regex) // 1) Find the next tag (regex)
@ -257,7 +257,7 @@ private function parse ($Str) {
$IsTag = preg_match("/((\[[a-zA-Z*#]+)(=(?:[^\n'\"\[\]]|\[\d*\])+)?\])|(\[\[[^\n\"'\[\]]+\]\])/", $Str, $Tag, PREG_OFFSET_CAPTURE, $i); $IsTag = preg_match("/((\[[a-zA-Z*#]+)(=(?:[^\n'\"\[\]]|\[\d*\])+)?\])|(\[\[[^\n\"'\[\]]+\]\])/", $Str, $Tag, PREG_OFFSET_CAPTURE, $i);
// 1a) If there aren't any tags left, write everything remaining to a block // 1a) If there aren't any tags left, write everything remaining to a block
if(!$IsTag) { if (!$IsTag) {
// No more tags // No more tags
$Array[$ArrayPos] = substr($Str, $i); $Array[$ArrayPos] = substr($Str, $i);
break; break;
@ -265,14 +265,14 @@ private function parse ($Str) {
// 1b) If the next tag isn't where the pointer is, write everything up to there to a text block. // 1b) If the next tag isn't where the pointer is, write everything up to there to a text block.
$TagPos = $Tag[0][1]; $TagPos = $Tag[0][1];
if($TagPos>$i) { if ($TagPos > $i) {
$Array[$ArrayPos] = substr($Str, $i, $TagPos-$i); $Array[$ArrayPos] = substr($Str, $i, $TagPos - $i);
++$ArrayPos; ++$ArrayPos;
$i=$TagPos; $i = $TagPos;
} }
// 2) See if it's a [[wiki-link]] or an ordinary tag, and get the tag name // 2) See if it's a [[wiki-link]] or an ordinary tag, and get the tag name
if(!empty($Tag[4][0])) { // Wiki-link if (!empty($Tag[4][0])) { // Wiki-link
$WikiLink = true; $WikiLink = true;
$TagName = substr($Tag[4][0], 2, -2); $TagName = substr($Tag[4][0], 2, -2);
$Attrib = ''; $Attrib = '';
@ -281,9 +281,9 @@ private function parse ($Str) {
$TagName = strtolower(substr($Tag[2][0], 1)); $TagName = strtolower(substr($Tag[2][0], 1));
//3a) check it against the $this->ValidTags array to see if it's actually a tag and not [bullshit] //3a) check it against the $this->ValidTags array to see if it's actually a tag and not [bullshit]
if(!isset($this->ValidTags[$TagName])) { if (!isset($this->ValidTags[$TagName])) {
$Array[$ArrayPos] = substr($Str, $i, ($TagPos-$i)+strlen($Tag[0][0])); $Array[$ArrayPos] = substr($Str, $i, ($TagPos - $i)+strlen($Tag[0][0]));
$i=$TagPos+strlen($Tag[0][0]); $i = $TagPos + strlen($Tag[0][0]);
++$ArrayPos; ++$ArrayPos;
continue; continue;
} }
@ -291,7 +291,7 @@ private function parse ($Str) {
$MaxAttribs = $this->ValidTags[$TagName]; $MaxAttribs = $this->ValidTags[$TagName];
// 3b) Get the attribute, if it exists [name=attribute] // 3b) Get the attribute, if it exists [name=attribute]
if(!empty($Tag[3][0])) { if (!empty($Tag[3][0])) {
$Attrib = substr($Tag[3][0], 1); $Attrib = substr($Tag[3][0], 1);
} else { } else {
$Attrib=''; $Attrib='';
@ -309,21 +309,21 @@ private function parse ($Str) {
//5a) Different for different types of tag. Some tags don't close, others are weird like [*] //5a) Different for different types of tag. Some tags don't close, others are weird like [*]
if($TagName == 'img' && !empty($Tag[3][0])) { //[img=...] if ($TagName == 'img' && !empty($Tag[3][0])) { //[img=...]
$Block = ''; // Nothing inside this tag $Block = ''; // Nothing inside this tag
// Don't need to touch $i // Don't need to touch $i
} elseif($TagName == 'inlineurl') { // We did a big replace early on to turn http:// into [inlineurl]http:// } elseif ($TagName == 'inlineurl') { // We did a big replace early on to turn http:// into [inlineurl]http://
// Let's say the block can stop at a newline or a space // Let's say the block can stop at a newline or a space
$CloseTag = strcspn($Str, " \n\r", $i); $CloseTag = strcspn($Str, " \n\r", $i);
if($CloseTag === false) { // block finishes with URL if ($CloseTag === false) { // block finishes with URL
$CloseTag = $Len; $CloseTag = $Len;
} }
if(preg_match('/[!,.?:]+$/',substr($Str, $i, $CloseTag), $Match)) { if (preg_match('/[!,.?:]+$/',substr($Str, $i, $CloseTag), $Match)) {
$CloseTag -= strlen($Match[0]); $CloseTag -= strlen($Match[0]);
} }
$URL = substr($Str, $i, $CloseTag); $URL = substr($Str, $i, $CloseTag);
if(substr($URL, -1) == ')' && substr_count($URL, '(') < substr_count($URL, ')')) { if (substr($URL, -1) == ')' && substr_count($URL, '(') < substr_count($URL, ')')) {
$CloseTag--; $CloseTag--;
$URL = substr($URL, 0, -1); $URL = substr($URL, 0, -1);
} }
@ -332,17 +332,17 @@ private function parse ($Str) {
// strcspn returns the number of characters after the offset $i, not after the beginning of the string // strcspn returns the number of characters after the offset $i, not after the beginning of the string
// Therefore, we use += instead of the = everywhere else // Therefore, we use += instead of the = everywhere else
$i += $CloseTag; // 5d) Move the pointer past the end of the [/close] tag. $i += $CloseTag; // 5d) Move the pointer past the end of the [/close] tag.
} elseif($WikiLink == true || $TagName == 'n') { } elseif ($WikiLink == true || $TagName == 'n') {
// Don't need to do anything - empty tag with no closing // Don't need to do anything - empty tag with no closing
} elseif($TagName === '*' || $TagName === '#') { } elseif ($TagName === '*' || $TagName === '#') {
// We're in a list. Find where it ends // We're in a list. Find where it ends
$NewLine = $i; $NewLine = $i;
do { // Look for \n[*] do { // Look for \n[*]
$NewLine = strpos($Str, "\n", $NewLine+1); $NewLine = strpos($Str, "\n", $NewLine+1);
} while($NewLine!== false && substr($Str, $NewLine+1, 3) == '['.$TagName.']'); } while ($NewLine!== false && substr($Str, $NewLine+1, 3) == '['.$TagName.']');
$CloseTag = $NewLine; $CloseTag = $NewLine;
if($CloseTag === false) { // block finishes with list if ($CloseTag === false) { // block finishes with list
$CloseTag = $Len; $CloseTag = $Len;
} }
$Block = substr($Str, $i, $CloseTag-$i); // Get the list $Block = substr($Str, $i, $CloseTag-$i); // Get the list
@ -355,7 +355,7 @@ private function parse ($Str) {
$NumInCloses = -1; $NumInCloses = -1;
$InOpenRegex = '/\[('.$TagName.')'; $InOpenRegex = '/\[('.$TagName.')';
if($MaxAttribs>0) { if ($MaxAttribs > 0) {
$InOpenRegex.="(=[^\n'\"\[\]]+)?"; $InOpenRegex.="(=[^\n'\"\[\]]+)?";
} }
$InOpenRegex.='\]/i'; $InOpenRegex.='\]/i';
@ -365,7 +365,7 @@ private function parse ($Str) {
// (as the first close tag won't do - it's been opened again) // (as the first close tag won't do - it's been opened again)
do { do {
$CloseTag = stripos($Str, '[/'.$TagName.']', $CloseTag+1); $CloseTag = stripos($Str, '[/'.$TagName.']', $CloseTag+1);
if($CloseTag === false) { if ($CloseTag === false) {
$CloseTag = $Len; $CloseTag = $Len;
break; break;
} else { } else {
@ -374,14 +374,14 @@ private function parse ($Str) {
// Is there another open tag inside this one? // Is there another open tag inside this one?
$OpenTag = preg_match($InOpenRegex, $Str, $InTag, PREG_OFFSET_CAPTURE, $InTagPos+1); $OpenTag = preg_match($InOpenRegex, $Str, $InTag, PREG_OFFSET_CAPTURE, $InTagPos+1);
if(!$OpenTag || $InTag[0][1]>$CloseTag) { if (!$OpenTag || $InTag[0][1] > $CloseTag) {
break; break;
} else { } else {
$InTagPos = $InTag[0][1]; $InTagPos = $InTag[0][1];
$NumInOpens++; $NumInOpens++;
} }
} while($NumInOpens>$NumInCloses); } while ($NumInOpens > $NumInCloses);
// Find the internal block inside the tag // Find the internal block inside the tag
@ -398,7 +398,7 @@ private function parse ($Str) {
break; break;
case 'url': case 'url':
$Array[$ArrayPos] = array('Type'=>'img', 'Attr'=>$Attrib, 'Val'=>$Block); $Array[$ArrayPos] = array('Type'=>'img', 'Attr'=>$Attrib, 'Val'=>$Block);
if(empty($Attrib)) { // [url]http://...[/url] - always set URL to attribute if (empty($Attrib)) { // [url]http://...[/url] - always set URL to attribute
$Array[$ArrayPos] = array('Type'=>'url', 'Attr'=>$Block, 'Val'=>''); $Array[$ArrayPos] = array('Type'=>'url', 'Attr'=>$Block, 'Val'=>'');
} else { } else {
$Array[$ArrayPos] = array('Type'=>'url', 'Attr'=>$Attrib, 'Val'=>$this->parse($Block)); $Array[$ArrayPos] = array('Type'=>'url', 'Attr'=>$Attrib, 'Val'=>$this->parse($Block));
@ -409,7 +409,7 @@ private function parse ($Str) {
break; break;
case 'img': case 'img':
case 'image': case 'image':
if(empty($Block)) { if (empty($Block)) {
$Block = $Attrib; $Block = $Attrib;
} }
$Array[$ArrayPos] = array('Type'=>'img', 'Val'=>$Block); $Array[$ArrayPos] = array('Type'=>'img', 'Val'=>$Block);
@ -417,7 +417,7 @@ private function parse ($Str) {
case 'aud': case 'aud':
case 'mp3': case 'mp3':
case 'audio': case 'audio':
if(empty($Block)) { if (empty($Block)) {
$Block = $Attrib; $Block = $Attrib;
} }
$Array[$ArrayPos] = array('Type'=>'aud', 'Val'=>$Block); $Array[$ArrayPos] = array('Type'=>'aud', 'Val'=>$Block);
@ -472,7 +472,7 @@ private function parse ($Str) {
$Array[$ArrayPos]['Val'] = explode('['.$TagName.']', $Block); $Array[$ArrayPos]['Val'] = explode('['.$TagName.']', $Block);
$Array[$ArrayPos]['ListType'] = $TagName === '*' ? 'ul' : 'ol'; $Array[$ArrayPos]['ListType'] = $TagName === '*' ? 'ul' : 'ol';
$Array[$ArrayPos]['Tag'] = $TagName; $Array[$ArrayPos]['Tag'] = $TagName;
foreach($Array[$ArrayPos]['Val'] as $Key=>$Val) { foreach ($Array[$ArrayPos]['Val'] as $Key=>$Val) {
$Array[$ArrayPos]['Val'][$Key] = $this->parse(trim($Val)); $Array[$ArrayPos]['Val'][$Key] = $this->parse(trim($Val));
} }
break; break;
@ -480,14 +480,14 @@ private function parse ($Str) {
$ArrayPos--; $ArrayPos--;
break; // n serves only to disrupt bbcode (backwards compatibility - use [pre]) break; // n serves only to disrupt bbcode (backwards compatibility - use [pre])
default: default:
if($WikiLink == true) { if ($WikiLink == true) {
$Array[$ArrayPos] = array('Type'=>'wiki','Val'=>$TagName); $Array[$ArrayPos] = array('Type'=>'wiki','Val'=>$TagName);
} else { } else {
// Basic tags, like [b] or [size=5] // Basic tags, like [b] or [size=5]
$Array[$ArrayPos] = array('Type'=>$TagName, 'Val'=>$this->parse($Block)); $Array[$ArrayPos] = array('Type'=>$TagName, 'Val'=>$this->parse($Block));
if(!empty($Attrib) && $MaxAttribs>0) { if (!empty($Attrib) && $MaxAttribs>0) {
$Array[$ArrayPos]['Attr'] = strtolower($Attrib); $Array[$ArrayPos]['Attr'] = strtolower($Attrib);
} }
} }
@ -512,7 +512,7 @@ public function parse_toc ($Min = 3)
foreach ($this->Headlines as $t) { foreach ($this->Headlines as $t) {
$n = (int) $t[0]; $n = (int) $t[0];
if($i === 0 && $n > 1) $off = $n - $level; if ($i === 0 && $n > 1) $off = $n - $level;
$this->headline_level($n, $level, $list, $i, $off); $this->headline_level($n, $level, $list, $i, $off);
$list .= sprintf('<li><a href="#%2$s">%1$s</a>', $t[1], $t[2]); $list .= sprintf('<li><a href="#%2$s">%1$s</a>', $t[1], $t[2]);
$level = $t[0]; $level = $t[0];
@ -565,11 +565,11 @@ private function headline_level (&$ItemLevel, &$Level, &$List, $i, &$Offset)
private function to_html ($Array) { private function to_html ($Array) {
global $SSL; global $SSL;
$this->Levels++; $this->Levels++;
if($this->Levels>10) { return $Block['Val']; } // Hax prevention if ($this->Levels>10) { return $Block['Val']; } // Hax prevention
$Str = ''; $Str = '';
foreach($Array as $Block) { foreach ($Array as $Block) {
if(is_string($Block)) { if (is_string($Block)) {
$Str.=$this->smileys($Block); $Str.=$this->smileys($Block);
continue; continue;
} }
@ -597,7 +597,7 @@ private function to_html ($Array) {
break; break;
case 'rule': case 'rule':
$Rule = trim(strtolower($Block['Val'])); $Rule = trim(strtolower($Block['Val']));
if($Rule[0] != 'r' && $Rule[0] != 'h') { if ($Rule[0] != 'r' && $Rule[0] != 'h') {
$Rule = 'r'.$Rule; $Rule = 'r'.$Rule;
} }
$Str.='<a href="rules.php?p=upload#'.urlencode(Format::undisplay_str($Rule)).'">'.preg_replace('/[aA-zZ]/', '', $Block['Val']).'</a>'; $Str.='<a href="rules.php?p=upload#'.urlencode(Format::undisplay_str($Rule)).'">'.preg_replace('/[aA-zZ]/', '', $Block['Val']).'</a>';
@ -636,7 +636,7 @@ private function to_html ($Array) {
break; break;
case 'list': case 'list':
$Str.='<'.$Block['ListType'].'>'; $Str.='<'.$Block['ListType'].'>';
foreach($Block['Val'] as $Line) { foreach ($Block['Val'] as $Line) {
$Str.='<li>'.$this->to_html($Line).'</li>'; $Str.='<li>'.$this->to_html($Line).'</li>';
} }
@ -644,7 +644,7 @@ private function to_html ($Array) {
break; break;
case 'align': case 'align':
$ValidAttribs = array('left', 'center', 'right'); $ValidAttribs = array('left', 'center', 'right');
if(!in_array($Block['Attr'], $ValidAttribs)) { if (!in_array($Block['Attr'], $ValidAttribs)) {
$Str.='[align='.$Block['Attr'].']'.$this->to_html($Block['Val']).'[/align]'; $Str.='[align='.$Block['Attr'].']'.$this->to_html($Block['Val']).'[/align]';
} else { } else {
$Str.='<div style="text-align:'.$Block['Attr'].'">'.$this->to_html($Block['Val']).'</div>'; $Str.='<div style="text-align:'.$Block['Attr'].'">'.$this->to_html($Block['Val']).'</div>';
@ -653,7 +653,7 @@ private function to_html ($Array) {
case 'color': case 'color':
case 'colour': case 'colour':
$ValidAttribs = array('aqua', 'black', 'blue', 'fuchsia', 'green', 'grey', 'lime', 'maroon', 'navy', 'olive', 'purple', 'red', 'silver', 'teal', 'white', 'yellow'); $ValidAttribs = array('aqua', 'black', 'blue', 'fuchsia', 'green', 'grey', 'lime', 'maroon', 'navy', 'olive', 'purple', 'red', 'silver', 'teal', 'white', 'yellow');
if(!in_array($Block['Attr'], $ValidAttribs) && !preg_match('/^#[0-9a-f]{6}$/', $Block['Attr'])) { if (!in_array($Block['Attr'], $ValidAttribs) && !preg_match('/^#[0-9a-f]{6}$/', $Block['Attr'])) {
$Str.='[color='.$Block['Attr'].']'.$this->to_html($Block['Val']).'[/color]'; $Str.='[color='.$Block['Attr'].']'.$this->to_html($Block['Val']).'[/color]';
} else { } else {
$Str.='<span style="color:'.$Block['Attr'].'">'.$this->to_html($Block['Val']).'</span>'; $Str.='<span style="color:'.$Block['Attr'].'">'.$this->to_html($Block['Val']).'</span>';
@ -662,7 +662,7 @@ private function to_html ($Array) {
case 'headline': case 'headline':
$text = $this->to_html($Block['Val']); $text = $this->to_html($Block['Val']);
$raw = $this->raw_text($Block['Val']); $raw = $this->raw_text($Block['Val']);
if(!in_array($Block['Attr'], $this->HeadlineLevels)) { if (!in_array($Block['Attr'], $this->HeadlineLevels)) {
$Str .= sprintf('%1$s%2$s%1$s', str_repeat('=', $Block['Attr'] + 1), $text); $Str .= sprintf('%1$s%2$s%1$s', str_repeat('=', $Block['Attr'] + 1), $text);
} else { } else {
$id = '_' . crc32($raw . $this->HeadlineID); $id = '_' . crc32($raw . $this->HeadlineID);
@ -675,7 +675,7 @@ private function to_html ($Array) {
case 'inlinesize': case 'inlinesize':
case 'size': case 'size':
$ValidAttribs = array('1','2','3','4','5','6','7','8','9','10'); $ValidAttribs = array('1','2','3','4','5','6','7','8','9','10');
if(!in_array($Block['Attr'], $ValidAttribs)) { if (!in_array($Block['Attr'], $ValidAttribs)) {
$Str.='[size='.$Block['Attr'].']'.$this->to_html($Block['Val']).'[/size]'; $Str.='[size='.$Block['Attr'].']'.$this->to_html($Block['Val']).'[/size]';
} else { } else {
$Str.='<span class="size'.$Block['Attr'].'">'.$this->to_html($Block['Val']).'</span>'; $Str.='<span class="size'.$Block['Attr'].'">'.$this->to_html($Block['Val']).'</span>';
@ -684,9 +684,9 @@ private function to_html ($Array) {
case 'quote': case 'quote':
$this->NoImg++; // No images inside quote tags $this->NoImg++; // No images inside quote tags
$this->InQuotes++; $this->InQuotes++;
if(!empty($Block['Attr'])) { if (!empty($Block['Attr'])) {
$Exploded = explode("|", $this->to_html($Block['Attr'])); $Exploded = explode("|", $this->to_html($Block['Attr']));
if(isset($Exploded[1]) && is_numeric($Exploded[1])) { if (isset($Exploded[1]) && is_numeric($Exploded[1])) {
$PostID = trim($Exploded[1]); $PostID = trim($Exploded[1]);
$Str.='<a href="#" onclick="QuoteJump(event, '.$PostID.'); return false;"><strong class="quoteheader">'.$Exploded[0].'</strong> wrote: </a>'; $Str.='<a href="#" onclick="QuoteJump(event, '.$PostID.'); return false;"><strong class="quoteheader">'.$Exploded[0].'</strong> wrote: </a>';
} }
@ -704,8 +704,8 @@ private function to_html ($Array) {
break; break;
case 'mature': case 'mature':
global $LoggedUser; global $LoggedUser;
if($LoggedUser['EnableMatureContent']) { if ($LoggedUser['EnableMatureContent']) {
if(!empty($Block['Attr'])) { if (!empty($Block['Attr'])) {
$Str.='<strong class="mature" style="font-size: 1.2em;">Mature content:</strong><strong> ' . $Block['Attr'] . '</strong><br \> <a href="javascript:void(0);" onclick="BBCode.spoiler(this);">Show</a>'; $Str.='<strong class="mature" style="font-size: 1.2em;">Mature content:</strong><strong> ' . $Block['Attr'] . '</strong><br \> <a href="javascript:void(0);" onclick="BBCode.spoiler(this);">Show</a>';
$Str.='<blockquote class="hidden spoiler">'.$this->to_html($Block['Val']).'</blockquote>'; $Str.='<blockquote class="hidden spoiler">'.$this->to_html($Block['Val']).'</blockquote>';
} }
@ -714,21 +714,21 @@ private function to_html ($Array) {
} }
} }
else { else {
$Str.='<span class="mature_blocked" style="font-style:italic;"><a href="wiki.php?action=article&amp;id=1063">Mature content </a>has been blocked. You can choose to view mature content by editing your <a href="user.php?action=edit&amp;userid=' . $LoggedUser['ID'] . '">settings</a>.</span>'; $Str.='<span class="mature_blocked" style="font-style: italic;"><a href="wiki.php?action=article&amp;id=1063">Mature content</a> has been blocked. You can choose to view mature content by editing your <a href="user.php?action=edit&amp;userid=' . $LoggedUser['ID'] . '">settings</a>.</span>';
} }
break; break;
case 'img': case 'img':
if($this->NoImg>0 && $this->valid_url($Block['Val'])) { if ($this->NoImg>0 && $this->valid_url($Block['Val'])) {
$Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Val'].'">'.$Block['Val'].'</a> (image)'; $Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Val'].'">'.$Block['Val'].'</a> (image)';
break; break;
} }
if(!$this->valid_url($Block['Val'], '\.(jpe?g|gif|png|bmp|tiff)')) { if (!$this->valid_url($Block['Val'], '\.(jpe?g|gif|png|bmp|tiff)')) {
$Str.='[img]'.$Block['Val'].'[/img]'; $Str.='[img]'.$Block['Val'].'[/img]';
} else { } else {
$LocalURL = $this->local_url($Block['Val']); $LocalURL = $this->local_url($Block['Val']);
if($LocalURL) { if ($LocalURL) {
$Str.='<img class="scale_image" onclick="lightbox.init(this,500);" alt="'.$Block['Val'].'" src="'.$LocalURL.'" />'; $Str.='<img class="scale_image" onclick="lightbox.init(this,500);" alt="'.$Block['Val'].'" src="'.$LocalURL.'" />';
} elseif(check_perms('site_proxy_images')) { } elseif (check_perms('site_proxy_images')) {
$Str.='<img class="scale_image" onclick="lightbox.init(this,500);" alt="'.$Block['Val'].'" src="http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?i='.urlencode($Block['Val']).'" />'; $Str.='<img class="scale_image" onclick="lightbox.init(this,500);" alt="'.$Block['Val'].'" src="http'.($SSL?'s':'').'://'.SITE_URL.'/image.php?i='.urlencode($Block['Val']).'" />';
} else { } else {
$Str.='<img class="scale_image" onclick="lightbox.init(this,500);" alt="'.$Block['Val'].'" src="'.$Block['Val'].'" />'; $Str.='<img class="scale_image" onclick="lightbox.init(this,500);" alt="'.$Block['Val'].'" src="'.$Block['Val'].'" />';
@ -737,11 +737,11 @@ private function to_html ($Array) {
break; break;
case 'aud': case 'aud':
if($this->NoImg>0 && $this->valid_url($Block['Val'])) { if ($this->NoImg>0 && $this->valid_url($Block['Val'])) {
$Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Val'].'">'.$Block['Val'].'</a> (audio)'; $Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Val'].'">'.$Block['Val'].'</a> (audio)';
break; break;
} }
if(!$this->valid_url($Block['Val'], '\.(mp3|ogg|wav)')) { if (!$this->valid_url($Block['Val'], '\.(mp3|ogg|wav)')) {
$Str.='[aud]'.$Block['Val'].'[/aud]'; $Str.='[aud]'.$Block['Val'].'[/aud]';
} else { } else {
//TODO: Proxy this for staff? //TODO: Proxy this for staff?
@ -751,7 +751,7 @@ private function to_html ($Array) {
case 'url': case 'url':
// Make sure the URL has a label // Make sure the URL has a label
if(empty($Block['Val'])) { if (empty($Block['Val'])) {
$Block['Val'] = $Block['Attr']; $Block['Val'] = $Block['Attr'];
$NoName = true; // If there isn't a Val for this $NoName = true; // If there isn't a Val for this
} else { } else {
@ -759,12 +759,12 @@ private function to_html ($Array) {
$NoName = false; $NoName = false;
} }
if(!$this->valid_url($Block['Attr'])) { if (!$this->valid_url($Block['Attr'])) {
$Str.='[url='.$Block['Attr'].']'.$Block['Val'].'[/url]'; $Str.='[url='.$Block['Attr'].']'.$Block['Val'].'[/url]';
} else { } else {
$LocalURL = $this->local_url($Block['Attr']); $LocalURL = $this->local_url($Block['Attr']);
if($LocalURL) { if ($LocalURL) {
if($NoName) { $Block['Val'] = substr($LocalURL,1); } if ($NoName) { $Block['Val'] = substr($LocalURL,1); }
$Str.='<a href="'.$LocalURL.'">'.$Block['Val'].'</a>'; $Str.='<a href="'.$LocalURL.'">'.$Block['Val'].'</a>';
} else { } else {
$Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Attr'].'">'.$Block['Val'].'</a>'; $Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Attr'].'">'.$Block['Val'].'</a>';
@ -773,7 +773,7 @@ private function to_html ($Array) {
break; break;
case 'inlineurl': case 'inlineurl':
if(!$this->valid_url($Block['Attr'], '', true)) { if (!$this->valid_url($Block['Attr'], '', true)) {
$Array = $this->parse($Block['Attr']); $Array = $this->parse($Block['Attr']);
$Block['Attr'] = $Array; $Block['Attr'] = $Array;
$Str.=$this->to_html($Block['Attr']); $Str.=$this->to_html($Block['Attr']);
@ -781,7 +781,7 @@ private function to_html ($Array) {
else { else {
$LocalURL = $this->local_url($Block['Attr']); $LocalURL = $this->local_url($Block['Attr']);
if($LocalURL) { if ($LocalURL) {
$Str.='<a href="'.$LocalURL.'">'.substr($LocalURL,1).'</a>'; $Str.='<a href="'.$LocalURL.'">'.substr($LocalURL,1).'</a>';
} else { } else {
$Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Attr'].'">'.$Block['Attr'].'</a>'; $Str.='<a rel="noreferrer" target="_blank" href="'.$Block['Attr'].'">'.$Block['Attr'].'</a>';
@ -798,8 +798,8 @@ private function to_html ($Array) {
private function raw_text ($Array) { private function raw_text ($Array) {
$Str = ''; $Str = '';
foreach($Array as $Block) { foreach ($Array as $Block) {
if(is_string($Block)) { if (is_string($Block)) {
$Str.=$Block; $Str.=$Block;
continue; continue;
} }
@ -829,14 +829,14 @@ private function raw_text ($Array) {
$Str.=$Block['Val']; $Str.=$Block['Val'];
break; break;
case 'list': case 'list':
foreach($Block['Val'] as $Line) { foreach ($Block['Val'] as $Line) {
$Str.=$Block['Tag'].$this->raw_text($Line); $Str.=$Block['Tag'].$this->raw_text($Line);
} }
break; break;
case 'url': case 'url':
// Make sure the URL has a label // Make sure the URL has a label
if(empty($Block['Val'])) { if (empty($Block['Val'])) {
$Block['Val'] = $Block['Attr']; $Block['Val'] = $Block['Attr'];
} else { } else {
$Block['Val'] = $this->raw_text($Block['Val']); $Block['Val'] = $this->raw_text($Block['Val']);
@ -846,7 +846,7 @@ private function raw_text ($Array) {
break; break;
case 'inlineurl': case 'inlineurl':
if(!$this->valid_url($Block['Attr'], '', true)) { if (!$this->valid_url($Block['Attr'], '', true)) {
$Array = $this->parse($Block['Attr']); $Array = $this->parse($Block['Attr']);
$Block['Attr'] = $Array; $Block['Attr'] = $Array;
$Str.=$this->raw_text($Block['Attr']); $Str.=$this->raw_text($Block['Attr']);
@ -863,7 +863,7 @@ private function raw_text ($Array) {
private function smileys ($Str) { private function smileys ($Str) {
global $LoggedUser; global $LoggedUser;
if(!empty($LoggedUser['DisableSmileys'])) { if (!empty($LoggedUser['DisableSmileys'])) {
return $Str; return $Str;
} }
$Str = strtr($Str, $this->Smileys); $Str = strtr($Str, $this->Smileys);

View File

@ -214,6 +214,16 @@ CREATE TABLE `concerts` (
KEY `TopicID` (`TopicID`) KEY `TopicID` (`TopicID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8; ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
CREATE TABLE `disable_list` (
`Nick` varchar(255) COLLATE utf8_bin NOT NULL,
`Username` varchar(255) COLLATE utf8_bin NOT NULL,
`UserID` int(10) unsigned NOT NULL,
`Time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
`Moderator` varchar(255) COLLATE utf8_bin DEFAULT NULL,
PRIMARY KEY (`Nick`),
KEY `UserID` (`UserID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
CREATE TABLE `do_not_upload` ( CREATE TABLE `do_not_upload` (
`ID` int(10) NOT NULL AUTO_INCREMENT, `ID` int(10) NOT NULL AUTO_INCREMENT,
`Name` varchar(255) COLLATE utf8_bin NOT NULL, `Name` varchar(255) COLLATE utf8_bin NOT NULL,

View File

@ -1,5 +1,7 @@
<? <?
if(!check_perms('admin_donor_log')) { error(403); } if (!check_perms('admin_donor_log')) {
error(403);
}
include(SERVER_ROOT.'/sections/donate/config.php'); include(SERVER_ROOT.'/sections/donate/config.php');
@ -7,8 +9,11 @@
$Balance = btc_balance() . " BTC"; $Balance = btc_balance() . " BTC";
$Receiveds = btc_received(); $Receiveds = btc_received();
$DB->query("SELECT i.UserID, i.BitcoinAddress FROM users_info AS i JOIN users_main AS m ON m.ID = i.UserID $DB->query("SELECT i.UserID, i.BitcoinAddress
WHERE BitcoinAddress IS NOT NULL ORDER BY m.Username ASC"); FROM users_info AS i
JOIN users_main AS m ON m.ID = i.UserID
WHERE BitcoinAddress IS NOT NULL
ORDER BY m.Username ASC");
?> ?>
<div class="thin"> <div class="thin">
<div class="header"> <div class="header">
@ -28,7 +33,9 @@
$amount = $R->amount . ' BTC'; $amount = $R->amount . ' BTC';
} }
} }
if ($amount === false) { continue; } if ($amount === false) {
continue;
}
?> ?>
<tr> <tr>
<td><?=Users::format_username($row['UserID'], true, false, false, false)?></td> <td><?=Users::format_username($row['UserID'], true, false, false, false)?></td>

View File

@ -1,13 +1,15 @@
<? <?
$Campaign = 'forumaudio'; $Campaign = 'forumaudio';
if (!$Votes = $Cache->get_value('support_'.$Campaign)) { $Votes = array(0,0); } if (!$Votes = $Cache->get_value('support_'.$Campaign)) {
$Votes = array(0,0);
}
if (!isset($_GET['support'])) { if (!isset($_GET['support'])) {
?> ?>
<h1>Browser Support Campaign: <?=$Campaign?></h1> <h1>Browser Support Campaign: <?=$Campaign?></h1>
<ul> <ul>
<li><?=number_format($Votes[0])?> +</li> <li><?=number_format($Votes[0])?> +</li>
<li><?=number_format($Votes[1])?> -</li> <li><?=number_format($Votes[1])?> -</li>
<li><?=number_format(($Votes[0]/($Votes[0]+$Votes[1]))*100,3)?> %</li> <li><?=number_format(($Votes[0] / ($Votes[0] + $Votes[1])) * 100,3)?> %</li>
</ul> </ul>
<? <?
} elseif ($_GET['support'] === 'true') { } elseif ($_GET['support'] === 'true') {

View File

@ -1,13 +1,16 @@
<? <?
if(!check_perms('admin_manage_permissions')) { error(403); } if (!check_perms('admin_manage_permissions')) {
error(403);
}
View::show_header('Special Users List'); View::show_header('Special Users List');
?> ?>
<div class="thin"> <div class="thin">
<? <?
$DB->query("SELECT m.ID FROM users_main AS m $DB->query("SELECT m.ID
FROM users_main AS m
WHERE m.CustomPermissions != '' WHERE m.CustomPermissions != ''
AND m.CustomPermissions != 'a:0:{}'"); AND m.CustomPermissions != 'a:0:{}'");
if($DB->record_count()) { if ($DB->record_count()) {
?> ?>
<table width="100%"> <table width="100%">
<tr class="colhead"> <tr class="colhead">
@ -15,7 +18,7 @@
<td>Access</td> <td>Access</td>
</tr> </tr>
<? <?
while(list($UserID)=$DB->next_record()) { while (list($UserID)=$DB->next_record()) {
?> ?>
<tr> <tr>
<td><?=Users::format_username($UserID, true, true, true, true)?></td> <td><?=Users::format_username($UserID, true, true, true, true)?></td>
@ -23,8 +26,10 @@
</tr> </tr>
<? } ?> <? } ?>
</table> </table>
<? } else { ?> <?
} else { ?>
<h2 align="center">There are no special users.</h2> <h2 align="center">There are no special users.</h2>
<? } ?> <?
} ?>
</div> </div>
<? View::show_footer(); ?> <? View::show_footer(); ?>

View File

@ -1,5 +1,7 @@
<? <?
if(!check_perms('site_view_flow')) { error(403); } if (!check_perms('site_view_flow')) {
error(403);
}
View::show_header('Upscale Pool'); View::show_header('Upscale Pool');
define('USERS_PER_PAGE', 50); define('USERS_PER_PAGE', 50);
list($Page,$Limit) = Format::page_limit(USERS_PER_PAGE); list($Page,$Limit) = Format::page_limit(USERS_PER_PAGE);
@ -29,7 +31,7 @@
list($TotalDisabled) = $DB->next_record(); list($TotalDisabled) = $DB->next_record();
$DB->set_query_id($RS); $DB->set_query_id($RS);
if($DB->record_count()) { if ($DB->record_count()) {
?> ?>
<div class="box pad"> <div class="box pad">
<p>There are currently <?=number_format($Results)?> users queued by the system and <?=number_format($TotalDisabled)?> already disabled.</p> <p>There are currently <?=number_format($Results)?> users queued by the system and <?=number_format($TotalDisabled)?> already disabled.</p>
@ -54,7 +56,7 @@
<td>Lifespan</td> <td>Lifespan</td>
</tr> </tr>
<? <?
while(list($UserID, $Username, $Uploaded, $Downloaded, $PermissionID, $Enabled, $Donor, $Warned, $Joined, $RatioWatchEnds, $RatioWatchDownload, $RequiredRatio)=$DB->next_record()) { while (list($UserID, $Username, $Uploaded, $Downloaded, $PermissionID, $Enabled, $Donor, $Warned, $Joined, $RatioWatchEnds, $RatioWatchDownload, $RequiredRatio)=$DB->next_record()) {
$Row = ($Row == 'b') ? 'a' : 'b'; $Row = ($Row == 'b') ? 'a' : 'b';
?> ?>
@ -64,8 +66,8 @@
<td><?=Format::get_size($Downloaded)?></td> <td><?=Format::get_size($Downloaded)?></td>
<td><?=Format::get_ratio_html($Uploaded, $Downloaded)?></td> <td><?=Format::get_ratio_html($Uploaded, $Downloaded)?></td>
<td><?=number_format($RequiredRatio, 2)?></td> <td><?=number_format($RequiredRatio, 2)?></td>
<td><? if(($Downloaded*$RequiredRatio)>$Uploaded) { echo Format::get_size(($Downloaded*$RequiredRatio)-$Uploaded);}?></td> <td><? if (($Downloaded * $RequiredRatio) > $Uploaded) { echo Format::get_size(($Downloaded * $RequiredRatio) - $Uploaded);}?></td>
<td><?=Format::get_size($Downloaded-$RatioWatchDownload)?></td> <td><?=Format::get_size($Downloaded - $RatioWatchDownload)?></td>
<td><?=time_diff($Joined,2)?></td> <td><?=time_diff($Joined,2)?></td>
<td><?=time_diff($RatioWatchEnds)?></td> <td><?=time_diff($RatioWatchEnds)?></td>
<td><?//time_diff(strtotime($Joined), strtotime($RatioWatchEnds))?></td> <td><?//time_diff(strtotime($Joined), strtotime($RatioWatchEnds))?></td>

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.9 KiB

View File

@ -375,6 +375,7 @@ ul#userinfo_minor a:hover {
ul#userinfo_major { ul#userinfo_major {
z-index: 3; z-index: 3;
padding-left: 530px; padding-left: 530px;
width: 365px;
} }
ul#userinfo_minor { ul#userinfo_minor {
@ -393,6 +394,7 @@ ul#userinfo_stats {
ul#userinfo_username { ul#userinfo_username {
z-index: 6; z-index: 6;
padding-left: 320px; padding-left: 320px;
width: 175px;
} }
#alerts { #alerts {