stuff
This commit is contained in:
93
lib/account.php
Normal file
93
lib/account.php
Normal file
@@ -0,0 +1,93 @@
|
||||
<?php
|
||||
|
||||
function isLoggedIn(){
|
||||
return $_SESSION["ID"] > 0 && !empty($_SESSION["email"]);
|
||||
}
|
||||
|
||||
function doLogin(){
|
||||
global $mysqli;
|
||||
if(!empty($_POST["email"]) && !empty($_POST["password"])){
|
||||
$email = $_POST["email"];
|
||||
$pass = $_POST["password"];
|
||||
/* prepare statement */
|
||||
$stmt = $mysqli->prepare("SELECT ID, FirstName, LastName, Nickname, PasswordHash, MinecraftNick, isAdmin FROM Users WHERE EMAIL = ? AND isActive = 1");
|
||||
$stmt->bind_param("s", $email);
|
||||
$stmt->execute();
|
||||
$idcko = 0;
|
||||
$fname = "";
|
||||
$lname = "";
|
||||
$nickname = "";
|
||||
$pwdhash = "";
|
||||
$mcnick = "";
|
||||
$isadmin = false;
|
||||
/* bind variables to prepared statement */
|
||||
$stmt->bind_result($idcko, $fname, $lname, $nickname, $pwdhash, $mcnick, $isadmin);
|
||||
|
||||
$found = false;
|
||||
/* fetch values */
|
||||
while ($stmt->fetch()) {
|
||||
if (password_verify($pass, $pwdhash)){
|
||||
$_SESSION["ID"] = $idcko;
|
||||
$_SESSION["first_name"] = $fname;
|
||||
$_SESSION["last_name"] = $lname;
|
||||
$_SESSION["nickname"] = $nickname;
|
||||
$_SESSION["email"] = $email;
|
||||
$_SESSION["mcnick"] = $mcnick;
|
||||
$_SESSION["isadmin"] = $isadmin;
|
||||
$found = true;
|
||||
break;
|
||||
}
|
||||
else{
|
||||
$found = false;
|
||||
}
|
||||
break;
|
||||
}
|
||||
$stmt->close();
|
||||
if($found){
|
||||
$status = ["status" => "success"];
|
||||
}
|
||||
else{
|
||||
$status = ["status" => "fail"];
|
||||
}
|
||||
echo json_encode($status);
|
||||
}
|
||||
}
|
||||
|
||||
function doLogout(){
|
||||
if(isLoggedIn()){
|
||||
session_destroy();
|
||||
$status = ["status" => "success"];
|
||||
}
|
||||
else{
|
||||
$status = ["status" => "fail"];
|
||||
}
|
||||
echo json_encode($status);
|
||||
}
|
||||
|
||||
function doRegister(){
|
||||
$status = ["status" => "fail"];
|
||||
if (!empty($_POST["activationtoken"])){
|
||||
global $mysqli;
|
||||
|
||||
$firstName = $_POST["firstname"];
|
||||
$lastName = $_POST["lastname"];
|
||||
$nickname = $_POST["nickname"];
|
||||
$email = $_POST["email"];
|
||||
$password = $_POST["password"];
|
||||
$minecraftNick = $_POST["minecraftnick"];
|
||||
$activationToken = $_POST["activationtoken"];
|
||||
if (!empty($firstName) && !empty($lastName) && !empty($nickname) && !empty($email) && !empty($password) && !empty($activationToken)){
|
||||
$passwordHash = password_hash($password, PASSWORD_DEFAULT);
|
||||
|
||||
$stmt = $mysqli->prepare("UPDATE Users SET FirstName = ?, LastName = ?, Nickname = ?, Email = ?, PasswordHash = ?, MinecraftNick = ?, isAdmin = 0, isActivated = 1 WHERE isActivated = 0 AND ActivationToken = ?");
|
||||
$stmt->bind_param("ssssss", $firstName, $lastName, $nickname, $email, $passwordHash, $minecraftNick, $activationToken);
|
||||
$stmt->execute();
|
||||
if ($stmt->affected_rows > 0) {
|
||||
$status["status"] = "success";
|
||||
}
|
||||
$stmt->close();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
58
lib/navpages.php
Normal file
58
lib/navpages.php
Normal file
@@ -0,0 +1,58 @@
|
||||
<?php
|
||||
|
||||
function generateNavigation($static_page_dir, $protocol, $subdomain, $domain, $tld, $default_page, $page_name)
|
||||
{
|
||||
$navsite_template = '<li class="navsite_item"><a href="__LOCATION__" __CLASS__>__NAME__</a><ul class="navpage_list">__NAVPAGES__</ul></li>';
|
||||
$navpage_template = '<li class="navpage_item"><a href="__LOCATION__" __CLASS__>__NAME__</a></li>';
|
||||
|
||||
$site_dirs = array_diff(scandir($static_page_dir), array('.', '..'));
|
||||
|
||||
$nav_out = "";
|
||||
|
||||
foreach ($site_dirs as $site_dir) {
|
||||
$pages_dir = array_diff(scandir("$static_page_dir$site_dir"), array('.', '..'));
|
||||
|
||||
$navsite = $navsite_template;
|
||||
$site_class = "class=\"navsite_link\"";
|
||||
$site_name = str_replace("_", " ", $site_dir);
|
||||
if ($site_name == "global") {
|
||||
$site_name = "misc";
|
||||
$site_dir = $default_page;
|
||||
}
|
||||
$site_location = "$protocol$site_dir.$domain.$tld/$default_page";
|
||||
$navsite = str_replace("__CLASS__", $site_class, $navsite);
|
||||
$navsite = str_replace("__LOCATION__", $site_location, $navsite);
|
||||
$navsite = str_replace("__NAME__", $site_name.ucfirst(), $navsite);
|
||||
|
||||
if ($subdomain == $site_dir) {
|
||||
//this is the current page
|
||||
$site_class = "class=\"navsite_link active\"";
|
||||
}
|
||||
|
||||
$navpages = "";
|
||||
foreach ($pages_dir as $page_dir) {
|
||||
$page_dir = explode(".", $page_dir)[0];
|
||||
$navpage = $navpage_template;
|
||||
$page_class = "class=\"navpage_link\"";
|
||||
if ($subdomain == $site_dir && $page_name == $page_dir) {
|
||||
$page_class = "class=\"navpage_link active\"";
|
||||
}
|
||||
|
||||
$page_location = "$protocol$site_dir.$domain.$tld/$page_dir";
|
||||
|
||||
$page_name = str_replace("_", " ", $page_dir);
|
||||
$page_name = explode(".", $page_name)[0];
|
||||
|
||||
$navpage = str_replace("__CLASS__", $page_class, $navpage);
|
||||
$navpage = str_replace("__LOCATION__", $page_location, $navpage);
|
||||
$navpage = str_replace("__NAME__", $page_name, $navpage);
|
||||
$navpages .= $navpage;
|
||||
}
|
||||
$navsite = str_replace("__NAVPAGES__", $navpages, $navsite);
|
||||
$nav_out .= $navsite;
|
||||
}
|
||||
|
||||
return $nav_out;
|
||||
}
|
||||
|
||||
?>
|
40
lib/routing.php
Normal file
40
lib/routing.php
Normal file
@@ -0,0 +1,40 @@
|
||||
<?php
|
||||
|
||||
function getProtocol(){
|
||||
if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && !empty($_SERVER['HTTP_X_FORWARDED_PROTO'])) {
|
||||
return "https://";
|
||||
} else {
|
||||
return "http://";
|
||||
}
|
||||
}
|
||||
|
||||
function getPage($routerConfig){
|
||||
$page_dir = $routerConfig['page_dir'];
|
||||
|
||||
$dynamic_page_file = $page_dir . $subdomain . "/" . $page_name . ".php";
|
||||
$page_file = $page_dir . $subdomain . "/" . $page_name . ".html";
|
||||
|
||||
$dynamic_page_file_global = $page_dir . "global/" . $page_name . ".php";
|
||||
$page_file_global = $page_dir . "global/" . $page_name . ".html";
|
||||
|
||||
$skeleton = file_get_contents($template_dir . "skeleton.html");
|
||||
$nav = file_get_contents($template_dir . "nav.html");
|
||||
|
||||
if (file_exists($dynamic_page_file_global)){
|
||||
$page = include_once $dynamic_page_file_global;
|
||||
}
|
||||
elseif (file_exists($page_file_global)){
|
||||
$page = file_get_contents($page_file_global);
|
||||
}
|
||||
elseif (file_exists($dynamic_page_file)){
|
||||
$page = include_once $dynamic_page_file;
|
||||
}
|
||||
elseif (file_exists($page_file)){
|
||||
$page = file_get_contents($page_file);
|
||||
}
|
||||
else{
|
||||
$page = file_get_contents($template_dir . "404.html");
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
Reference in New Issue
Block a user