2016-04-18 17:33:36 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace manager\module;
|
|
|
|
use \manager\sessionManager;
|
|
|
|
use \manager\Database;
|
|
|
|
use \manager\ManagerError;
|
|
|
|
use \manager\Repo;
|
2016-05-26 14:33:00 +00:00
|
|
|
use \manager\lightdb;
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
class subject{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* RETOURNE LE SUJET D'ID DONNE
|
|
|
|
*
|
|
|
|
* @id_subject<int> UID du sujet en question
|
|
|
|
*
|
|
|
|
* @return subject<Array> Tableau contenant les informations du sujet
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function getById($params){
|
|
|
|
extract($params);
|
|
|
|
|
|
|
|
/* [1] On recupere les donnees du sujet
|
|
|
|
=========================================================*/
|
|
|
|
$getUser = new Repo('subject/getById', array($id_subject));
|
|
|
|
$subject_data = $getUser->answer();
|
|
|
|
|
|
|
|
// Si aucun utilisateur n'est trouve
|
|
|
|
if( $subject_data === false ) return array('ModuleError' => ManagerError::ModuleError);
|
|
|
|
|
|
|
|
|
|
|
|
/* [2] Gestion du retour
|
|
|
|
=========================================================*/
|
|
|
|
return array(
|
|
|
|
'ModuleError' => ManagerError::Success,
|
|
|
|
'subject' => $subject_data
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* RETOURNE LA LISTE DE TOUS LES SUJETS
|
|
|
|
*
|
|
|
|
* @return subjects<Array> Tableau contenant les informations de tous les utilisateurs
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function getAll(){
|
|
|
|
/* [1] On recupere les donnees des utilisateurs
|
|
|
|
=========================================================*/
|
|
|
|
$getUsers = new Repo('subject/getAll');
|
|
|
|
$subjects_data = $getUsers->answer();
|
|
|
|
|
|
|
|
// Si aucun utilisateur n'est trouve
|
|
|
|
if( $subjects_data === false ) return array('ModuleError' => ManagerError::ModuleError);
|
|
|
|
|
|
|
|
/* [2] Gestion du retour
|
|
|
|
=========================================================*/
|
|
|
|
return array(
|
|
|
|
'ModuleError' => ManagerError::Success,
|
|
|
|
'subjects' => $subjects_data
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* CREATION D'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
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function create($params){
|
|
|
|
extract($params);
|
|
|
|
|
|
|
|
/* [0] Verification et formattage des INPUT
|
|
|
|
=========================================================*/
|
2016-04-18 20:45:55 +00:00
|
|
|
$id_facebook = !is_null($id_facebook) ? (int) $id_facebook : null;
|
|
|
|
$number = !is_null($number) ? Database::formatNumber($number) : null;
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
/* [1] Creation du sujet
|
|
|
|
=========================================================*/
|
2016-04-18 20:45:55 +00:00
|
|
|
$create = new Repo('subject/create', array($username, $firstname, $lastname, $id_facebook, $number));
|
2016-04-18 17:33:36 +00:00
|
|
|
$created_id = $create->answer();
|
|
|
|
|
|
|
|
// Si erreur de creation, on retourne une erreur
|
|
|
|
if( $created_id === false ) return array( 'ModuleError' => ManagerError::ModuleError );
|
|
|
|
|
|
|
|
/* [2] Gestion du retour
|
|
|
|
=========================================================*/
|
|
|
|
return array(
|
|
|
|
'ModuleError' => ManagerError::Success,
|
2016-04-18 20:45:55 +00:00
|
|
|
'id_subject' => $created_id
|
2016-04-18 17:33:36 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* SUPPRESSION D'UN SUJET
|
|
|
|
*
|
|
|
|
* @id_subject<int> UID du sujet en question
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function remove($params){
|
|
|
|
extract($params);
|
|
|
|
|
|
|
|
/* [1] On verifie que le sujet existe
|
|
|
|
=========================================================*/
|
|
|
|
$exists = new Repo('subject/getById', array($id_subject));
|
|
|
|
$exists_status = $exists->answer();
|
|
|
|
|
|
|
|
// Si le sujet n'existe pas, on retourne une erreur
|
|
|
|
if( $exists_status === false ) return array( 'ModuleError' => ManagerError::ModuleError );
|
|
|
|
|
|
|
|
/* [2] Suppression du sujet
|
|
|
|
=========================================================*/
|
|
|
|
$remove = new Repo('subject/remove', array($id_subject));
|
|
|
|
$remove_status = $remove->answer();
|
|
|
|
|
2016-05-09 09:01:43 +00:00
|
|
|
// Si erreur lors de la requête
|
|
|
|
if( $remove_status === false )
|
|
|
|
return array( 'ModuleError' => ManagerError::ModuleError );
|
|
|
|
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
/* [3] On verifie que le sujet est bien supprime
|
|
|
|
=========================================================*/
|
|
|
|
$removed = new Repo('subject/getById', array($id_subject));
|
|
|
|
$removed_status = $removed->answer();
|
|
|
|
|
|
|
|
// Si le sujet n'existe pas, on retourne une erreur
|
|
|
|
if( $removed_status !== false ) return array( 'ModuleError' => ManagerError::ModuleError );
|
|
|
|
|
|
|
|
|
|
|
|
/* [4] Gestion du retour
|
|
|
|
=========================================================*/
|
|
|
|
return array( 'ModuleError' => ManagerError::Success );
|
|
|
|
}
|
|
|
|
|
2016-05-26 14:33:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* RECHERCHE DE SUJETS
|
|
|
|
*
|
|
|
|
* @name<String> Nom du sujet recherché
|
|
|
|
*
|
|
|
|
* @return results<Array> Tableau contenant les résultats
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public static function search($params){
|
|
|
|
extract($params);
|
|
|
|
|
|
|
|
// Contiendra les sujets
|
|
|
|
$subjects = array();
|
|
|
|
|
|
|
|
|
|
|
|
/* [0] Notre fonction de recherche (comparaison)
|
|
|
|
=========================================================*/
|
|
|
|
function compareSearch($A, $B){
|
|
|
|
// {1} On supprime les espaces et tout en minuscule //
|
|
|
|
$A = str_replace(' ', '', strtolower($A));
|
|
|
|
$B = str_replace(' ', '', strtolower($B));
|
|
|
|
|
|
|
|
// {2} On vérifie si A est dans B et inversement //
|
|
|
|
if( strpos($A, $B) !== false ) return true;
|
|
|
|
if( strpos($B, $A) !== false ) return true;
|
|
|
|
|
|
|
|
return $A == $B;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* [1] On récupére la liste des sujets pour PHONE
|
|
|
|
=========================================================*/
|
|
|
|
/* (1) On initialise et ouvre la bd */
|
|
|
|
$db = new lightdb('phone_db', __ROOT__.'/src/dynamic/');
|
|
|
|
$ids = array_keys( $db->index() );
|
|
|
|
|
|
|
|
/* (2) On récupère tous les sujets */
|
|
|
|
foreach($ids as $id){
|
|
|
|
$sub = $db->fetch($id)['subject'];
|
2016-05-26 17:43:50 +00:00
|
|
|
if( compareSearch($name, $sub['name']) ){
|
|
|
|
|
|
|
|
if( !isset($subjects[$id]) )
|
|
|
|
$subjects[$id] = $sub;
|
|
|
|
|
|
|
|
$subjects[$id]['phone'] = true;
|
|
|
|
}
|
2016-05-26 14:33:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* (3) On ferme la bd */
|
|
|
|
$db->close();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* [2] On récupére la liste des sujets pour FACEBOOK
|
|
|
|
=========================================================*/
|
|
|
|
/* (1) On initialise et ouvre la bd */
|
|
|
|
$db = new lightdb('facebook_db', __ROOT__.'/src/dynamic/');
|
|
|
|
$ids = array_keys( $db->index() );
|
|
|
|
|
|
|
|
/* (2) On récupère tous les sujets */
|
|
|
|
foreach($ids as $id){
|
|
|
|
$sub = $db->fetch($id)['subject'];
|
2016-05-26 17:43:50 +00:00
|
|
|
if( compareSearch($name, $sub['name']) ){
|
|
|
|
|
|
|
|
if( !isset($subjects[$id]) )
|
|
|
|
$subjects[$id] = $sub;
|
|
|
|
|
|
|
|
$subjects[$id]['facebook'] = true;
|
|
|
|
}
|
2016-05-26 14:33:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* (3) On ferme la bd */
|
|
|
|
$db->close();
|
|
|
|
|
|
|
|
|
|
|
|
/* [3] On récupére la liste des sujets pour SURVEYS
|
|
|
|
=========================================================*/
|
|
|
|
/* (1) On initialise et ouvre la bd */
|
|
|
|
$db = new lightdb('survey_db', __ROOT__.'/src/dynamic/');
|
|
|
|
$ids = array_keys( $db->index() );
|
|
|
|
|
|
|
|
/* (2) On récupère tous les sujets */
|
|
|
|
foreach($ids as $id){
|
|
|
|
$sub = $db->fetch($id)['subject'];
|
2016-05-26 17:43:50 +00:00
|
|
|
if( compareSearch($name, $sub['name']) ){
|
|
|
|
|
|
|
|
if( !isset($subjects[$id]) )
|
|
|
|
$subjects[$id] = $sub;
|
|
|
|
|
|
|
|
$subjects[$id]['survey'] = true;
|
|
|
|
$subjects[$id]['name'] = $sub['name'];
|
|
|
|
}
|
2016-05-26 14:33:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* (3) On ferme la bd */
|
|
|
|
$db->close();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* [4] Retour des données
|
|
|
|
=========================================================*/
|
|
|
|
return array(
|
|
|
|
'ModuleError' => ManagerError::Success,
|
|
|
|
'results' => $subjects
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
2016-04-18 17:33:36 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
?>
|