bdd = new Connector(); $this->selectCat($nomCat); $this->questsets = array(); $this->load(); } private function selectCat($nomCat) { $options = array( "where" => array( array("nom_cat", "=", $nomCat) ) ); if(!is_null($this->bdd->Select('*', 'categorie', $options))) { $this->nomCat = $nomCat; } else { throw new Exception('cant_find_cat'); } } private function load() { $options = array( "where" => array( array("nom_cat", "=", $this->nomCat) ), "order by" => array("rand()"), "limit" => array("2") ); $resp = $this->bdd->Select('*', 'reponses', $options); foreach($resp as $questset) { array_push($this->questsets, new Questset(array($questset['reponse1'], $questset['reponse2']))); } } public static function randSelect() { $bdd = new Connector(); $arrayCat = $bdd->Select("*", "categorie"); $return = array(); $catIndex = -1; $previousIndex = -1; for($i = 0; $i < 2; $i++) { do { $filled = true; $previousIndex = $catIndex; $catIndex = rand(0, sizeof($arrayCat)-1); $category = new Categorie($arrayCat[$catIndex]['nom_cat']); if(sizeof($category->getArray()['themes']) >=2) { foreach($category->getArray()['themes'] as $theme) { if(sizeof($theme['questions']) < 3) { $filled = false; } } } else { $filled = false; } } while(($catIndex == $previousIndex) || !$filled); array_push($return, new Categorie($arrayCat[$catIndex]['nom_cat'])); } return $return; } public function getArray() { $questsets = array(); foreach($this->questsets as $questset) { array_push($questsets, $questset->getArray()); } return array( "nom_cat" => utf8_encode($this->nomCat), "themes" => $questsets ); } }