NxTIC/manager/module/subject.php

342 lines
9.2 KiB
PHP
Raw Normal View History

<?php
namespace manager\module;
use \manager\sessionManager;
use \manager\Database;
use \manager\ManagerError;
use \manager\Repo;
use \manager\lightdb;
class subject{
/* RETOURNE LA LISTE DE TOUS LES SUJETS
*
* @return subjects<Array> Tableau contenant les informations de tous les utilisateurs
*
*/
public static function getAll(){
// Contiendra les sujets
$subjects = array();
/* [1] On récupére la liste des sujets
=========================================================*/
/* (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'];
$sub['creation'] = date('d/m/Y H:i:s', $sub['creation']);
$subjects[$id] = $sub;
}
$db->close();
/* [2] 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() );
$db->close();
/* (2) Si un des sujets de 'survey' est dans PHONE, on ajoute la mention */
foreach($subjects as $id=>$data)
if( in_array($id, $ids) ) // Si dans phone
$subjects[$id]['phone'] = true;
/* [3] 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() );
$db->close();
/* (2) Si un des sujets de 'survey' est dans FACBEOOK, on ajoute la mention */
foreach($subjects as $id=>$data)
if( in_array($id, $ids) ) // Si dans facebook
$subjects[$id]['facebook'] = true;
/* [4] Gestion du retour
=========================================================*/
return array(
'ModuleError' => ManagerError::Success,
'subjects' => $subjects
);
}
/* RETOURNE LA LISTE DE TOUS LES AMIS D'UN SUJET
*
* @subject_id<int> Identifiant du sujet d'enquête
*
* @return subjects<Array> Tableau contenant les informations de tous les utilisateurs
*
*/
public static function getFriends($params){
extract($params);
// Contiendra les sujets
$subjects = array();
/* [1] On récupére la liste des sujets
=========================================================*/
/* (1) On initialise et ouvre la bd */
$db = new lightdb('survey_db', __ROOT__.'/src/dynamic/');
$fetch = $db->fetch($subject_id);
$db->close();
/* (2) Si on trouve personne, on renvoie une erreur */
if( $fetch === false )
return array( 'ModuleError' => ManagerError::ModuleError );
/* (3) On enregistre ses contacts s'il en a */
if( isset($fetch['contacts']) )
$subjects = array_merge($subjects, $fetch['contacts']);
/* [2] On récupére la liste des contacts saisis dans PHONE
=========================================================*/
/* (1) On initialise et ouvre la bd */
$db = new lightdb('phone_db', __ROOT__.'/src/dynamic/');
$fetch = $db->fetch($subject_id);
$db->close();
/* (2) Si on trouve des contacts, on les ajoute */
if( $fetch !== false && isset($fetch['contacts']) )
$subjects = array_merge($subjects, $fetch['contacts']);
/* [3] 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/');
$fetch = $db->fetch($subject_id);
$db->close();
/* (2) Si on trouve des contacts, on les ajoute */
if( $fetch !== false && isset($fetch['contacts']) )
$subjects = array_merge($subjects, $fetch['contacts']);
/* [4] Gestion du retour
=========================================================*/
return array(
'ModuleError' => ManagerError::Success,
'subjects' => $subjects
);
}
/* CREATION D'UN SUJET
*
* @name<String> Pseudo du sujet
*
* @return id_subject<int> Renvoie l'id du sujet cree
*
*/
public static function create($params){
extract($params);
/* [1] On récupère l'id unique actuel
=========================================================*/
$funiq = fopen( __ROOT__.'/src/dynamic/uniqid', 'r+' );
flock($funiq, LOCK_EX); // On verrouille le fichier
$uniqid = fgets( $funiq );
if( !is_numeric($uniqid) )
$uniqid = 0;
// Décalage à appliquer à tous les ids
$newId = intval($uniqid) + 1;
// On crée notre sujet
$data = array( 'subject' => array(
'id' => $newId,
'name' => $name,
'creation' => time()
));
/* [2] On crée le sujet dans SURVEYS
=========================================================*/
/* (1) On initialise et ouvre la bd */
$db = new lightdb('survey_db', __ROOT__.'/src/dynamic/');
$db->insert( $newId, $data );
$db->close();
/* [3] On met à jour le nouvel ID unique
=========================================================*/
rewind($funiq); // On revient au début du fichier
fwrite($funiq, $newId); // On écrit la nouvelle valeur (forcément plus grande)
flock($funiq, LOCK_UN); // On débloque le verrou
fclose($funiq);
/* [2] Gestion du retour
=========================================================*/
return array(
'ModuleError' => ManagerError::Success,
'id_subject' => $newId
);
}
/* 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();
// Si erreur lors de la requête
if( $remove_status === false )
return array( 'ModuleError' => ManagerError::ModuleError );
/* [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 );
}
/* 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
=========================================================*/
/* (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'];
if( compareSearch($name, $sub['name']) ){
$sub['creation'] = date('d/m/Y H:i:s', $sub['creation']);
$subjects[$id] = $sub;
}
}
$db->close();
/* [2] 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() );
$db->close();
/* (2) Si un des sujets de 'survey' est dans PHONE, on ajoute la mention */
foreach($subjects as $id=>$data)
if( in_array($id, $ids) ) // Si dans phone
$subjects[$id]['phone'] = true;
/* [3] 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() );
$db->close();
/* (2) Si un des sujets de 'survey' est dans FACBEOOK, on ajoute la mention */
foreach($subjects as $id=>$data)
if( in_array($id, $ids) ) // Si dans facebook
$subjects[$id]['facebook'] = true;
/* [4] Retour des données
=========================================================*/
return array(
'ModuleError' => ManagerError::Success,
'results' => $subjects
);
}
}
?>