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', __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 [ 'ModuleError' => ManagerError::Success, 'subjects' => $subjects ]; } /* RETOURNE LA LISTE DE TOUS LES AMIS D'UN SUJET * * @subject_id Identifiant du sujet d'enquête * * @return subjects 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', __ROOT__.'/src/dynamic/'); $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', __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']) ) 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', __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']) ) foreach($fetch['contacts'] as $contact) $subjects[$contact['id']] = $contact; /* [4] Gestion du retour =========================================================*/ return [ 'ModuleError' => ManagerError::Success, 'subjects' => $subjects ]; } /* CREATION D'UN SUJET * * @name Pseudo du sujet * * @return id_subject 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 = 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', __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 [ 'ModuleError' => ManagerError::Success, 'id_subject' => $newId ]; } /* RECHERCHE DE SUJETS * * @name Nom du sujet recherché * * @return results 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', __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 [ 'ModuleError' => ManagerError::Success, 'results' => $subjects ]; } } ?>