You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
105 lines
4.4 KiB
105 lines
4.4 KiB
<?php
|
|
include('Connection.php');
|
|
|
|
Class UserGateway{
|
|
private Connection $con;
|
|
|
|
public function __construct(Connection $con){
|
|
$this->con=$con;
|
|
}
|
|
|
|
public function insert(string $username,string $email,string $passwd):int{
|
|
|
|
// récupération id
|
|
$query='SELECT id_user FROM Users WHERE id_user >= ALL (SELECT id_user FROM Users);';
|
|
$this->con->executeQuery($query);
|
|
$result=$this->con->getResults();
|
|
foreach($result as $row){
|
|
$id=$row['id_user'] + 1;
|
|
}
|
|
// insertion user
|
|
$query='INSERT INTO Users VALUES (:id,:username,:email,:passwd,CURRENT_DATE,false);';
|
|
$this->con->executeQuery($query,array(':id' => array($id,PDO::PARAM_INT),':username' => array($u->username,PDO::PARAM_STR),':email' => array($u->email,PDO::PARAM_STR),':passwd' => array($u->passwd,PDO::PARAM_STR)));
|
|
return $id;
|
|
}
|
|
|
|
public function delete(int $id){
|
|
|
|
// supretion user
|
|
$query='DELETE FROM Users WHERE id_user = :id;';
|
|
$this->con->executeQuery($query,array(':id' => array($id,PDO::PARAM_INT)));
|
|
}
|
|
|
|
public function getFavorite(int $id):array{
|
|
|
|
//obtention favoris d'un user
|
|
$query='SELECT * FROM Quote WHERE id_quote IN (SELECT id_quote IN Favorite f JOIN User u ON u.id_user = f.user WHERE id_user = :id);';
|
|
$this->con->executeQuery($query,array(':id' => array($id,PDO::PARAM_INT)));
|
|
$result=$this->con->getResults();
|
|
return $result;
|
|
}
|
|
|
|
public function donneeUser(string $id):array{
|
|
$query = 'SELECT * FROM Users WHERE id_user=:idUser';
|
|
$this->con->executeQuery($query, array(':idUser'=>array($id, PDO::PARAM_STR)));
|
|
$result = $this->con->getResults();
|
|
return $result;
|
|
}
|
|
|
|
// ===================== UPDATE FUNCTION =====================
|
|
|
|
public function updateUsername(string $id, string $newUsername):array{
|
|
//Update le nom du user passé en paramètre
|
|
$queryUpdate = 'UPDATE Users SET username=:newUsername WHERE id_user=:idUser';
|
|
$this->con->executeQuery($queryUpdate, array(':idUser'=>array($id, PDO::PARAM_STR), ':newUsername'=> array($newUsername, PDO::PARAM_STR)));
|
|
|
|
//Renvoie le nouveau nom du user
|
|
$queryReponse = 'SELECT username FROM Users WHERE id_user=:idUser';
|
|
$this->con->executeQuery($queryReponse, array($id=>array($newUsername, PDO::PARAM_STR)));
|
|
return $result;
|
|
}
|
|
|
|
public function updateEmail(string $id, string $newEmail):array{
|
|
//Update le email du user passé en paramètre
|
|
$queryUpdate = 'UPDATE Users SET email=:newEmail WHERE id_user=:idUser';
|
|
$this->con->executeQuery($queryUpdate, array(':idUser'=>array($id, PDO::PARAM_STR), ':newEmail'=> array($newEmail, PDO::PARAM_STR)));
|
|
|
|
//Renvoie le nouveau email du user
|
|
$queryReponse = 'SELECT email FROM Users WHERE id_user=:idUser';
|
|
$con->executeQuery($queryReponse, array(':idUser'=>array($id, PDO::PARAM_STR)));
|
|
$result = $con->getResults();
|
|
return $result;
|
|
}
|
|
|
|
public function updateImg(string $id, string $newImg):array{
|
|
//Update l'image du user passé en paramètre
|
|
$query = 'UPDATE Users SET img=:newImg WHERE id_user=:idUser';
|
|
$this->con->executeQuery($query, array(':idUser'=>array($id, PDO::PARAM_STR), ':newImg'=> array($newImg, PDO::PARAM_STR)));
|
|
|
|
//Renvoie la nouvelle image du user
|
|
$queryReponse = 'SELECT img FROM Users WHERE id_user=:idUser';
|
|
$con->executeQuery($queryReponse, array(':idUser'=>array($id, PDO::PARAM_STR)));
|
|
$result = $this->con->getResults();
|
|
return $result;
|
|
}
|
|
|
|
public function updatePasswd(string $id, string $newPassWd):array{
|
|
//Update le passwd du user passé en paramètre
|
|
$query = 'UPDATE Users SET pssword=:newPassWd WHERE id_user=:idUser';
|
|
$this->con->executeQuery($query, array(':idUser'=>array($id, PDO::PARAM_STR), ':newPassWd'=> array($newPassWd, PDO::PARAM_STR)));
|
|
|
|
//Renvoie le nouveau passwd du user
|
|
$queryReponse = 'SELECT pssword FROM Users WHERE id_user=:idUser';
|
|
$con->executeQuery($queryReponse, array(':idUser'=>array($id, PDO::PARAM_STR)));
|
|
$result = $this->con->getResults();
|
|
return $result;
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//$uG = new UserGateway(new Connection("pgsql:host=londres;dbname=dbkekentin","kekentin",""));
|
|
$uG = new UserGateway(new Connection("pgsql:host=londres;dbname=dblebeaulato","lebeaulato",""));
|
|
$uG->delete(2);
|
|
?>
|