You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
132 lines
4.6 KiB
132 lines
4.6 KiB
<?php
|
|
|
|
namespace API\script\Gateway;
|
|
|
|
use Config\Connection;
|
|
use PDO;
|
|
|
|
/**
|
|
* Permet d'accéder, d'écrire ou de modifier les données contenues dans la table Response
|
|
* afin de récupérer les réponses d'un utilisateur.
|
|
*/
|
|
class GatewayResponse
|
|
{
|
|
/**
|
|
* @var Connection
|
|
*/
|
|
private Connection $connection;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->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";
|
|
$this->connection->executeQuery($query, array(
|
|
':id' => array($listResponsesOfCandidateId, PDO::PARAM_INT)
|
|
));
|
|
return $this->connection->getResults();
|
|
}
|
|
|
|
/**
|
|
* 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.responsesCandidate = :id AND r.id = s.response";
|
|
$this->connection->executeQuery($query, array(
|
|
':id' => array($listResponsesOfCandidateId, 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;
|
|
}
|
|
}
|