You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
215 lines
6.3 KiB
PHP
215 lines
6.3 KiB
PHP
<?php
|
|
//geterror de l'index
|
|
function getErrorIndex($code)
|
|
{
|
|
switch ($code) {
|
|
case 1:
|
|
return "Adresse mail ou mot de passe invalide.";
|
|
}
|
|
}
|
|
|
|
function getErrorProfil($code)
|
|
{
|
|
switch ($code) {
|
|
case 1:
|
|
return "Ce login est déjà associé à un compte.";
|
|
case 2:
|
|
return "Les mots de passe ne correspondent pas.";
|
|
case 3:
|
|
return "Erreur lors de la récupération des informations de profil.";
|
|
case 4:
|
|
return "Le fichier envoyé doit être une image au format PNG ou JPEG.";
|
|
case 5:
|
|
return "La taille de l'image ne doit pas dépasser 2 MB.";
|
|
case 6:
|
|
return "Erreur lors de la modification du compte.";
|
|
}
|
|
}
|
|
|
|
function getErrorInscription($code)
|
|
{
|
|
switch ($code) {
|
|
case 1:
|
|
return "L'adresse mail est invalide.";
|
|
case 2:
|
|
return "Cette adresse est déjà associée à un compte.";
|
|
case 3:
|
|
return "Ce login est déjà associé à un compte.";
|
|
case 4:
|
|
return "Le fichier envoyé doit être une image au format PNG.";
|
|
case 5:
|
|
return "La taille de l'image ne doit pas dépasser 2 MB.";
|
|
case 6:
|
|
return "Erreur lors de la création du compte.";
|
|
}
|
|
}
|
|
|
|
function authentification($db, $mail, $password)
|
|
{
|
|
$result = pg_query_params($db, "SELECT * FROM Utilisateur WHERE mail = $1;", array($mail));
|
|
if ($result) {
|
|
$row = pg_fetch_array($result);
|
|
return (strcmp($row["passwd"], $password)) == 0;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function loginChange($user, $login)
|
|
{
|
|
return strcmp($user['login'], $login);
|
|
}
|
|
|
|
function isLoginUniqueModifier($db, $mail, $login)
|
|
{
|
|
$result = pg_query_params($db, "SELECT login FROM Utilisateur WHERE login = $1 AND mail != $2;", array($login, $mail));
|
|
if ($result) {
|
|
$row = pg_fetch_array($result);
|
|
return (strcmp($row['login'], $login) != 0);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function modifierLogin($db, $mail, $login)
|
|
{
|
|
$result = pg_query_params($db, "UPDATE Utilisateur SET login = $1 WHERE mail = $2;", array($login, $mail));
|
|
return $result;
|
|
}
|
|
|
|
function modifierUtilisateur($db, $mail, $prenom, $nom, $password, $phone)
|
|
{
|
|
$result = pg_query_params($db, "UPDATE Utilisateur SET prenom = $1, nom = $2, telephone = $3 , passwd = $4 WHERE mail = $5;", array($prenom, $nom, $phone, $password, $mail));
|
|
return $result;
|
|
}
|
|
|
|
function getUser($db, $mail)
|
|
{
|
|
$result = pg_query_params($db, "SELECT * FROM Utilisateur WHERE mail = $1;", array($mail));
|
|
return pg_fetch_array($result);
|
|
}
|
|
|
|
function getPrenom($db, $mail)
|
|
{
|
|
$result = pg_query_params($db, "SELECT prenom from Utilisateur WHERE mail = $1;", array($mail));
|
|
if ($result) {
|
|
$row = pg_fetch_array($result);
|
|
$prenom = $row[0];
|
|
return $prenom;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function getLogin($db, $mail)
|
|
{
|
|
$result = pg_query_params($db, "SELECT login from Utilisateur WHERE mail = $1;", array($mail));
|
|
if ($result) {
|
|
$row = pg_fetch_array($result);
|
|
$login = $row[0];
|
|
return $login;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function getPathImgProfilTableau($mail)
|
|
{
|
|
$list = scandir("../imageProfil");
|
|
foreach ($list as $entry) {
|
|
if (strpos($entry, $mail) !== false) {
|
|
return "../imageProfil/$entry";
|
|
}
|
|
}
|
|
return "../imageProfil/default.svg";
|
|
}
|
|
|
|
function getPathImgProfil($mail)
|
|
{
|
|
$list = scandir("../imageProfil");
|
|
foreach ($list as $entry) {
|
|
if (strpos($entry, $mail) !== false) {
|
|
return "../imageProfil/$entry";
|
|
}
|
|
}
|
|
return "../imageProfil/default.svg";
|
|
}
|
|
|
|
function supprimerAvatar($mail)
|
|
{
|
|
$list = scandir("../imageProfil");
|
|
foreach ($list as $entry) {
|
|
if (strpos($entry, $mail) !== false) {
|
|
unlink("../imageProfil/$entry");
|
|
}
|
|
}
|
|
}
|
|
|
|
function isMailUnique($db, $mail)
|
|
{
|
|
$result = pg_query_params($db, "SELECT * FROM Utilisateur WHERE mail = $1;", array($mail));
|
|
if ($result) {
|
|
$row = pg_fetch_array($result);
|
|
return (strcmp($row['mail'], $mail) != 0);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function isLoginUnique($db, $login)
|
|
{
|
|
$result = pg_query_params($db, "SELECT * FROM Utilisateur WHERE login = $1;", array($login));
|
|
if ($result) {
|
|
$row = pg_fetch_array($result);
|
|
return (strcmp($row['login'], $login) != 0);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function creerUtilisateur($db, $mail, $password, $prenom, $nom, $login, $phone, $dateN)
|
|
{
|
|
$result = pg_query_params($db, "INSERT INTO Utilisateur VALUES ($1, $2, $3, $4, $5, $6, to_date($7, 'YYYY/MM/DD'), false);", array($mail, $password, $prenom, $nom, $login, $phone, $dateN));
|
|
return $result;
|
|
}
|
|
|
|
function uploadAvatar($mail, $fic)
|
|
{
|
|
$tmp = explode('.', $fic['name']);
|
|
$extension = end($tmp);
|
|
$target_file = "../imageProfil/$mail.$extension";
|
|
$file_tmp = $fic['tmp_name'];
|
|
$check = getimagesize($file_tmp);
|
|
if ($check === false or !in_array($extension, array('png', 'jpg', 'jpeg', 'pjpeg', 'jfif', 'pjp'))) {
|
|
return -1;
|
|
} else if ($fic['size'] > 2 * 1024 * 1024) {
|
|
return -2;
|
|
} else {
|
|
if (!move_uploaded_file($file_tmp, $target_file)) {
|
|
return -3;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
function deluser($db, $delmail)
|
|
{
|
|
/*
|
|
$requete = "UPDATE public.utilisateur SET (mail, passwd, prenom, nom, login, telephone, datenaissance, estadmin) = ('utilisateur_supprime@local', '', '', '', 'utilisateur_supprime', '', to_date('1970/01/01','YYYY/MM/DD'), false) WHERE mail = '".$delmail."';";
|
|
marche pas
|
|
ERROR: duplicate key value violates unique constraint "pk_utilisateur"
|
|
DETAIL: Key (mail)=(utilisateur_supprime@local) already exists.
|
|
*/
|
|
|
|
/*
|
|
a faire = array('' => , );Delete l'utilisateur du reste de la base
|
|
*/
|
|
$requete = "UPDATE trajet SET mailproposition = 'utilisateur_supprime@local' WHERE mailproposition = $delmail;";
|
|
pg_query($db, $requete);
|
|
$requete = "UPDATE reserver SET mailutilisateur = 'utilisateur_supprime@local' WHERE mailutilisateur = $delmail;";
|
|
pg_query($db, $requete);
|
|
$requete = "DELETE FROM avis WHERE mailemetteur = $delmail;";
|
|
pg_query($db, $requete);
|
|
$requete = "DELETE FROM voiture WHERE mail = $delmail;";
|
|
pg_query($db, $requete);
|
|
$requete = "DELETE FROM utilisateur WHERE mail = $delmail;";
|
|
pg_query($db, $requete);
|
|
|
|
}
|
|
|
|
?>
|