Reorganize app
|
@ -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);
|
|
||||||
}
|
|
||||||
?>
|
|
|
@ -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
|
||||||
|
@ -26,29 +10,6 @@ CANTTOUCH;
|
||||||
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.
|
||||||
|
@ -135,56 +96,15 @@ CANTTOUCH;
|
||||||
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.
|
||||||
|
@ -333,4 +253,25 @@ EDITOR;
|
||||||
|
|
||||||
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();
|
||||||
|
}
|
||||||
?>
|
?>
|
|
@ -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);
|
|
||||||
}
|
|
||||||
?>
|
|
Before Width: | Height: | Size: 20 KiB After Width: | Height: | Size: 20 KiB |
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 18 KiB |
Before Width: | Height: | Size: 88 KiB After Width: | Height: | Size: 88 KiB |
Before Width: | Height: | Size: 102 KiB After Width: | Height: | Size: 102 KiB |
Before Width: | Height: | Size: 21 KiB After Width: | Height: | Size: 21 KiB |
Before Width: | Height: | Size: 143 KiB After Width: | Height: | Size: 143 KiB |
Before Width: | Height: | Size: 66 KiB After Width: | Height: | Size: 66 KiB |
Before Width: | Height: | Size: 56 KiB After Width: | Height: | Size: 56 KiB |
Before Width: | Height: | Size: 110 KiB After Width: | Height: | Size: 110 KiB |
Before Width: | Height: | Size: 333 B After Width: | Height: | Size: 333 B |
Before Width: | Height: | Size: 58 KiB After Width: | Height: | Size: 58 KiB |
Before Width: | Height: | Size: 27 KiB After Width: | Height: | Size: 27 KiB |
Before Width: | Height: | Size: 64 KiB After Width: | Height: | Size: 64 KiB |
Before Width: | Height: | Size: 179 KiB After Width: | Height: | Size: 179 KiB |
Before Width: | Height: | Size: 149 KiB After Width: | Height: | Size: 149 KiB |
Before Width: | Height: | Size: 48 KiB After Width: | Height: | Size: 48 KiB |
Before Width: | Height: | Size: 76 KiB After Width: | Height: | Size: 76 KiB |
Before Width: | Height: | Size: 124 KiB After Width: | Height: | Size: 124 KiB |
Before Width: | Height: | Size: 168 KiB After Width: | Height: | Size: 168 KiB |
Before Width: | Height: | Size: 203 KiB After Width: | Height: | Size: 203 KiB |
Before Width: | Height: | Size: 194 KiB After Width: | Height: | Size: 194 KiB |
Before Width: | Height: | Size: 44 KiB After Width: | Height: | Size: 44 KiB |
Before Width: | Height: | Size: 27 KiB After Width: | Height: | Size: 27 KiB |
Before Width: | Height: | Size: 61 KiB After Width: | Height: | Size: 61 KiB |
Before Width: | Height: | Size: 104 KiB After Width: | Height: | Size: 104 KiB |
Before Width: | Height: | Size: 67 KiB After Width: | Height: | Size: 67 KiB |
Before Width: | Height: | Size: 18 KiB After Width: | Height: | Size: 18 KiB |
Before Width: | Height: | Size: 19 KiB After Width: | Height: | Size: 19 KiB |
Before Width: | Height: | Size: 76 KiB After Width: | Height: | Size: 76 KiB |
Before Width: | Height: | Size: 24 KiB After Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 148 KiB After Width: | Height: | Size: 148 KiB |
Before Width: | Height: | Size: 56 KiB After Width: | Height: | Size: 56 KiB |
Before Width: | Height: | Size: 70 KiB After Width: | Height: | Size: 70 KiB |
Before Width: | Height: | Size: 983 B After Width: | Height: | Size: 983 B |
Before Width: | Height: | Size: 6.2 KiB After Width: | Height: | Size: 6.2 KiB |
Before Width: | Height: | Size: 207 B After Width: | Height: | Size: 207 B |
Before Width: | Height: | Size: 227 B After Width: | Height: | Size: 227 B |
Before Width: | Height: | Size: 638 B After Width: | Height: | Size: 638 B |