Last active
July 4, 2024 19:09
-
-
Save SajidK25/c3f93cd0b2f6e65b9abab4ca84c21b84 to your computer and use it in GitHub Desktop.
Assignment-3 PHP Annonymous Feedback
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
session_start(); | |
class Auth { | |
public static function login($username, $password) { | |
if (User::verifyPassword($username, $password)) { | |
$user = User::find($username); | |
print_r($user); | |
$_SESSION['username'] = $username; | |
$_SESSION['user_id'] = $user->getId(); | |
return true; | |
} | |
return false; | |
} | |
public static function logout() { | |
session_destroy(); | |
} | |
public static function isLoggedIn() { | |
return isset($_SESSION['username']); | |
} | |
public static function getUsername() { | |
return $_SESSION['username']; | |
} | |
public static function getUserId() { | |
return $_SESSION['user_id']; | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
require_once '../classes/User.php'; | |
require_once '../classes/Auth.php'; | |
if ($_SERVER['REQUEST_METHOD'] === 'POST') { | |
$username = $_POST['username']; | |
$password = $_POST['password']; | |
if (Auth::login($username, $password)) { | |
header('Location: dashboard.php'); | |
exit(); | |
} else { | |
echo 'Invalid username or password'; | |
} | |
} else { | |
include '../templates/login.html'; | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
require_once '../classes/User.php'; | |
require_once '../classes/Utils.php'; | |
if ($_SERVER['REQUEST_METHOD'] === 'POST') { | |
$username = $_POST['username']; | |
$password = $_POST['password']; | |
if (User::find($username) === null) { | |
$user = new User($username, $password); | |
$user->save(); | |
header('Location: login.php'); | |
exit(); | |
} else { | |
echo 'Username already exists'; | |
} | |
} else { | |
include '../templates/register.html'; | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{ | |
"admin":{ | |
"id":"6686c83583629", | |
"username":"admin", | |
"password":"$2y$10$Q8G3jlcQwNrymIFOPIM\/2eozzhxiPy1RpveWHvHWT6xKTK9Jx1tg." | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
class User { | |
private $username; | |
private $password; | |
private $id; | |
public function __construct($username, $password, $id = null) { | |
$this->username = $username; | |
// $this->password = password_hash($password, PASSWORD_DEFAULT); | |
$this->password = $this->isHashed($password) ? $password : password_hash($password, PASSWORD_BCRYPT); | |
$this->id = $id ? $id : uniqid(); | |
} | |
public function getUsername() { | |
return $this->username; | |
} | |
public function getPassword() { | |
return $this->password; | |
} | |
public function getId() { | |
return $this->id; | |
} | |
public function save() { | |
$users = json_decode(file_get_contents('../data/users.json'), true) ?: []; | |
$users[$this->username] = [ | |
'id' => $this->id, | |
'username' => $this->username, | |
'password' => $this->password | |
]; | |
file_put_contents('../data/users.json', json_encode($users)); | |
} | |
public static function find($username) { | |
$users = json_decode(file_get_contents('../data/users.json'), true) ?: []; | |
if (isset($users[$username])) { | |
$user_data = $users[$username]; | |
return new User($user_data['username'], $user_data['password'], $user_data['id']); | |
} | |
return null; | |
} | |
public static function verifyPassword($username, $password) { | |
$user = self::find($username); | |
if ($user) { | |
$storedPassword = $user->getPassword(); | |
$isVerified = password_verify($password, $storedPassword); | |
error_log('Username: ' . $username); | |
error_log('Provided Password: ' . $password); | |
error_log('Stored Password Hash: ' . $storedPassword); | |
error_log('Password Verified: ' . ($isVerified ? 'true' : 'false')); | |
return $isVerified; | |
} | |
error_log('User not found: ' . $username); | |
return false; | |
} | |
private function isHashed($password) { | |
$info = password_get_info($password); | |
return isset($info['algo']) && $info['algo'] !== 0; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment