Identifiant de la machine * * @return status Retourne si oui ou non, tout s'est bien passe * */ public static function create($params){ extract($params); /* [1] Creation de la machine =========================================================*/ $create_machine = new Repo('machine/create', [ $_SESSION['WAREHOUSE']['id'], $name ]); $id_machine = $create_machine->answer(); // Si une erreur est retournee, on retourne une erreur if( $id_machine === false ) return ['ModuleError' => ManagerError::ModuleError]; /* [2] Creation du groupe de meme nom que la machine =========================================================*/ $create_group = new Repo('cluster/create', [ $_SESSION['WAREHOUSE']['id'], $name, clusterRepo::MACHINE_CLASS ]); $id_group = $create_group->answer(); // Si une erreur est retournee, on retourne une erreur if( $id_group === false ) return ['ModuleError' => ManagerError::ModuleError]; /* [3] Association au groupe =========================================================*/ $assoc_goup = new Repo('cluster/link', [ $_SESSION['WAREHOUSE']['id'], $id_group, $id_machine, clusterRepo::MACHINE_CLASS ]); $id_assoc = $assoc_goup->answer(); // Si une erreur est retournee, on retourne une erreur if( $id_assoc === false ) return ['ModuleError' => ManagerError::ModuleError]; /* [4] Gestion du retour =========================================================*/ return [ 'ModuleError' => ManagerError::Success, 'id_machine' => $id_machine, 'id_cluster' => $id_group ]; } /* AJOUTE UNE MACHINE DONNEE A UN GROUPE DONNE * * @id_cluster UID du groupe * @id_machine UID de la machine * * @return association Renvoie l'UID de l'association cree * Renvoie FALSE si une erreur occure * */ public static function link($params){ extract($params); /* Creation de l'association */ $link_machine = new Repo('cluster/link', [ $_SESSION['WAREHOUSE']['id'], $id_cluster, $id_machine, clusterRepo::MACHINE_CLASS ]); /* (1) On retourne l'erreur du repo */ return [ 'ModuleError' => $link_machine->answer() ]; } /* RETIRE UNE MACHINE DONNEE A UN GROUPE DONNE * * @id_cluster UID du groupe * @id_machine UID de la machine * * @return association Renvoie l'UID de l'association cree * Renvoie FALSE si une erreur occure * */ public static function unlink($params){ extract($params); /* Suppression de l'association */ $link_machine = new Repo('cluster/unlink', [ $_SESSION['WAREHOUSE']['id'], $id_cluster, $id_machine, clusterRepo::MACHINE_CLASS ]); /* (1) On retourne l'erreur du repo */ return [ 'ModuleError' => $link_machine->answer() ]; } /* RENVOIE UNE MACHINE EN FONCTION D'UN MOT CLE * * @keywords Element de recherche * * @return machines Retourne la liste des machines trouvees * */ public static function search($params){ extract($params); // On recupere les donnees $machine = new Repo('machine/search', [ $_SESSION['WAREHOUSE']['id'], $keywords ]); return [ 'machines' => $machine->answer() ]; } /* RENVOIE LA LISTE EXHAUSTIVE DES MACHINES * * @return machines Liste des machines * */ public static function getAll(){ // On recupere les donnees $machines = new Repo('machine/getAll', [$_SESSION['WAREHOUSE']['id']]); return [ 'machines' => $machines->answer() ]; } /* RENVOIE LA MACHINE D'UID DONNE * * @id_machine UID de la machine en question * * @return machine Machine d'UID donne * */ public static function getById($params){ extract($params); // On recupere les donnees $request = new Repo('machine/getById', [ $_SESSION['WAREHOUSE']['id'], $id_machine ]); $answer = $request->answer(); // Si aucun resultat, on retourne une erreur if( $answer === false ) return [ 'ModuleError' => ManagerError::NoMatchFound ]; return [ 'machine' => $answer ]; } /* RENVOIE LA MACHINE DE NAME DONNE * * @name Name de l'utilisateur en question * * @return machine Machine de name donne * */ public static function getByName($params){ extract($params); // On recupere les donnees $request = new Repo('machine/getByName', [ $_SESSION['WAREHOUSE']['id'], $name ]); $answer = $request->answer(); // Si aucun resultat, on retourne une erreur if( $answer === false ) return [ 'ModuleError' => ManagerError::NoMatchFound ]; return [ 'machine' => $answer ]; } /* RENVOIE LES GROUPES D'UNE MACHINE DONNEE * * @id_machine UID de la machine en question * * @return clusters Groupes de la machine donne * */ public static function getClusters($params){ extract($params); // On recupere les donnees $request = new Repo('machine/getClusters', [ $_SESSION['WAREHOUSE']['id'], $id_machine ]); $answer = $request->answer(); // Si aucun resultat, on retourne une erreur if( $answer === false ) return [ 'ModuleError' => ManagerError::NoMatchFound ]; return [ 'clusters' => $answer ]; } /* MODIFIE UNE MACHINE DONNEE * * @id_machine UID de la machine * @name Identifiant l'utilisateur * * @return status Retourne si oui ou non tout s'est bien deroule * */ public static function edit($params){ extract($params); /* [1] On verifie l'existence de la machine =========================================================*/ $machine_exists = new Repo('machine/getById', [ $_SESSION['WAREHOUSE']['id'], $id_machine ]); $machine_data = $machine_exists->answer(); // Si on a recupere aucune machine, on retourne une erreur if( !is_array($machine_data) ) return ['ModuleError' => ManagerError::NoMatchFound]; /* [2] Normalisation + verification des donnees =========================================================*/ /* (1) Verification des parametres (si correct et different)*/ $correct_param = [ 'name' => !is_null($name) && $machine_data['name'] != $name ]; /* (2) Gestion des parametres optionnels */ $opt_data = [ 'name' => ($correct_param['name']) ? $name : $machine_data['name'] ]; /* [3] Modification de la machine =========================================================*/ $request = new Repo('machine/edit', [ $_SESSION['WAREHOUSE']['id'], $id_machine, $opt_data['name'] ]); return [ 'status' => $request->answer() ]; } /* SUPPRIME UNE MACHINE DONNEE * * @id_machine UID de la machine en question * * @return status Retourne si oui ou non tout s'est bien deroule * */ public static function delete($params){ extract($params); // On recupere les donnees $request = new Repo('machine/delete', [ $_SESSION['WAREHOUSE']['id'], $id_machine ]); $answer = $request->answer(); return [ 'status' => $answer ]; } /* SYNCHRONISE UNE MACHINE * * @token Token de synchronisation de la machine * @data Données de la synchronisation * * @return data Données de retour de synchronisation * */ public static function sync($params){ extract($params); $checkToken = new Repo('machine/checkToken', [ $_SESSION['WAREHOUSE']['id'], $token ]); return [ 'tokenResult' => $checkToken->answer() ]; } } ?>