2016-04-18 17:33:36 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace manager\repo;
|
|
|
|
use \manager\Database;
|
|
|
|
use \manager\sessionManager;
|
|
|
|
|
2016-04-19 11:44:41 +00:00
|
|
|
class subject extends parentRepo{
|
|
|
|
|
2016-04-19 12:35:40 +00:00
|
|
|
protected static function table_name(){ static $table_name = 'sujets'; return $table_name; }
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* RETOURNE LES DONNEES D'UN SUJET D'ID DONNE
|
|
|
|
*
|
|
|
|
* @id_subject<int> UID du sujet en question
|
|
|
|
*
|
|
|
|
* @return subject<Array> Tableau contenant les donnees du sujet s'il existe sinon retourne FALSE
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function getById($id_subject){
|
|
|
|
/* [1] On effectue la requete
|
|
|
|
=========================================================*/
|
2016-04-19 12:35:40 +00:00
|
|
|
$getSubject = Database::getPDO()->prepare("SELECT idSujet, pseudo, prenom, nom, id_facebook, telephone
|
|
|
|
FROM sujets
|
|
|
|
WHERE idSujet = :id_subject");
|
2016-05-09 09:01:43 +00:00
|
|
|
$get_status = $getSubject->execute(array( ':id_subject' => $id_subject ));
|
|
|
|
|
|
|
|
// Si erreur de requête
|
|
|
|
if( $get_status === false )
|
|
|
|
return false;
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* [2] On recupere le resultat de la requete
|
|
|
|
=========================================================*/
|
|
|
|
$subjectData = $getSubject->fetch();
|
|
|
|
|
|
|
|
// Si l'utilisateur n'existe pas, on retourne FALSE
|
|
|
|
if( $subjectData === false ) return false;
|
|
|
|
|
|
|
|
/* [3] Gestion du retour
|
|
|
|
=========================================================*/
|
|
|
|
return Database::delNumeric( $subjectData, true );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* RETOURNE LES DONNEES DE TOUS LES SUJETS
|
|
|
|
*
|
|
|
|
* @return subjects<Array> Tableau contenant les donnees des sujets, retourne FALSE si erreur
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function getAll(){
|
|
|
|
/* [1] On effectue la requete
|
|
|
|
=========================================================*/
|
2016-04-19 12:35:40 +00:00
|
|
|
$getSubjects = Database::getPDO()->query("SELECT idSujet, pseudo, prenom, nom, id_facebook, telephone
|
|
|
|
FROM sujets
|
|
|
|
ORDER BY idSujet ASC");
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* [2] On recupere le resultat de la requete
|
|
|
|
=========================================================*/
|
|
|
|
$subjectsData = $getSubjects->fetchAll();
|
|
|
|
|
|
|
|
// Si l'utilisateur n'existe pas, on retourne FALSE
|
|
|
|
if( $subjectsData === false ) return false;
|
|
|
|
|
|
|
|
/* [3] Gestion du retour
|
|
|
|
=========================================================*/
|
|
|
|
return Database::delNumeric( $subjectsData );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* CREE UN SUJET
|
|
|
|
*
|
2016-04-18 20:45:55 +00:00
|
|
|
* @username<String> Pseudo du sujet
|
|
|
|
* @firstname<String> Prénom du sujet
|
|
|
|
* @lastname<String> Nom du sujet
|
|
|
|
* @id_facebook<int> Id facebook du sujet (optionnel)
|
|
|
|
* @number<String> Numéro de téléphone du sujet (optionnel)
|
2016-04-18 17:33:36 +00:00
|
|
|
*
|
|
|
|
* @return id_subject<int> Renvoie l'id du sujet cree ou FALSE si erreur
|
|
|
|
*
|
|
|
|
*/
|
2016-04-18 20:45:55 +00:00
|
|
|
public static function create($username, $firstname, $lastname, $id_facebook, $number){
|
2016-04-18 17:33:36 +00:00
|
|
|
/* [0] Verification et formattage des INPUT
|
|
|
|
=========================================================*/
|
2016-04-18 20:45:55 +00:00
|
|
|
$checkInput = Database::check('varchar(0,30)', $username);
|
|
|
|
$checkInput = $checkInput && Database::check('varchar(0,30)', $firstname);
|
|
|
|
$checkInput = $checkInput && Database::check('varchar(0,30)', $lastname);
|
|
|
|
$checkInput = $checkInput && !!strlen($username.$firstname.$lastname); // Pseudo, prénom, ou nom, au moins un n'est pas vide
|
|
|
|
$checkInput = $checkInput && ( Database::check('id', $id_facebook) || is_null($id_facebook) );
|
2016-04-30 14:50:46 +00:00
|
|
|
$checkInput = $checkInput && ( Database::check('number', $number) || is_null($number) );
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
// Si erreur en entree, on retourne FAUX
|
|
|
|
if( !$checkInput ) return false;
|
|
|
|
|
2016-04-18 20:45:55 +00:00
|
|
|
/* [1] On écrit la requête
|
2016-04-18 17:33:36 +00:00
|
|
|
=========================================================*/
|
2016-04-30 14:50:46 +00:00
|
|
|
$request_create_string = 'INSERT INTO sujets(idSujet, pseudo, nom, prenom, id_facebook, telephone) ';
|
|
|
|
$request_create_string .= 'VALUES (';
|
|
|
|
$request_create_string .= 'DEFAULT, '; // idPersone
|
|
|
|
$request_create_string .= strlen($username) ? ':pseudo, ' : 'NULL, '; // pseudo
|
|
|
|
$request_create_string .= strlen($lastname) ? ':nom, ' : 'NULL, '; // nom
|
|
|
|
$request_create_string .= strlen($firstname) ? ':prenom, ' : 'NULL, '; // prenom
|
|
|
|
$request_create_string .= !is_null($id_facebook) ? ':id_facebook, ' : 'NULL, '; // Id facebook
|
|
|
|
$request_create_string .= !is_null($number) ? ':number, ' : 'NULL, '; // Numéro de tél
|
|
|
|
// On retire la dernière virgule
|
|
|
|
$request_create_string = preg_replace('/, ?$/', '', $request_create_string);
|
|
|
|
$request_create_string .= ')';
|
|
|
|
|
|
|
|
// On crée la requête
|
|
|
|
$request_create = Database::getPDO()->prepare($request_create_string);
|
|
|
|
|
|
|
|
|
|
|
|
/* [2] On exécute la requête avec les valeurs
|
|
|
|
=========================================================*/
|
|
|
|
/* (1) On ajoute les paramètres à ajouter */
|
|
|
|
$variables = array();
|
|
|
|
if( strlen($username) ) $variables[':pseudo'] = $username;
|
|
|
|
if( strlen($lastname) ) $variables[':nom'] = $lastname;
|
|
|
|
if( strlen($firstname) ) $variables[':prenom'] = $firstname;
|
|
|
|
if( !is_null($id_facebook) ) $variables[':id_facebook'] = $id_facebook;
|
|
|
|
if( !is_null($number) ) $variables[':number'] = $number;
|
|
|
|
|
|
|
|
/* (2) On exécute la requête avec leurs variables utiles uniquement */
|
|
|
|
$status_created = $request_create->execute($variables);
|
|
|
|
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
/* [3] Verification de la creation + recuperation id
|
|
|
|
=========================================================*/
|
2016-04-30 14:50:46 +00:00
|
|
|
// Si erreur de création
|
|
|
|
if( $status_created === false ) return false;
|
|
|
|
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
// On recupere l'id du sujet
|
2016-04-30 14:50:46 +00:00
|
|
|
$id_subject = Database::getPDO()->lastInsertId();
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
// Si erreur, on retourne FALSE
|
2016-04-30 14:50:46 +00:00
|
|
|
if( $id_subject == null ) return false;
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
/* [4] Gestion du retour
|
|
|
|
=========================================================*/
|
2016-04-30 14:50:46 +00:00
|
|
|
return $id_subject;
|
2016-04-18 17:33:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* SUPRESSION D'UN SUJET D'ID DONNE
|
|
|
|
*
|
|
|
|
* @id_subject<int> UID du sujet en question
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function remove($id_subject){
|
2016-05-09 09:27:00 +00:00
|
|
|
/* [0] Vérification des INPUT
|
|
|
|
=========================================================*/
|
|
|
|
if( !Database::check('id', $id_subject) )
|
|
|
|
return false;
|
|
|
|
|
2016-04-18 17:33:36 +00:00
|
|
|
/* [1] On effectue la suppression
|
|
|
|
=========================================================*/
|
2016-05-09 09:01:43 +00:00
|
|
|
$delSubject = Database::getPDO()->prepare("DELETE FROM sujets WHERE idSujet = :id_subject");
|
|
|
|
return $delSubject->execute(array( ':id_subject' => $id_subject ));
|
2016-04-18 17:33:36 +00:00
|
|
|
}
|
|
|
|
|
2016-05-09 09:27:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* CREER UNE RELATION ENTRE 2 SUJETS
|
|
|
|
*
|
|
|
|
* @A<int> UID du premier sujet
|
|
|
|
* @B<int> UID du second sujet
|
|
|
|
* @category<String> Intitulé du type de relation
|
|
|
|
*
|
|
|
|
* @return id_relation<int> Renvoie l'id de la relation crée, sinon FALSE si erreur
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function link($A, $B, $category){
|
|
|
|
/* [0] Vérification des INPUT
|
|
|
|
=========================================================*/
|
|
|
|
$checkInput = Database::check('id', $A);
|
|
|
|
$checkInput = $checkInput && Database::check('id', $B);
|
2016-05-09 12:12:02 +00:00
|
|
|
$checkInput = $checkInput && ( Database::check('varchar(0,40)', $category) || is_null($category) );
|
2016-05-09 09:27:00 +00:00
|
|
|
|
|
|
|
// Si erreur de type de paramètre, on retourne FALSE
|
|
|
|
if( !$checkInput )
|
|
|
|
return false;
|
|
|
|
|
2016-05-09 12:12:02 +00:00
|
|
|
$nullCat = is_null($category);
|
2016-05-09 09:27:00 +00:00
|
|
|
|
|
|
|
/* [1] On vérifie l'existence de la catégorie
|
|
|
|
=========================================================*/
|
|
|
|
$category_exists_req = Database::getPDO()->prepare("SELECT idCategorie as id
|
|
|
|
FROM categories
|
2016-05-09 12:12:02 +00:00
|
|
|
WHERE intitule ".
|
|
|
|
( $nullCat ? "is NULL" : "= :category" )
|
|
|
|
);
|
|
|
|
$cat_ex_status = $category_exists_req->execute( ($nullCat) ? null : array( ':category' => $category ) );
|
2016-05-09 09:27:00 +00:00
|
|
|
|
|
|
|
// Si erreur de requête -> FALSE
|
|
|
|
if( $cat_ex_status === false )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// On récupère l'id de la catégorie, sinon NULL
|
|
|
|
$category_id = is_array($category_exists_req->fetch()) ? $category_exists_req->fetch()['id'] : null;
|
|
|
|
|
|
|
|
|
|
|
|
/* [2] On crée la catégorie si elle n'existe pas
|
|
|
|
=========================================================*/
|
|
|
|
if( $category_id === null ){
|
|
|
|
|
|
|
|
$create_category_req = Database::getPDO()->prepare("INSERT INTO categories(idCategorie, intitule)
|
2016-05-09 12:12:02 +00:00
|
|
|
VALUES(DEFAULT, ".
|
|
|
|
( $nullCat ? "NULL" : ":category" )
|
|
|
|
.")");
|
|
|
|
$create_cat_status = $create_category_req->execute( ($nullCat) ? null : array( ':category' => $category ) );
|
2016-05-09 09:27:00 +00:00
|
|
|
|
|
|
|
// Si erreur de requête -> FALSE
|
|
|
|
if( $create_cat_status === false )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// On récupère l'id de la catégorie
|
|
|
|
$get_category_id = Database::getPDO()->prepare("SELECT idCategorie as id
|
|
|
|
FROM categories
|
2016-05-09 12:12:02 +00:00
|
|
|
WHERE intitule ".
|
|
|
|
( $nullCat ? "is NULL" : "= :category" )
|
|
|
|
);
|
|
|
|
$get_cat_status = $get_category_id->execute( ($nullCat) ? null : array( ':category' => $category ) );
|
2016-05-09 09:27:00 +00:00
|
|
|
|
|
|
|
// Si erreur de requête -> FALSE
|
|
|
|
if( $get_cat_status === false )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// Si on a toujours rien, on retourne FALSE
|
|
|
|
if( !is_array($get_category_id->fetch()) )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// On récupère l'id de la catégorie
|
|
|
|
$category_id = $get_category_id->fetch()['id'];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* [3] On crée la relation
|
|
|
|
=========================================================*/
|
|
|
|
$create_relation = Database::getPDO()->prepare("INSERT INTO relations(idPersonneA, idPersonneB, idCategorie)
|
|
|
|
VALUES(:A, :B, :category)");
|
|
|
|
$create_rel_status = $create_relation->execute( array(
|
|
|
|
':A' => $A,
|
|
|
|
':B' => $B,
|
|
|
|
':category' => $category_id
|
|
|
|
));
|
|
|
|
|
2016-05-09 12:12:02 +00:00
|
|
|
return $B;
|
|
|
|
|
2016-05-09 09:27:00 +00:00
|
|
|
// Si erreur de requête -> FALSE
|
|
|
|
if( $create_rel_status === false )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
/* [4] On vérifie que la relation est crée
|
|
|
|
=========================================================*/
|
2016-05-09 09:46:12 +00:00
|
|
|
$check_relation = Database::getPDO()->prepare("SELECT idPersonneA, idPersonneB, idCategorie
|
2016-05-09 09:27:00 +00:00
|
|
|
FROM relations
|
|
|
|
WHERE idPersonneA = :A
|
|
|
|
AND idPersonneB = :B
|
|
|
|
AND idCategorie = :category");
|
|
|
|
|
|
|
|
$check_rel_status = $check_relation->execute( array(
|
|
|
|
':A' => $A,
|
|
|
|
':B' => $B,
|
|
|
|
':category' => $category_id
|
|
|
|
));
|
|
|
|
|
|
|
|
// Si erreur de requête -> FALSE
|
|
|
|
if( $check_rel_status === false )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
// Si on ne trouve pas, on retourne une erreur
|
|
|
|
if( $check_relation->fetch() === false )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
// Si tout s'est bien passé, on retourne TRUE
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-04-18 17:33:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
?>
|