connection = connect(); } /** * Permet de récupérer la liste des réponses d'un candidat ainsi que les Keyword couvert pour chaque réponse. * * @param int $listResponsesOfCandidateId Id du candidat * * @return array Retourne une liste contenant à l'indice 0 la liste de réponse * et à l'indice 1 une liste de liste de Keword, * où chaque indice d'une liste de question est associé au même indice une réponse */ public function getCatgoriezeOfResponsesIdByIdListCandidate(int $listResponsesOfCandidateId): array { $result = $this->getResponsesByIdListCandidate($listResponsesOfCandidateId); $tab = []; foreach ($result as $row) { $tab[] = (new GatewayKeyword())->getKeywordsContentByCategorieze($row['id']); } return array($result, $tab); } /** * Permet de récupérer la liste des réponses d'un candidat par son id. * * @param int $listResponsesOfCandidateId Id du candidat * * @return array Retourne la list des réponses du candidat */ public function getResponsesByIdListCandidate(int $listResponsesOfCandidateId): array { $query = "SELECT r.* FROM Response r, Submit s WHERE s.responsesCandidate = :id AND r.id = s.response"; return $this->getResponsesByQueryAndIdListCandidate($query, $listResponsesOfCandidateId); } /** * Permet de récupérer la liste des id des réponses d'un candidat par son id. * * @param int $listResponsesOfCandidateId Id du candidat * * @return array Retourne la list des id des réponses du candidat */ public function getResponsesIdByIdListCandidate(int $listResponsesOfCandidateId): array { $query = "SELECT r.id FROM Response r, Submit s WHERE s.responseCandidate = :id AND r.id = s.response"; return $this->getResponsesByQueryAndIdListCandidate($query, $listResponsesOfCandidateId); } /** * Permet de récupérer une liste de format de réponse définit par la commande sql passé en paramètre, * dont l'id du candidat, ayant formulé ces réponses, est passé en paramètre. * * @param string $query Requête du format de liste de réponse voulu * @param int $id Id du candidat cible * * @return array Retourne la liste des réponses d'un candidat selon le format voulu */ private function getResponsesByQueryAndIdListCandidate(string $query, int $id): array { $this->connection->executeQuery($query, array( ':id' => array($id, PDO::PARAM_INT) )); return $this->connection->getResults(); } /** * Permet de supprimer la réponse et ses liens avec les différents Keyword * selon l'id de la réponse passée en paramêtre * * @param int $responseId Id de la réponse à supprimer * * @return void */ public function deleteResponseById(int $responseId): void { $query = "DELETE FROM Categorize WHERE response = :id"; $this->connection->executeQuery($query, array( ':id' => array($responseId, PDO::PARAM_INT) )); $query = "DELETE FROM Submit WHERE response = :id"; $this->connection->executeQuery($query, array( ':id' => array($responseId, PDO::PARAM_INT) )); $query = "DELETE FROM Response WHERE id = :id"; $this->connection->executeQuery($query, array( ':id' => array($responseId, PDO::PARAM_INT) )); } /** * Permet d'insérer une réponse ainsi que de la lier avec les Keywords passés en paramètre. * * @param string $content Contenu de la réponse * @param string $questionContent Contenu de la question, dans le cas où la question viendra à changer dans le futur * @param array $category Liste des Keyword associé à la réponse * * @return int Retourne l'Id de la réponse insérée */ public function insertResponse(string $content, string $questionContent, array $category): int { $query = "INSERT INTO Response(content, questionContent) VALUES (:content, :questionContent)"; $this->connection->executeQuery($query, array( ':content' => array($content, PDO::PARAM_STR), ':questionContent' => array($questionContent, PDO::PARAM_STR) )); $idResponse = $this->connection->lastInsertId(); foreach ($category as $keyword) { $query = "INSERT INTO Categorize (response, keyword) VALUES(:response, :keyword)"; $this->connection->executeQuery($query, array( ':response' => array($idResponse, PDO::PARAM_STR), ':keyword' => array($keyword, PDO::PARAM_STR) )); } return $idResponse; } }