301 lines
7.7 KiB
PHP
301 lines
7.7 KiB
PHP
<?php
|
|
|
|
namespace api\module;
|
|
use \manager\sessionManager;
|
|
use \database\core\DatabaseDriver;
|
|
use \manager\ManagerError;
|
|
use \database\core\Repo;
|
|
use \lightdb\core\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 = [];
|
|
|
|
/* [1] On récupére la liste des sujets
|
|
=========================================================*/
|
|
/* (1) On initialise et ouvre la bd */
|
|
$db = new lightdb('survey_db');
|
|
$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');
|
|
$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');
|
|
$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 [
|
|
'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 = [];
|
|
|
|
/* [1] On récupére la liste des sujets
|
|
=========================================================*/
|
|
/* (1) On initialise et ouvre la bd */
|
|
$db = new lightdb('survey_db');
|
|
$fetch = $db->fetch($subject_id);
|
|
$db->close();
|
|
|
|
/* (2) Si on trouve personne, on renvoie une erreur */
|
|
if( $fetch === false )
|
|
return [ 'ModuleError' => ManagerError::ModuleError ];
|
|
|
|
/* (3) On enregistre ses contacts s'il en a */
|
|
if( isset($fetch['contacts']) )
|
|
foreach($fetch['contacts'] as $contact)
|
|
$subjects[$contact['id']] = $contact;
|
|
|
|
|
|
/* [2] On récupére la liste des contacts saisis dans PHONE
|
|
=========================================================*/
|
|
/* (1) On initialise et ouvre la bd */
|
|
$db = new lightdb('phone_db');
|
|
$fetch = $db->fetch($subject_id);
|
|
$db->close();
|
|
|
|
/* (2) Si on trouve des contacts, on les ajoute */
|
|
if( $fetch !== false && isset($fetch['contacts']) )
|
|
foreach($fetch['contacts'] as $contact)
|
|
$subjects[$contact['id']] = $contact;
|
|
|
|
|
|
|
|
|
|
/* [3] On récupére la liste des sujets pour FACEBOOK
|
|
=========================================================*/
|
|
/* (1) On initialise et ouvre la bd */
|
|
$db = new lightdb('facebook_db');
|
|
$fetch = $db->fetch($subject_id);
|
|
$db->close();
|
|
|
|
/* (2) Si on trouve des contacts, on les ajoute */
|
|
if( $fetch !== false && isset($fetch['contacts']) )
|
|
foreach($fetch['contacts'] as $contact)
|
|
$subjects[$contact['id']] = $contact;
|
|
|
|
|
|
/* [4] Gestion du retour
|
|
=========================================================*/
|
|
return [
|
|
'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( __BUILD__.'/src/dynamic/uniqid', 'r+' );
|
|
flock($funiq, LOCK_EX); // On verrouille le fichier
|
|
$uniqid = trim( fgets( $funiq ) );
|
|
|
|
|
|
if( !is_numeric($uniqid) )
|
|
$uniqid = 0;
|
|
|
|
// Décalage à appliquer à tous les ids
|
|
$newId = intval($uniqid) + 1;
|
|
|
|
// On crée notre sujet
|
|
$data = [ 'subject' => [
|
|
'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');
|
|
$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 [
|
|
'ModuleError' => ManagerError::Success,
|
|
'id_subject' => $newId
|
|
];
|
|
}
|
|
|
|
|
|
|
|
|
|
/* 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 = [];
|
|
|
|
|
|
/* [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');
|
|
$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');
|
|
$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');
|
|
$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 [
|
|
'ModuleError' => ManagerError::Success,
|
|
'results' => $subjects
|
|
];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
?>
|