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.
128 lines
4.5 KiB
128 lines
4.5 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 PossibleResponse
|
|
* afin de gérer la liste des réponses et les catégories associer d'un candidat.
|
|
*/
|
|
class GatewayListResponseOfCandidate
|
|
{
|
|
/**
|
|
* @var Connection
|
|
*/
|
|
private Connection $connection;
|
|
|
|
/**
|
|
*
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->connection = connect();
|
|
}
|
|
|
|
/**
|
|
* Permet de récupérer la liste détaillée des réponses avec leurs catégories associer
|
|
* aux différentes questions qu'un candidat cible a répondu
|
|
*
|
|
* @param int $idListResponse Id du candidat pour lequel on veut récupérer ses réponses
|
|
*
|
|
* @return array Retourne une liste qui pour
|
|
* l'indice 0 a la liste des infos du candidat
|
|
* l'indice 1 la liste des réponses
|
|
* l'indice 2 une liste de liste de catégories, qui pour chaque même indice correspont à la liste des catégories de la réponse
|
|
*/
|
|
public function getDetailsListResponsesOfCandidate(int $idListResponse)
|
|
{
|
|
$gatewayResponse = new GatewayResponse();
|
|
$gatewayKeyword = new GatewayKeyword();
|
|
$tabKeywords = [];
|
|
|
|
$query = "SELECT * FROM ListResponsesOfCandidate WHERE id = :id";
|
|
$this->connection->executeQuery($query, array(
|
|
':id' => array($idListResponse, PDO::PARAM_INT)
|
|
));
|
|
|
|
$questionList = $this->connection->getResults()[0];
|
|
|
|
$responses = $gatewayResponse->getResponsesByIdListCandidate($questionList['id']);
|
|
|
|
foreach ($responses as $row) {
|
|
$tabKeywords[] = $gatewayKeyword->getKeywordsContentByCategorieze($row['id']);
|
|
}
|
|
|
|
return array($questionList, $responses, $tabKeywords);
|
|
}
|
|
|
|
/**
|
|
* Permet de récupérer la liste des personnes ayant répondu aux formulaire
|
|
*
|
|
* @return array Retourne la liste brute des informations de tous les candidats ayant répondu au formulaire
|
|
*/
|
|
public function getAllListResponsesOfCandidate(): array
|
|
{
|
|
$query = "SELECT * FROM ListResponsesOfCandidate";
|
|
$this->connection->executeQuery($query);
|
|
|
|
return $this->connection->getResults();
|
|
}
|
|
|
|
/**
|
|
* Permet de supprimer la liste des réponses d'un candidat de la base de donnée
|
|
*
|
|
* @param int $id Id du candidat à supprimer
|
|
*
|
|
* @return void
|
|
*/
|
|
public function deleteListResponseOfCandidate(int $id): void
|
|
{
|
|
$gatewayResponse = new GatewayResponse();
|
|
foreach ($gatewayResponse->getResponsesIdByIdListCandidate($id) as $response) {
|
|
$gatewayResponse->deleteResponseById($response['id']);
|
|
}
|
|
$query = "DELETE FROM ListResponsesOfCandidate WHERE id = :id";
|
|
$this->connection->executeQuery($query, array(
|
|
'id' => array($id, PDO::PARAM_INT)
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Permet d'insérer dans la base de données les réponses aux questions d'un candidat
|
|
* ainsi que les catégories associées à chaque réponse
|
|
*
|
|
* @param array $id Liste des id des questions répondue
|
|
* @param array $answer Liste des réponses à chaque question
|
|
* @param array $category Liste des catégories attribuées à chaque réponse
|
|
* @param string $titleForm Titre du formulaire
|
|
*
|
|
* @return void
|
|
*/
|
|
public function insertListResponsesOfCandidate(array $id, array $answer, array $category, string $titleForm): void
|
|
{
|
|
$gatewayResponse = new GatewayResponse();
|
|
$gatewayQuestion = new GatewayQuestion();
|
|
|
|
$query = "INSERT INTO ListResponsesOfCandidate(date, titleForm) VALUES(:date, :titleForm)";
|
|
$this->connection->executeQuery($query, array(
|
|
':date' => array(date('Y-m-d H:i:s'), PDO::PARAM_STR),
|
|
':titleForm' => array($titleForm, PDO::PARAM_STR)
|
|
));
|
|
|
|
$idListQuestion = $this->connection->lastInsertId();
|
|
|
|
for ($i = 0; $i < count($answer); $i++) {
|
|
$question = $gatewayQuestion->getQuestionContentById($id[$i]);
|
|
$idResponse = $gatewayResponse->insertResponse($question, $answer[$i], $category[$i]);
|
|
|
|
$query = "INSERT INTO Submit (responsesCandidate, response) VALUES(:responsesCandidate, :response)";
|
|
$this->connection->executeQuery($query, array(
|
|
':responsesCandidate' => array($idListQuestion, PDO::PARAM_STR),
|
|
':response' => array($idResponse, PDO::PARAM_STR)
|
|
));
|
|
}
|
|
}
|
|
}
|