177 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			177 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | ||
| /***
 | ||
|  * Copyright (c) 2022 DevRas
 | ||
|  * 
 | ||
|  */
 | ||
| 
 | ||
|  class User
 | ||
| {
 | ||
|     public function __construct($pdo)
 | ||
|     {
 | ||
|         $this->pdo = $pdo;
 | ||
|     }
 | ||
|     
 | ||
|     protected $pdo;
 | ||
| 
 | ||
|     public function formalPassword($password)
 | ||
|     {
 | ||
|         return hash("sha256", $password);
 | ||
|     }
 | ||
| 
 | ||
|     public function hasLogout()
 | ||
|     {
 | ||
|         $filter = filter_input(INPUT_GET, "logout");
 | ||
|         if ($filter)
 | ||
|         {
 | ||
|             return true;
 | ||
|         } else {
 | ||
|             return false;
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     public function hasLogin()
 | ||
|     {
 | ||
|         $username = filter_input(INPUT_POST, "username");
 | ||
|         $password = filter_input(INPUT_POST, "password");
 | ||
| 
 | ||
|         if (!$username || !$password)
 | ||
|         {
 | ||
|             return false;
 | ||
|         }
 | ||
| 
 | ||
|         $result = $this->Login($username, $password);
 | ||
| 
 | ||
|         return $result;
 | ||
|     }
 | ||
| 
 | ||
|     public function hasUpdatePassword()
 | ||
|     {
 | ||
|         $username = filter_input(INPUT_POST, "username");
 | ||
|         $password = filter_input(INPUT_POST, "password");
 | ||
|         $newPassword = filter_input(INPUT_POST, "newPassword");
 | ||
| 
 | ||
|         if (!$username || !$password || !$newPassword)
 | ||
|         {
 | ||
|             return false;
 | ||
|         }
 | ||
| 
 | ||
|         $currentUser = $this->Login($username, $password);
 | ||
|         if (!$currentUser)
 | ||
|         {
 | ||
|             return false;
 | ||
|         }
 | ||
| 
 | ||
|         $result = $this->updatePassword($currentUser, $newPassword);
 | ||
| 
 | ||
|         return $result;
 | ||
|     }
 | ||
| 
 | ||
|     public function hasCreate()
 | ||
|     {
 | ||
|         $username = filter_input(INPUT_POST, "username");
 | ||
|         $password = filter_input(INPUT_POST, "password");
 | ||
|         $mode = filter_input(INPUT_POST, "mode");
 | ||
| 
 | ||
|         if (!$username || !$password || !$mode)
 | ||
|         {
 | ||
|             return false;
 | ||
|         }
 | ||
| 
 | ||
|         $result = $this->Create($username, $password);
 | ||
| 
 | ||
|         return $result;
 | ||
|     }
 | ||
| 
 | ||
|     public function updatePassword($currentUser, $newPassword)
 | ||
|     {
 | ||
|         try {
 | ||
|             $formal = $this->formalPassword($newPassword);
 | ||
| 
 | ||
|             $smt = $this->pdo->prepare("UPDATE users SET password=? WHERE id=?");
 | ||
|             $smt->execute([
 | ||
|                 $formal,
 | ||
|                 $currentUser["id"]
 | ||
|             ]);
 | ||
| 
 | ||
|             return true;
 | ||
|         } catch (\PDOException $e)
 | ||
|         {
 | ||
|             throw new \RuntimeException("SQLエラーが発生しました。パスワードの更新に失敗しました。");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     public function Login($username, $password)
 | ||
|     {
 | ||
|         try {
 | ||
|             $formal = $this->formalPassword($password);
 | ||
| 
 | ||
|             $smt = $this->pdo->prepare("SELECT * FROM users WHERE username=? AND password=?;");
 | ||
|             $smt->execute([
 | ||
|                 $username,
 | ||
|                 $formal
 | ||
|             ]);
 | ||
| 
 | ||
|             return $smt->fetch();
 | ||
|         } catch (\PDOException $e)
 | ||
|         {
 | ||
|             throw new \RuntimeException("SQLエラーが発生しました。発生箇所:UserLogin");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     public function Create($username, $password)
 | ||
|     {
 | ||
|         $user = $this->getUser($username);
 | ||
|         if ($user)
 | ||
|         {
 | ||
|             throw new \RuntimeException("操作を続行できません。そのユーザー名は既に存在します。");
 | ||
|         }
 | ||
| 
 | ||
|         try {
 | ||
|             $smt = $this->pdo->prepare("INSERT INTO users(username, password) VALUES(?, ?);");
 | ||
|             $formal = $this->formalPassword($password);
 | ||
| 
 | ||
|             $smt->execute([
 | ||
|                 $username,
 | ||
|                 $formal
 | ||
|             ]);
 | ||
| 
 | ||
|             return true;
 | ||
|         } catch (\PDOException $e)
 | ||
|         {
 | ||
|             throw new \RuntimeException("SQLエラーが発生しました。発生箇所:createUser");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     public function getUser($username)
 | ||
|     {
 | ||
|         try {
 | ||
|             $smt = $this->pdo->prepare("SELECT * FROM users WHERE username=?");
 | ||
| 
 | ||
|             $smt->execute([
 | ||
|                 $username
 | ||
|             ]);
 | ||
| 
 | ||
|             return $smt->fetch();
 | ||
|         } catch (\PDOException $e)
 | ||
|         {
 | ||
|             throw new \RuntimeException("SQLエラーが発生しました。発生箇所:getUser");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     public function getUserById($id)
 | ||
|     {
 | ||
|         try {
 | ||
|             $smt = $this->pdo->prepare("SELECT * FROM users WHERE id=?");
 | ||
| 
 | ||
|             $smt->execute([
 | ||
|                 $id
 | ||
|             ]);
 | ||
| 
 | ||
|             return $smt->fetch();
 | ||
|         } catch (\PDOException $e)
 | ||
|         {
 | ||
|             throw new \RuntimeException("SQLエラーが発生しました。発生箇所:getUser");
 | ||
|         }
 | ||
|     }
 | ||
| }
 |