mirror of
				https://gitlab.com/animath/si/plateforme.git
				synced 2025-11-04 01:32:05 +01:00 
			
		
		
		
	Ajout d'une classe pour les fichiers à télécharger, meilleur support des organisateurs d'un tournoi
This commit is contained in:
		@@ -3,19 +3,12 @@
 | 
			
		||||
$tournament_name = htmlspecialchars($_GET["name"]);
 | 
			
		||||
 | 
			
		||||
$tournament = Tournament::fromName($tournament_name);
 | 
			
		||||
$orgas = $tournament->getOrganizers();
 | 
			
		||||
 | 
			
		||||
if ($tournament === null)
 | 
			
		||||
	require_once "server_files/404.php";
 | 
			
		||||
 | 
			
		||||
$orgas_req = $DB->query("SELECT `users`.`id` AS `id` FROM `users` JOIN `organizers` ON `users`.`id` = `organizer` WHERE `tournament` = " . $tournament->getId() . ";");
 | 
			
		||||
$orgas = [];
 | 
			
		||||
$orgas_id = [];
 | 
			
		||||
while (($orga_data = $orgas_req->fetch()) !== false) {
 | 
			
		||||
    $orgas[] = User::fromId($orga_data["id"]);
 | 
			
		||||
    $orgas_id[] = $orga_data["id"];
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (isset($_GET["modifier"]) && $_SESSION["role"] != Role::ADMIN && !in_array($_SESSION["user_id"], $orgas_id))
 | 
			
		||||
if (isset($_GET["modifier"]) && $_SESSION["role"] != Role::ADMIN && !$tournament->organize($_SESSION["user_id"]))
 | 
			
		||||
    require_once "server_files/403.php";
 | 
			
		||||
 | 
			
		||||
if (isset($_POST["edit_tournament"])) {
 | 
			
		||||
 
 | 
			
		||||
@@ -9,58 +9,58 @@ if (!isset($_SESSION["user_id"]))
 | 
			
		||||
	require_once "server_files/403.php";
 | 
			
		||||
 | 
			
		||||
$id = htmlspecialchars($_GET["file_id"]);
 | 
			
		||||
$type = "SOLUTION";
 | 
			
		||||
 | 
			
		||||
$req = $DB->query("SELECT * FROM `solutions` WHERE `file_id` = '$id';");
 | 
			
		||||
if (($data = $req->fetch()) === false) {
 | 
			
		||||
	$req = $DB->query("SELECT * FROM `syntheses` WHERE `file_id` = '$id';");
 | 
			
		||||
	$type = "SYNTHESE";
 | 
			
		||||
$type = DocumentType::SOLUTION;
 | 
			
		||||
$file = Solution::fromId($id);
 | 
			
		||||
if ($file === null) {
 | 
			
		||||
	$type = DocumentType::SYNTHESE;
 | 
			
		||||
	$file = Synthese::fromId($id);
 | 
			
		||||
 | 
			
		||||
	if (($data = $req->fetch()) === false) {
 | 
			
		||||
		$req = $DB->query("SELECT * FROM `documents` WHERE `file_id` = '$id';");
 | 
			
		||||
		$type = "DOCUMENT";
 | 
			
		||||
		$data = $req->fetch();
 | 
			
		||||
	if ($file === null) {
 | 
			
		||||
		$file = Document::fromId($id);
 | 
			
		||||
		$type = DocumentType::PARENTAL_CONSENT;
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if ($data !== false) {
 | 
			
		||||
	$team = Team::fromId($data["team"]);
 | 
			
		||||
	$tournament = Tournament::fromId($data["tournament"]);
 | 
			
		||||
if ($file !== null) {
 | 
			
		||||
	$team = Team::fromId($file->getTeamId());
 | 
			
		||||
	$tournament = Tournament::fromId($file->getTournamentId());
 | 
			
		||||
	$trigram = $team->getTrigram();
 | 
			
		||||
	if ($type == "SOLUTION") {
 | 
			
		||||
		$problem = $data["problem"];
 | 
			
		||||
 | 
			
		||||
	if ($_SESSION["role"] == Role::ORGANIZER && !$tournament->organize($_SESSION["user_id"]))
 | 
			
		||||
		require_once "server_files/403.php";
 | 
			
		||||
 | 
			
		||||
	if ($type == DocumentType::SOLUTION) {
 | 
			
		||||
		$problem = $file->getProblem();
 | 
			
		||||
		$name = "Problème $problem $trigram.pdf";
 | 
			
		||||
 | 
			
		||||
		if (($_SESSION["role"] == Role::PARTICIPANT || $_SESSION["role"] == Role::ENCADRANT) && (!isset($_SESSION["team"]) || $_SESSION["team"]->getId() != $team->getId()))
 | 
			
		||||
			require_once "server_files/403.php";
 | 
			
		||||
 | 
			
		||||
		// TODO Seuls les organisateurs concernés doivent pouvoir télécharger les fichiers
 | 
			
		||||
	}
 | 
			
		||||
	else if ($type == "SYNTHESE") {
 | 
			
		||||
		$dest = $data["dest"];
 | 
			
		||||
		$name = "Note de synthèse $trigram pour " . ($dest == "OPPOSANT" ? "l'opposant" : "le rapporteur") . ".pdf";
 | 
			
		||||
		$dest = $file->getDest();
 | 
			
		||||
		$name = "Note de synthèse $trigram pour " . ($dest == DestType::OPPOSANT ? "l'opposant" : "le rapporteur") . ".pdf";
 | 
			
		||||
 | 
			
		||||
		// TODO Seuls les organisateurs, défenseurs, opposants et rapporteurs doivent pouvoir télécharger les fichiers
 | 
			
		||||
	}
 | 
			
		||||
	else if ($type == "DOCUMENT") {
 | 
			
		||||
		$user_id = $data["user"];
 | 
			
		||||
		$user = User::fromId($user_id);
 | 
			
		||||
 | 
			
		||||
		if (($_SESSION["role"] == Role::PARTICIPANT || $_SESSION["role"] == Role::ENCADRANT) && $user_id != $_SESSION["user_id"])
 | 
			
		||||
		if (($_SESSION["role"] == Role::PARTICIPANT || $_SESSION["role"] == Role::ENCADRANT) && (!isset($_SESSION["team"]) || $_SESSION["team"]->getId() != $team->getId()))
 | 
			
		||||
			require_once "server_files/403.php";
 | 
			
		||||
	}
 | 
			
		||||
	else {
 | 
			
		||||
		$user = User::fromId($file->getUserId());
 | 
			
		||||
		$type = $file->getType();
 | 
			
		||||
 | 
			
		||||
		// TODO Seuls les organisateurs concernés doivent pouvoir télécharger les fichiers
 | 
			
		||||
		if (($_SESSION["role"] == Role::PARTICIPANT || $_SESSION["role"] == Role::ENCADRANT) && $user->getId() != $_SESSION["user_id"])
 | 
			
		||||
			require_once "server_files/403.php";
 | 
			
		||||
 | 
			
		||||
		$surname = $user->getSurname();
 | 
			
		||||
		$first_name = $user->getFirstName();
 | 
			
		||||
		switch ($data["type"]) {
 | 
			
		||||
			case "PARENTAL_CONSENT":
 | 
			
		||||
		switch ($type) {
 | 
			
		||||
			case DocumentType::PARENTAL_CONSENT:
 | 
			
		||||
				$name = "Autorisation parentale";
 | 
			
		||||
				break;
 | 
			
		||||
			case "PHOTO_CONSENT":
 | 
			
		||||
			case DocumentType::PHOTO_CONSENT:
 | 
			
		||||
				$name = "Autorisation de droit à l'image";
 | 
			
		||||
				break;
 | 
			
		||||
			case "SANITARY_PLUG":
 | 
			
		||||
			case DocumentType::SANITARY_PLUG:
 | 
			
		||||
				$name = "Fiche sanitaire";
 | 
			
		||||
				break;
 | 
			
		||||
		}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user