1
0
mirror of https://gitlab.com/animath/si/plateforme.git synced 2025-01-13 19:02:22 +00:00
plateforme-tfjm2/server_files/controllers/view_file.php

95 lines
2.8 KiB
PHP
Raw Normal View History

2019-08-21 20:56:46 +00:00
<?php
if (!isset($_GET["file_id"])) {
header("Location: $URL_BASE");
exit();
}
if (!isset($_SESSION["user_id"]))
require_once "server_files/403.php";
2019-08-21 20:56:46 +00:00
$id = htmlspecialchars($_GET["file_id"]);
$type = DocumentType::SOLUTION;
$file = Solution::fromId($id);
if ($file === null) {
2019-09-07 23:35:05 +00:00
$type = DocumentType::SYNTHESIS;
$file = Synthesis::fromId($id);
2019-08-21 20:56:46 +00:00
if ($file === null) {
$file = Document::fromId($id);
$type = DocumentType::PARENTAL_CONSENT;
2019-08-21 20:56:46 +00:00
}
}
if ($file !== null) {
$team = Team::fromId($file->getTeamId());
$tournament = Tournament::fromId($file->getTournamentId());
$trigram = $team->getTrigram();
if ($_SESSION["role"] == Role::ORGANIZER && !$tournament->organize($_SESSION["user_id"]))
require_once "server_files/403.php";
if ($type == DocumentType::SOLUTION) {
$problem = $file->getProblem();
2020-02-03 15:44:38 +00:00
$name = "Problème $problem $trigram";
if (($_SESSION["role"] == Role::PARTICIPANT || $_SESSION["role"] == Role::ENCADRANT) && (!isset($_SESSION["team"]) || $_SESSION["team"]->getId() != $team->getId()))
require_once "server_files/403.php";
2019-08-21 20:56:46 +00:00
}
2019-09-07 23:35:05 +00:00
else if ($type == DocumentType::SYNTHESIS) {
$dest = $file->getDest();
2020-02-03 15:44:38 +00:00
$name = "Note de synthèse $trigram pour " . ($dest == DestType::OPPOSANT ? "l'opposant" : "le rapporteur");
if (($_SESSION["role"] == Role::PARTICIPANT || $_SESSION["role"] == Role::ENCADRANT) && (!isset($_SESSION["team"]) || $_SESSION["team"]->getId() != $team->getId()))
require_once "server_files/403.php";
2019-08-21 20:56:46 +00:00
}
else {
$user = User::fromId($file->getUserId());
$type = $file->getType();
2020-01-18 13:43:42 +00:00
if (($_SESSION["role"] == Role::PARTICIPANT || $_SESSION["role"] == Role::ENCADRANT)) {
if ($type != DocumentType::MOTIVATION_LETTER && $user->getId() != $_SESSION["user_id"] || $file->getTeamId() != $team->getId())
require_once "server_files/403.php";
}
switch ($type) {
case DocumentType::PARENTAL_CONSENT:
2019-08-21 20:56:46 +00:00
$name = "Autorisation parentale";
break;
case DocumentType::PHOTO_CONSENT:
2019-08-21 20:56:46 +00:00
$name = "Autorisation de droit à l'image";
break;
case DocumentType::SANITARY_PLUG:
2019-08-21 20:56:46 +00:00
$name = "Fiche sanitaire";
break;
2020-01-01 23:09:02 +00:00
case DocumentType::SCHOLARSHIP:
$name = "Notification de bourse";
break;
2019-08-21 20:56:46 +00:00
}
2020-01-18 13:43:42 +00:00
if ($type == DocumentType::MOTIVATION_LETTER)
2020-02-03 15:44:38 +00:00
$name = "Lettre de motivation de l'équipe $trigram";
2020-01-18 13:43:42 +00:00
else {
$surname = $user->getSurname();
$first_name = $user->getFirstName();
2020-02-03 15:44:38 +00:00
$name .= " de $first_name $surname";
2020-01-18 13:43:42 +00:00
}
2019-08-21 20:56:46 +00:00
}
}
else
require_once "server_files/404.php";
2019-08-21 20:56:46 +00:00
2020-02-03 15:44:38 +00:00
$mime = finfo_file(finfo_open(FILEINFO_MIME_TYPE), "$LOCAL_PATH/files/$id");
if ($mime == "application/pdf")
$name .= ".pdf";
elseif ($mime == "image/png")
$name .= ".png";
else
$name = ".jpg";
header("Content-Type: $mime");
2019-08-21 20:56:46 +00:00
header("Content-Disposition: inline; filename=\"$name\"");
readfile("$LOCAL_PATH/files/$id");
2019-08-21 20:56:46 +00:00
exit();