2022-08-13 12:04:17 +00:00
< ? php
2022-09-06 18:15:59 +00:00
// Include server connection
2022-09-13 16:07:01 +00:00
include dirname ( __DIR__ ) . " /server/conn.php " ;
2022-09-06 18:15:59 +00:00
2022-08-13 12:04:17 +00:00
/*
|-------------------------------------------------------------
2022-09-06 18:15:59 +00:00
| Login
2022-08-13 12:04:17 +00:00
|-------------------------------------------------------------
2022-09-06 18:15:59 +00:00
| This is annoying because I want to keep the website secure
| but I have no clue how to keep things secure with HTML , PHP
| or JS . So I hope seperating the scripts and putting all this
| into a PHP file is a good secutiry mesure
2022-08-13 12:04:17 +00:00
|-------------------------------------------------------------
*/
2022-09-06 18:15:59 +00:00
if ( isset ( $_POST [ 'submit_login' ])) {
/*
|-------------------------------------------------------------
| Set error status to 0
|-------------------------------------------------------------
| if there are more than 0 error , then they cannot submit a
| request
|-------------------------------------------------------------
*/
$error = 0 ;
// Checking if Username is empty
if ( empty ( trim ( $_POST [ " username " ]))) {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Who dis?' , 'You must enter a username to login!' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-09-06 18:15:59 +00:00
</ script >
< ? php
$error = $error + 1 ;
} else {
$username = trim ( $_POST [ " username " ]);
}
// Check if Password is empty
if ( empty ( trim ( $_POST [ " password " ]))) {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Whats the magic word?' , 'Pls enter the super duper secrete word(s) to login!' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-09-06 18:15:59 +00:00
</ script >
< ? php
$error = $error + 1 ;
} else {
$password = trim ( $_POST [ " password " ]);
}
if ( $error <= 0 ) {
// Prepare so SQL doesnt get spooked
$sql = " SELECT id, username, password FROM users WHERE username = ? " ;
2022-08-13 12:04:17 +00:00
2022-09-06 18:15:59 +00:00
if ( $stmt = mysqli_prepare ( $conn , $sql )) {
// Bind dis shit
mysqli_stmt_bind_param ( $stmt , " s " , $param_username );
// Set parameters
$param_username = $username ;
// Attempt to execute the prepared statement
if ( mysqli_stmt_execute ( $stmt )) {
// Store result
mysqli_stmt_store_result ( $stmt );
// Check if username exists, if yes then verify password
if ( mysqli_stmt_num_rows ( $stmt ) == 1 ) {
// Bind result variables
mysqli_stmt_bind_result ( $stmt , $id , $username , $hashed_password );
if ( mysqli_stmt_fetch ( $stmt )) {
if ( password_verify ( $password , $hashed_password )) {
// Password is correct, so start a new session
session_start ();
// Store data in session variables
$_SESSION [ " loggedin " ] = true ;
$_SESSION [ " id " ] = $id ;
$_SESSION [ " username " ] = $username ;
// let the user know
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'O hi <?php echo $_SESSION["username"]; ?>' , 'You are now logged in! You will be redirected in a few seconds' , 'var(--green)' , 'assets/icons/hand-waving.svg' );
setTimeout ( function (){ window . location . href = " index.php " ;}, 2000 );
//window.location.href = "../index.php?login=success";
2022-09-06 18:15:59 +00:00
</ script >
< ? php
} else {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Sus' , 'Username or Password WRONG, please try again :3' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-09-06 18:15:59 +00:00
</ script >
< ? php
}
}
} else {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Sus' , 'Username or Password WRONG, please try again :3' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-09-06 18:15:59 +00:00
</ script >
< ? php
}
} else {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'woops...' , 'Sowwy, something went wrong on our end :c' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-09-06 18:15:59 +00:00
</ script >
< ? php
}
// Close statement
mysqli_stmt_close ( $stmt );
}
}
}
/*
|-------------------------------------------------------------
| Signup
|-------------------------------------------------------------
| The dreaded signup . Please save me ...
|-------------------------------------------------------------
*/
if ( isset ( $_POST [ 'submit_signup' ])) {
2022-08-13 12:04:17 +00:00
/*
|-------------------------------------------------------------
| Set error status to 0
|-------------------------------------------------------------
| if there are more than 0 error , then they cannot submit a
| request
|-------------------------------------------------------------
*/
$error = 0 ;
if ( empty ( trim ( $_POST [ " username " ]))) {
// Username not entered
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Hmmm' , 'You must enter a username!' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
} elseif ( ! preg_match ( '/^[a-zA-Z0-9_]+$/' , trim ( $_POST [ " username " ]))) {
// Username entered contains illegal characters
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Sussy Wussy' , 'Very sus. Username can only contain letters, numbers, and underscores' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
} else {
// Prepare sql for sus
$sql = " SELECT id FROM users WHERE username = ? " ;
if ( $stmt = mysqli_prepare ( $conn , $sql )) {
mysqli_stmt_bind_param ( $stmt , " s " , $username_request );
$username_request = trim ( $_POST [ " username " ]);
if ( mysqli_stmt_execute ( $stmt )) {
// Ask sql nicely if other usernames exist and store info
mysqli_stmt_store_result ( $stmt );
if ( mysqli_stmt_num_rows ( $stmt ) == 1 ) {
// Username taken
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'A clone?' , 'Sorry, but username was already taken by someone else' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
} else {
$username = trim ( $_POST [ " username " ]);
}
} else {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Reee' , 'We had a problem on our end, sowwy' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
}
// Outa here with this
mysqli_stmt_close ( $stmt );
}
}
// Validate sussness of Password
if ( empty ( trim ( $_POST [ " password " ]))) {
// No password entered
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'What' , 'You must enter a password, dont want just anyone seeing your stuff uwu' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
} elseif ( strlen ( trim ( $_POST [ " password " ])) < 6 ){
// Password not long enough 👀
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( '👀' , 'Nice (Password) but its not long enough 👀' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
} else {
$password = trim ( $_POST [ " password " ]);
}
// Validate sussiness of the other Password
if ( empty ( trim ( $_POST [ " confirm_password " ]))) {
// Did not confirm passowrd
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Eh?' , 'Confirm the password pls, its very important you remember what it issss' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
} else {
$confirm_password = trim ( $_POST [ " confirm_password " ]);
if ( empty ( $error ) && $confirm_password != $password ) {
// Password and re-entered Password does not match
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Try again' , 'Passwords need to be the same, smelly smelly' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
}
}
// Check for invite code
if ( isset ( $_POST [ 'token' ])) {
// Check if invite code is empty
if ( empty ( $_POST [ 'token' ])) {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'smelly' , 'Enter Invite Code ;3' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
} else {
// Prepare sql for sus
$sql = " SELECT id FROM tokens WHERE code = ? AND used = 0 " ;
if ( $stmt = mysqli_prepare ( $conn , $sql )) {
mysqli_stmt_bind_param ( $stmt , " s " , $param_code );
$param_code = $_POST [ 'token' ];
// Ask sql nicely if other usernames exist and store info
if ( mysqli_stmt_execute ( $stmt )) {
mysqli_stmt_store_result ( $stmt );
if ( mysqli_stmt_num_rows ( $stmt ) == 1 ) {
$token = trim ( $_POST [ " token " ]);
} else {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Argh' , 'Your invite code/token did not check out, woopsie!' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
}
} else {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Woops' , 'The server or website died inside and could not process your information, sowwy!' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
$error = $error + 1 ;
}
// Outa here with this
mysqli_stmt_close ( $stmt );
}
}
}
// Checking for errors
if ( $error <= 0 ) {
$sql = " INSERT INTO users (username, password) VALUES (?, ?) " ;
if ( $stmt = mysqli_prepare ( $conn , $sql )) {
// Bind variables to the prepared statement as parameters
mysqli_stmt_bind_param ( $stmt , " ss " , $param_username , $param_password );
// Set parameters
$param_username = $username ;
$param_password = password_hash ( $password , PASSWORD_DEFAULT );
// Attempt to execute the prepared statement
if ( mysqli_stmt_execute ( $stmt )) {
// Prepare sql
$sql = " UPDATE tokens SET used = True WHERE code = ? " ;
$stmt = mysqli_prepare ( $conn , $sql );
mysqli_stmt_bind_param ( $stmt , " s " , $param_token );
$param_token = $_POST [ 'token' ];
if ( mysqli_stmt_execute ( $stmt )) {
//
// Hey fluffy why didn't you do this
// Hey fluffy, thats not how you do this
// Thats wrong! Do this instead!!!!!!
//
// I DON'T KNOW HOW TO DO THIS, BUT IT WORKS
// SO LEAVE ME ALONEEEEEEEEEE
// anyway....
// Generate Token
$token_array = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890abcdefghijklmnopqrstuvwxyz' ;
$new_token = substr ( str_shuffle ( $token_array ), 0 , 15 );
// Prepare sql
$sql = " INSERT INTO tokens (code, used) VALUES(?, False) " ;
$stmt = mysqli_prepare ( $conn , $sql );
mysqli_stmt_bind_param ( $stmt , " s " , $param_new_token );
$param_new_token = $new_token ;
mysqli_stmt_execute ( $stmt );
}
// Yupeee! Account was made
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Success!' , 'You account made for <?php echo $username; ?>!!!!! You must now login' , 'var(--green)' , 'assets/icons/hand-waving.svg' );
2022-09-06 18:15:59 +00:00
//setTimeout(function(){window.location.href = "../account/login.php";}, 2000);
loginShow ();
2022-08-13 12:04:17 +00:00
</ script >
< ? php
} else {
?>
< script >
2022-09-07 09:41:18 +00:00
sniffleAdd ( 'Bruh' , 'Something went fuckywucky, please try later' , 'var(--red)' , 'assets/icons/cross.svg' );
2022-08-13 12:04:17 +00:00
</ script >
< ? php
}
}
}
2022-09-06 18:15:59 +00:00
}