2019-09-06 11:48:50 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
if (isset($_POST["leave_team"])) {
|
|
|
|
quitTeam();
|
2019-09-06 23:33:05 +00:00
|
|
|
exit();
|
2019-09-06 11:48:50 +00:00
|
|
|
}
|
|
|
|
|
2019-09-07 23:35:05 +00:00
|
|
|
$tournaments = Tournament::getAllTournaments(false, true);
|
2019-09-06 11:48:50 +00:00
|
|
|
|
2019-09-09 21:28:03 +00:00
|
|
|
$has_error = false;
|
|
|
|
$error_message = null;
|
|
|
|
|
|
|
|
if (isset($_POST["team_edit"])) {
|
|
|
|
$my_team = new MyTeam($_POST);
|
|
|
|
try {
|
|
|
|
$my_team->makeVerifications();
|
|
|
|
$my_team->updateTeam();
|
|
|
|
}
|
|
|
|
catch (AssertionError $e) {
|
|
|
|
$has_error = true;
|
|
|
|
$error_message = $e->getMessage();
|
|
|
|
}
|
2019-09-06 11:48:50 +00:00
|
|
|
}
|
|
|
|
|
2019-09-06 23:33:05 +00:00
|
|
|
if (isset($_SESSION["user_id"]) && isset($_SESSION["team"]) && $_SESSION["team"] !== null) {
|
2019-09-07 23:35:05 +00:00
|
|
|
/**
|
|
|
|
* @var User $user
|
|
|
|
* @var Team $team
|
|
|
|
*/
|
|
|
|
$user = $_SESSION["user"];
|
2019-09-06 23:33:05 +00:00
|
|
|
$team = $_SESSION["team"];
|
|
|
|
|
|
|
|
$tournament = Tournament::fromId($team->getTournamentId());
|
2020-01-16 21:04:29 +00:00
|
|
|
$documents = $tournament->getAllDocuments($team->getId());
|
2019-09-07 23:35:05 +00:00
|
|
|
if ($team->isSelectedForFinal())
|
2020-01-16 21:04:29 +00:00
|
|
|
$documents_final = $FINAL->getAllDocuments($team->getId());
|
2019-09-06 11:48:50 +00:00
|
|
|
}
|
|
|
|
else
|
2019-09-09 21:28:03 +00:00
|
|
|
require_once "server_files/403.php";
|
2019-09-06 11:48:50 +00:00
|
|
|
|
2020-01-16 21:04:29 +00:00
|
|
|
if (isset($_POST["request_validation"])) {
|
|
|
|
if (!canValidate($team, $tournament))
|
|
|
|
$error_message = "Votre équipe ne peut pas demander la validation : il manque soit des participants, soit des documents.";
|
2020-01-16 22:00:31 +00:00
|
|
|
else {
|
2020-01-16 21:04:29 +00:00
|
|
|
$team->setValidationStatus(ValidationStatus::WAITING);
|
2020-01-16 22:00:31 +00:00
|
|
|
Mailer::sendRequestValidationMail($team, $team->isSelectedForFinal() ? $FINAL : $tournament);
|
|
|
|
}
|
2020-01-16 21:04:29 +00:00
|
|
|
}
|
|
|
|
|
2019-09-09 21:28:03 +00:00
|
|
|
class MyTeam
|
2019-09-06 11:48:50 +00:00
|
|
|
{
|
2019-09-09 21:28:03 +00:00
|
|
|
public $name;
|
|
|
|
public $trigram;
|
|
|
|
public $tournament_id;
|
|
|
|
private $team;
|
|
|
|
private $tournament;
|
|
|
|
|
|
|
|
public function __construct($data)
|
|
|
|
{
|
|
|
|
foreach ($data as $key => $value)
|
|
|
|
$this->$key = htmlspecialchars($value);
|
|
|
|
|
|
|
|
$this->trigram = strtoupper($this->trigram);
|
|
|
|
$this->team = $_SESSION["team"];
|
|
|
|
$this->tournament = Tournament::fromId($this->tournament_id);
|
|
|
|
}
|
2019-09-06 11:48:50 +00:00
|
|
|
|
2019-09-09 21:28:03 +00:00
|
|
|
public function makeVerifications()
|
|
|
|
{
|
|
|
|
ensure($this->name != "" && $this->name != null, "Veuillez spécifier un nom d'équipe.");
|
|
|
|
ensure($this->name == $this->team->getName() || !teamExists($this->name), "Une équipe existe déjà avec ce nom.");
|
|
|
|
ensure(preg_match("#^[A-Z]{3}$#", $this->trigram), "Le trigramme n'est pas valide.");
|
|
|
|
ensure($this->trigram == $this->team->getTrigram() || !trigramExists($this->trigram), "Une équipe a déjà choisi ce trigramme.");
|
|
|
|
ensure($this->tournament != null, "Le tournoi indiqué n'existe pas.");
|
2020-01-01 21:41:08 +00:00
|
|
|
ensure(date("Y-m-d H:i:s") <= $this->tournament->getInscriptionDate(), "Les inscriptions sont terminées.");
|
2019-09-09 21:28:03 +00:00
|
|
|
ensure($this->team->getValidationStatus() == ValidationStatus::NOT_READY, "Votre équipe est déjà validée ou en cours de validation.");
|
2019-09-06 11:48:50 +00:00
|
|
|
}
|
2019-09-09 21:28:03 +00:00
|
|
|
|
|
|
|
public function updateTeam()
|
|
|
|
{
|
2020-04-13 01:41:15 +00:00
|
|
|
global $URL_BASE, $DB;
|
2019-09-09 21:28:03 +00:00
|
|
|
|
|
|
|
$this->team->setName($this->name);
|
|
|
|
$this->team->setTrigram($this->trigram);
|
|
|
|
$this->team->setTournamentId($this->tournament_id);
|
|
|
|
|
2020-04-13 01:41:15 +00:00
|
|
|
$DB->prepare("UPDATE `documents` SET `tournament` = ? WHERE `team` = ?;")->execute([$this->tournament_id, $this->team->getId()]);
|
|
|
|
$DB->prepare("UPDATE `solutions` SET `tournament` = ? WHERE `team` = ?;")->execute([$this->tournament_id, $this->team->getId()]);
|
|
|
|
$DB->prepare("UPDATE `syntheses` SET `tournament` = ? WHERE `team` = ?;")->execute([$this->tournament_id, $this->team->getId()]);
|
|
|
|
foreach ($this->team->getParticipants() as $user) {
|
|
|
|
if ($user != null)
|
|
|
|
$DB->prepare("UPDATE `payments` SET `tournament` = ? WHERE `user` = ?;")->execute([$this->tournament_id, $user]);
|
|
|
|
}
|
|
|
|
foreach ($this->team->getEncadrants() as $user) {
|
|
|
|
if ($user != null)
|
|
|
|
$DB->prepare("UPDATE `payments` SET `tournament` = ? WHERE `user` = ?;")->execute([$this->tournament_id, $user]);
|
|
|
|
}
|
|
|
|
|
2019-09-09 21:28:03 +00:00
|
|
|
$_SESSION["tournament"] = $this->tournament;
|
|
|
|
|
2019-12-19 12:02:01 +00:00
|
|
|
header("Location: $URL_BASE/mon-equipe");
|
2019-09-06 11:48:50 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-07 11:42:36 +00:00
|
|
|
require_once "server_files/views/mon_equipe.php";
|