Reorganize app

This commit is contained in:
Sky Johnson 2024-06-29 07:47:23 -05:00
parent 9e8d5b74e0
commit 5269bf5539
147 changed files with 95 additions and 163 deletions

View File

@ -1,17 +0,0 @@
<?php
if(!defined('SAFE')) {
$page = <<<CANTTOUCH
<html>
<head>
</head>
<body style="padding:0px; margin:0px; background-color: #425b5c;">
<center><img src="../../Images/General/CantTouchThis.png" /></center>
</body>
</html>
CANTTOUCH;
die($page);
}
?>

View File

@ -1,20 +1,4 @@
<?php <?php
if(!defined('SAFE')) {
$page = <<<CANTTOUCH
<html>
<head>
</head>
<body style="padding:0px; margin:0px; background-color: #425b5c;">
<center><img src="../../Images/General/CantTouchThis.png" /></center>
</body>
</html>
CANTTOUCH;
die($page);
}
/* /*
/// ///
// Author: Skylear Johnson Co-Author: None // Author: Skylear Johnson Co-Author: None
@ -22,58 +6,35 @@ CANTTOUCH;
// This script is copyright (c) 2013, by Mad Splash Studios. // This script is copyright (c) 2013, by Mad Splash Studios.
/// ///
*/ */
ini_set('display_errors', 'On'); ini_set('display_errors', 'On');
error_reporting(E_ALL | E_STRICT); error_reporting(E_ALL | E_STRICT);
/* This entire block here is a method to rid POST, GET and COOKIE of unwanted slashes.
// I have to give some thanks to Atli from Dream.In.Code for helping me come up with this.
// However, this should never really be used. If magic_slashes is a problem, it's time to switch servers; ASAP. */
if(function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()) {
function undo_magic_quotes_gpc(&$array) {
foreach($array as &$value) {
if(is_array($value)) {
undo_magic_quotes_gpc($value);
} else {
$value = stripslashes($value);
}
}
}
undo_magic_quotes_gpc($_POST);
undo_magic_quotes_gpc($_GET);
undo_magic_quotes_gpc($_COOKIE);
}
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
/// Includes, so we can use them elsewhere without having to call them each time. /// Includes, so we can use them elsewhere without having to call them each time.
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/User.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/User.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/Show.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/Show.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/Article.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/Article.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/Project.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/Project.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/ArticleComment.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/ArticleComment.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/EpisodeComment.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Classes/EpisodeComment.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Modules/DisplayModule.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Modules/DisplayModule.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Modules/DatabaseModule.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Modules/DatabaseModule.php");
include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Modules/CommunityModule.php"); include($_SERVER["DOCUMENT_ROOT"] . "/Resources/Scripts/PHP/Modules/CommunityModule.php");
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
/// Misc functions - used for who-knows-what and who-knows-when. /// Misc functions - used for who-knows-what and who-knows-when.
// Used for scripts that require some sort of timing. // Used for scripts that require some sort of timing.
function getMicroTime() { function getMicroTime() {
list($usec, $sec) = explode(" ", microtime()); list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec); return ((float)$usec + (float)$sec);
} }
function arrayCheck($ArrayToCheck, $CheckAgainst) { function arrayCheck($ArrayToCheck, $CheckAgainst) {
if(count(array_intersect($ArrayToCheck, $CheckAgainst)) > 0) { if(count(array_intersect($ArrayToCheck, $CheckAgainst)) > 0) {
return true; return true;
@ -81,112 +42,71 @@ CANTTOUCH;
return false; return false;
} }
} }
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
/// Pretty functions - used to makes things cleaner and look nicer. /// Pretty functions - used to makes things cleaner and look nicer.
// Change the MySQL date format (YYYY-MM-DD) into something friendlier. // Change the MySQL date format (YYYY-MM-DD) into something friendlier.
function betterDate($uglyDate) { function betterDate($uglyDate) {
try { try {
$date = new DateTime($uglyDate); $date = new DateTime($uglyDate);
return $date->format("jS M Y, g:i A"); return $date->format("jS M Y, g:i A");
} catch(PDOException $ex) { } catch(PDOException $ex) {
echo $ex->getMessage(); echo $ex->getMessage();
} }
} }
function nicerDate($uglyDate) { function nicerDate($uglyDate) {
try { try {
$date = new DateTime($uglyDate); $date = new DateTime($uglyDate);
return $date->format("jS M Y - g:i A"); return $date->format("jS M Y - g:i A");
} catch(PDOException $ex) { } catch(PDOException $ex) {
echo $ex->getMessage(); echo $ex->getMessage();
} }
} }
function getAge($date) { function getAge($date) {
$birthDay = new DateTime($date); $birthDay = new DateTime($date);
$today = new DateTime(); $today = new DateTime();
$age = $today->diff($birthDay); $age = $today->diff($birthDay);
return $age->y; return $age->y;
} }
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
/// Aegis functions - cleans data and parses it, as well as hashes and checks other stuff for protection. /// Aegis functions - cleans data and parses it, as well as hashes and checks other stuff for protection.
// This function serves to prevent tags within HTML getting into things. It's basically a symbol cleaner. // This function serves to prevent tags within HTML getting into things. It's basically a symbol cleaner.
// Kudos to Atli from Dream.In.Code for showing me htmlentities()! // Kudos to Atli from Dream.In.Code for showing me htmlentities()!
function magicClean($text) { function magicClean($text) {
$text = htmlentities($text, ENT_QUOTES, "UTF-8"); $text = htmlentities($text, ENT_QUOTES, "UTF-8");
return $text; return $text;
} }
// Hash a password thousands of times using a random salt. // Hash a password thousands of times using a random salt.
function hashPass($password, $salt, $username = "failure") { function hashPass($password, $salt, $username = "failure") {
for($round = 0; $round < 124363; $round++) { for($round = 0; $round < 124363; $round++) {
$HashedPass = hash("sha512", $username . $salt . $password); $HashedPass = hash("sha512", $username . $salt . $password);
} }
return $HashedPass; return $HashedPass;
} }
function generateSalt($max = 15) { function generateSalt(int $length = 15): string
$characterList = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!@#$%&*?"; {
$i = 0; return bin2hex(random_bytes($length));
$salt = "";
while ($i < $max) {
$salt .= $characterList{mt_rand(0, (strlen($characterList) - 1))};
$i++;
}
return $salt;
} }
// Validate the email address inputted! // Validate the email address inputted!
function checkEmail($email) { function checkEmail($email): bool
$isValid = true; {
$atIndex = strrpos($email, "@"); return filter_var($email, FILTER_VALIDATE_EMAIL) ? true : false;
if(is_bool($atIndex) && !$atIndex) {
$isValid = false;
} else {
$domain = substr($email, $atIndex + 1);
$local = substr($email, 0, $atIndex);
$localLen = strlen($local);
$domainLen = strlen($domain);
if($localLen < 1 || $localLen > 64) {
$isValid = false;
} elseif($domainLen < 1 || $domainLen > 255) {
$isValid = false;
} elseif($local[0] == '.' || $local[$localLen - 1] == '.') {
$isValid = false;
} elseif(preg_match('/\\.\\./', $local)) {
$isValid = false;
} elseif(!preg_match('/^[A-Za-z0-9\\-\\.]+$/', $domain)) {
$isValid = false;
} elseif(preg_match('/\\.\\./', $domain)) {
$isValid = false;
} elseif(!preg_match('/^(\\\\.|[A-Za-z0-9!#%&`_=\\/$\'*+?^{}|~.-])+$/', str_replace("\\\\", "", $local))) {
if (!preg_match('/^"(\\\\"|[^"])+"$/', str_replace("\\\\", "", $local))) {
$isValid = false;
}
}
if ($isValid && !(checkdnsrr($domain, "MX") || checkdnsrr($domain, "A"))) {
$isValid = false;
}
}
return $isValid;
} }
// Simple BBCode parse function. // Simple BBCode parse function.
function BBCode($data) { function BBCode($data) {
$input = array( $input = array(
@ -214,7 +134,7 @@ CANTTOUCH;
'/\[code\](.*?)\[\/code\]/is', '/\[code\](.*?)\[\/code\]/is',
'/ \:P/is' '/ \:P/is'
); );
$output = array( $output = array(
'<br />', '<br />',
'<br /><br />', '<br /><br />',
@ -240,36 +160,36 @@ CANTTOUCH;
'<pre class="forumCode"><span class="title"><span class="hdr">CODE</span> </span><p style="padding: 5px;">$1</p></pre>', '<pre class="forumCode"><span class="title"><span class="hdr">CODE</span> </span><p style="padding: 5px;">$1</p></pre>',
'<img class="Emote" src=\'../Resources/Images/Icons/Emotes/Tongue.gif\' />' '<img class="Emote" src=\'../Resources/Images/Icons/Emotes/Tongue.gif\' />'
); );
$rtrn = preg_replace($input, $output, $data); $rtrn = preg_replace($input, $output, $data);
return $rtrn; return $rtrn;
} }
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
/// Email functions - used to send emails for various reasons /// Email functions - used to send emails for various reasons
// Send an email to the specified recipient. // Send an email to the specified recipient.
function sendMail($mailSubject, $mailContent, $mailDestinee, $templatename) { function sendMail($mailSubject, $mailContent, $mailDestinee, $templatename) {
$mailHeaders = 'MIME-Version: 1.0' . "\r\n"; $mailHeaders = 'MIME-Version: 1.0' . "\r\n";
$mailHeaders .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n"; $mailHeaders .= 'Content-type: text/html; charset=iso-8859-1' . "\r\n";
$mailHeaders .= 'From: theguys@localhost:8888' . "\r\n"; $mailHeaders .= 'From: theguys@localhost:8888' . "\r\n";
$filename = $_SERVER['DOCUMENT_ROOT'] . "/Resources/Templates/emails/" . $templatename . ".php"; $filename = $_SERVER['DOCUMENT_ROOT'] . "/Resources/Templates/emails/" . $templatename . ".php";
include("$filename"); include("$filename");
foreach($mailContent as $a => $b) { foreach($mailContent as $a => $b) {
$template = str_replace("{{{" . $a . "}}}", $b, $template); $template = str_replace("{{{" . $a . "}}}", $b, $template);
} }
mail($mailDestinee, $mailSubject, $template, $mailHeaders); mail($mailDestinee, $mailSubject, $template, $mailHeaders);
} }
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
// ---------------------------------------------------------------------------- // // ---------------------------------------------------------------------------- //
/// Generator functions - used to create things that would take too many lines to constantly repeat /// Generator functions - used to create things that would take too many lines to constantly repeat
// Create the new and improved text editor. // Create the new and improved text editor.
function textEditor($Width, $Height, $Name, $Default) { function textEditor($Width, $Height, $Name, $Default) {
echo <<<EDITOR echo <<<EDITOR
@ -283,14 +203,14 @@ CANTTOUCH;
<li onclick="addTXT('img', '{$Name}')"><span class="BBCButton">IMG</span></li> <li onclick="addTXT('img', '{$Name}')"><span class="BBCButton">IMG</span></li>
<li onclick="addTXT('url', '{$Name}')"><span class="BBCButton">URL</span></li> <li onclick="addTXT('url', '{$Name}')"><span class="BBCButton">URL</span></li>
</ul> </ul>
<label for="{$Name}" style="color: #888; font-weight: bold; position: relative; top: 6px;">{$Name}</label> <label for="{$Name}" style="color: #888; font-weight: bold; position: relative; top: 6px;">{$Name}</label>
<textarea id="{$Name}" class="message" name="{$Name}" style="width: 100%; max-width: 100%; height: {$Height};">{$Default}</textarea> <textarea id="{$Name}" class="message" name="{$Name}" style="width: 100%; max-width: 100%; height: {$Height};">{$Default}</textarea>
</div> </div>
EDITOR; EDITOR;
} }
// Function to check for errors and display them as needed. // Function to check for errors and display them as needed.
function displayErrors($leErrors, $errorArray) { function displayErrors($leErrors, $errorArray) {
$Errors = array( $Errors = array(
@ -308,29 +228,50 @@ EDITOR;
"<!-- 12 -->That password doesn't match the username. <a href=\"iForgot.php?this=password\">Reset your password?</a>", "<!-- 12 -->That password doesn't match the username. <a href=\"iForgot.php?this=password\">Reset your password?</a>",
"<1-- 13 -->Whoops! You need to give both your username and your password!" "<1-- 13 -->Whoops! You need to give both your username and your password!"
); );
$leErrors = array_intersect($leErrors, $errorArray); $leErrors = array_intersect($leErrors, $errorArray);
foreach($leErrors as $error) { foreach($leErrors as $error) {
$error = $error - 1; $error = $error - 1;
echo "<span class=\"error\">" . $Errors[$error] . "</span>"; echo "<span class=\"error\">" . $Errors[$error] . "</span>";
} }
} }
// Retrieve template from the source. // Retrieve template from the source.
function GetTemplate($templatename) { function GetTemplate($templatename) {
$filename = $_SERVER['DOCUMENT_ROOT'] . "/Resources/Templates/" . $templatename . ".php"; $filename = $_SERVER['DOCUMENT_ROOT'] . "/Resources/Templates/" . $templatename . ".php";
include("$filename"); include("$filename");
return $template; return $template;
} }
// Parse all proper content into the template. // Parse all proper content into the template.
function ParseTemplate($template, $array) { function ParseTemplate($template, $array) {
foreach($array as $a => $b) { foreach($array as $a => $b) {
$template = str_replace("{{{" . $a . "}}}", $b, $template); $template = str_replace("{{{" . $a . "}}}", $b, $template);
} }
return $template; return $template;
} }
?>
/**
* Return the path to the given template.
*/
function template(string $name): string
{
return "../app/templates/$name.php";
}
/**
* Render a template. Pass data to it - uses an output buffer to have PHP process the template instead of using
* a template engine. If you're including partials in the page, call render('partial', $data), as $data will still
* be available.
*/
function render(string $baseView, array $data = []): string
{
ob_start();
extract($data);
include template($baseView);
return ob_get_clean();
}
?>

View File

@ -1,17 +0,0 @@
<?php
if(!defined('SAFE')) {
$page = <<<CANTTOUCH
<html>
<head>
</head>
<body style="padding:0px; margin:0px; background-color: #425b5c;">
<center><img src="../../Images/General/CantTouchThis.png" /></center>
</body>
</html>
CANTTOUCH;
die($page);
}
?>

View File

Before

Width:  |  Height:  |  Size: 20 KiB

After

Width:  |  Height:  |  Size: 20 KiB

View File

Before

Width:  |  Height:  |  Size: 18 KiB

After

Width:  |  Height:  |  Size: 18 KiB

View File

Before

Width:  |  Height:  |  Size: 88 KiB

After

Width:  |  Height:  |  Size: 88 KiB

View File

Before

Width:  |  Height:  |  Size: 102 KiB

After

Width:  |  Height:  |  Size: 102 KiB

View File

Before

Width:  |  Height:  |  Size: 21 KiB

After

Width:  |  Height:  |  Size: 21 KiB

View File

Before

Width:  |  Height:  |  Size: 143 KiB

After

Width:  |  Height:  |  Size: 143 KiB

View File

Before

Width:  |  Height:  |  Size: 66 KiB

After

Width:  |  Height:  |  Size: 66 KiB

View File

Before

Width:  |  Height:  |  Size: 56 KiB

After

Width:  |  Height:  |  Size: 56 KiB

View File

Before

Width:  |  Height:  |  Size: 110 KiB

After

Width:  |  Height:  |  Size: 110 KiB

View File

Before

Width:  |  Height:  |  Size: 333 B

After

Width:  |  Height:  |  Size: 333 B

View File

Before

Width:  |  Height:  |  Size: 58 KiB

After

Width:  |  Height:  |  Size: 58 KiB

View File

Before

Width:  |  Height:  |  Size: 27 KiB

After

Width:  |  Height:  |  Size: 27 KiB

View File

Before

Width:  |  Height:  |  Size: 64 KiB

After

Width:  |  Height:  |  Size: 64 KiB

View File

Before

Width:  |  Height:  |  Size: 179 KiB

After

Width:  |  Height:  |  Size: 179 KiB

View File

Before

Width:  |  Height:  |  Size: 149 KiB

After

Width:  |  Height:  |  Size: 149 KiB

View File

Before

Width:  |  Height:  |  Size: 48 KiB

After

Width:  |  Height:  |  Size: 48 KiB

View File

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

View File

Before

Width:  |  Height:  |  Size: 124 KiB

After

Width:  |  Height:  |  Size: 124 KiB

View File

Before

Width:  |  Height:  |  Size: 168 KiB

After

Width:  |  Height:  |  Size: 168 KiB

View File

Before

Width:  |  Height:  |  Size: 203 KiB

After

Width:  |  Height:  |  Size: 203 KiB

View File

Before

Width:  |  Height:  |  Size: 194 KiB

After

Width:  |  Height:  |  Size: 194 KiB

View File

Before

Width:  |  Height:  |  Size: 44 KiB

After

Width:  |  Height:  |  Size: 44 KiB

View File

Before

Width:  |  Height:  |  Size: 27 KiB

After

Width:  |  Height:  |  Size: 27 KiB

View File

Before

Width:  |  Height:  |  Size: 61 KiB

After

Width:  |  Height:  |  Size: 61 KiB

View File

Before

Width:  |  Height:  |  Size: 104 KiB

After

Width:  |  Height:  |  Size: 104 KiB

View File

Before

Width:  |  Height:  |  Size: 67 KiB

After

Width:  |  Height:  |  Size: 67 KiB

View File

Before

Width:  |  Height:  |  Size: 18 KiB

After

Width:  |  Height:  |  Size: 18 KiB

View File

Before

Width:  |  Height:  |  Size: 19 KiB

After

Width:  |  Height:  |  Size: 19 KiB

View File

Before

Width:  |  Height:  |  Size: 76 KiB

After

Width:  |  Height:  |  Size: 76 KiB

View File

Before

Width:  |  Height:  |  Size: 24 KiB

After

Width:  |  Height:  |  Size: 24 KiB

View File

Before

Width:  |  Height:  |  Size: 148 KiB

After

Width:  |  Height:  |  Size: 148 KiB

View File

Before

Width:  |  Height:  |  Size: 56 KiB

After

Width:  |  Height:  |  Size: 56 KiB

View File

Before

Width:  |  Height:  |  Size: 70 KiB

After

Width:  |  Height:  |  Size: 70 KiB

View File

Before

Width:  |  Height:  |  Size: 983 B

After

Width:  |  Height:  |  Size: 983 B

View File

Before

Width:  |  Height:  |  Size: 6.2 KiB

After

Width:  |  Height:  |  Size: 6.2 KiB

View File

Before

Width:  |  Height:  |  Size: 207 B

After

Width:  |  Height:  |  Size: 207 B

View File

Before

Width:  |  Height:  |  Size: 227 B

After

Width:  |  Height:  |  Size: 227 B

View File

Before

Width:  |  Height:  |  Size: 638 B

After

Width:  |  Height:  |  Size: 638 B

Some files were not shown because too many files have changed in this diff Show More