diff --git a/dispatcher.php b/dispatcher.php
index 1e85705..317038c 100644
--- a/dispatcher.php
+++ b/dispatcher.php
@@ -41,6 +41,9 @@ $ROUTES["^inscription/?$"] = ["server_files/controllers/inscription.php"];
$ROUTES["^mon-compte/?$"] = ["server_files/controllers/mon_compte.php"];
$ROUTES["^mon-equipe/(modifier)/?$"] = ["server_files/controllers/mon_equipe.php", "modifier"];
$ROUTES["^mon-equipe/?$"] = ["server_files/controllers/mon_equipe.php"];
+$ROUTES["^organisateurs"] = ["server_files/controllers/organisateurs.php"];
+$ROUTES["^profils/?$"] = ["server_files/controllers/profils.php"];
+$ROUTES["^profils-(orphelins)/?$"] = ["server_files/controllers/profils.php", "orphans"];
$ROUTES["^rejoindre_equipe/?$"] = ["server_files/controllers/rejoindre_equipe.php"];
$ROUTES["^solutions/?$"] = ["server_files/controllers/solutions.php"];
$ROUTES["^solutions_orga/?$"] = ["server_files/controllers/solutions_orga.php"];
diff --git a/server_files/403.php b/server_files/403.php
index 51e6852..72127d0 100644
--- a/server_files/403.php
+++ b/server_files/403.php
@@ -4,9 +4,13 @@ require_once "config.php";
require_once "views/header.php";
http_response_code(403);
+?>
-echo "
Vous n'êtes pas autorisé à accéder à cette page.
";
+
+
+ Vous n'êtes pas autorisé à accéder à cette page.
+
+
-require_once "views/footer.php";
-
-exit();
\ No newline at end of file
+
-echo "Cette page n'existe pas.
";
+
+
+ Cette page n'existe pas.
+
+
-require_once "views/footer.php";
-
-exit();
\ No newline at end of file
+year;
}
+
+ public static function getAllTeams($only_not_validated = false)
+ {
+ global $DB, $YEAR;
+ $req = $DB->query("SELECT * FROM `teams` WHERE " . ($only_not_validated ? "`validation_status` = 'NOT_READY' AND " : "") . "`year` = $YEAR;");
+
+ $teams = [];
+
+ while (($data = $req->fetch()) != false) {
+ $team = new Team();
+ $team->fill($data);
+ $teams[] = $team;
+ }
+
+ return $teams;
+ }
}
diff --git a/server_files/classes/User.php b/server_files/classes/User.php
index cd1fd8d..15a6f62 100644
--- a/server_files/classes/User.php
+++ b/server_files/classes/User.php
@@ -86,6 +86,52 @@ class User
$this->forgotten_password = $data["forgotten_password"];
$this->inscription_date = $data["inscription_date"];
}
+ public static function getOrganizers()
+ {
+ global $DB, $YEAR;
+ $admins = [];
+ $req = $DB->query("SELECT * FROM `users` WHERE `role` = 'ORGANIZER' OR `role` = 'ADMIN' AND `year` = $YEAR;");
+
+ while (($data = $req->fetch()) !== false) {
+ $admin = new User();
+ $admin->fill($data);
+ $admins[] = $admin;
+ }
+
+ return $admins;
+ }
+
+ public static function getAllUsers()
+ {
+ global $DB, $YEAR;
+ $users = [];
+ $req = $DB->query("SELECT * FROM `users` WHERE (`role` = 'PARTICIPANT' OR `role` = 'ENCADRANT') "
+ . "AND `year` = $YEAR ORDER BY `role`, `inscription_date`;");
+
+ while (($data = $req->fetch()) !== false) {
+ $orphan = new User();
+ $orphan->fill($data);
+ $users[] = $orphan;
+ }
+
+ return $users;
+ }
+
+ public static function getOrphanUsers()
+ {
+ global $DB, $YEAR;
+ $orphans = [];
+ $req = $DB->query("SELECT * FROM `users` WHERE `role` != 'ADMIN' AND `team_id` IS NULL "
+ . "AND `year` = $YEAR ORDER BY `role`, `inscription_date`;");
+
+ while (($data = $req->fetch()) !== false) {
+ $orphan = new User();
+ $orphan->fill($data);
+ $orphans[] = $orphan;
+ }
+
+ return $orphans;
+ }
public function getEmail()
{
diff --git a/server_files/controllers/informations.php b/server_files/controllers/informations.php
index 5422f72..6863dec 100644
--- a/server_files/controllers/informations.php
+++ b/server_files/controllers/informations.php
@@ -6,29 +6,110 @@ if (!isset($_SESSION["role"]))
$id = $_GET["id"];
$user = User::fromId($id);
-if ($_SESSION["role"] != Role::ORGANIZER && $_SESSION["role"] != Role::ADMIN) {
- if ($user->getId() != $_SESSION["user_id"] && ($user->getTeamId() == null || $user->getTeamId() != $_SESSION["user"]->getTeamId()))
+if ($_SESSION["role"] != Role::ADMIN) {
+ if ($user->getId() != $_SESSION["user_id"])
require_once "server_files/403.php";
}
if ($user === null)
require_once "server_files/404.php";
-if (isset($_POST["view_as"]) && $_SESSION["role"] == Role::ADMIN) {
- if (!isset($_SESSION["admin"]))
- $_SESSION["admin"] = $_SESSION["user_id"];
- $_SESSION["user_id"] = $user->getId();
- header("Location: /");
- exit();
-}
-
$team = Team::fromId($user->getTeamId());
-$tournaments = $user->getOrganizedTournaments();
-if ($team != null) {
- $documents = $user->getAllDocuments($team->getTournamentId());
- if ($team->isSelectedForFinal())
- $documents_final = $user->getAllDocuments($FINAL->getId());
+$has_error = false;
+$error_message = null;
+
+if (isset($_POST["kick"])) {
+ if ($team == null) {
+ $has_error = true;
+ $error_message = "La personne à expulser n'est dans aucune équipe.";
+ }
+ else {
+ quitTeam($id);
+ $team = null;
+ }
}
+if (isset($_POST["attribute_team"])) {
+ $attribute_team = new AttributeTeam($_POST);
+ try {
+ $attribute_team->makeVerifications();
+ $attribute_team->attribute();
+ } catch (AssertionError $e) {
+ $has_error = true;
+ $error_message = $e->getMessage();
+ }
+}
+
+if (isset($_POST["view_as"]) && $_SESSION["role"] == Role::ADMIN) {
+ if (!isset($_SESSION["admin"]))
+ $_SESSION["admin"] = $_SESSION["user_id"];
+ $_SESSION["user_id"] = $user->getId();
+ header("Location: /");
+ exit();
+}
+
+if (isset($_POST["delete_account"]) && $team == null && $_SESSION["role"] == Role::ADMIN) {
+ /** @var Document $document */
+ foreach ($user->getAllDocuments($team->getTournamentId()) as $document)
+ unlink($LOCAL_PATH . "/files/" . $document->getFileId());
+ $DB->prepare("DELETE FROM `documents` WHERE `user` = ?;")->execute([$user->getId()]);
+ $DB->prepare("DELETE FROM `users` WHERE `id` = ?;")->execute([$user->getId()]);
+ header("Location: /");
+ exit();
+}
+
+class AttributeTeam
+{
+ private $team_id;
+ private $team;
+ private $min_null_index;
+
+ public function __construct($data)
+ {
+ $this->team_id = $data["team"];
+ $this->team = Team::fromId($this->team_id);
+ }
+
+ public function makeVerifications()
+ {
+ global $user;
+
+ ensure($user->getConfirmEmailToken() == null, "Ce participant n'a pas encore validé son adresse e-mail.");
+ ensure($this->team_id != "no_team", "Vous n'avez pas choisi d'équipe.");
+ ensure($this->team != null, "Cette équipe n'existe pas.");
+ ensure($this->team->getValidationStatus() == ValidationStatus::NOT_READY, "Cette équipe est déjà validée ou en cours de validation.");
+
+ $role = $user->getRole();
+ for ($i = 1; $i <= $role == Role::ENCADRANT ? 2 : 6; ++$i) {
+ if (($role == Role::PARTICIPANT ? $this->team->getParticipants()[$i - 1] : $this->team->getEncadrants()[$i]) == NULL)
+ break;
+ }
+
+ $this->min_null_index = $i;
+
+ ensure($role == Role::PARTICIPANT && $this->min_null_index <= 5 || $role == Role::ENCADRANT && $this->min_null_index <= 2,
+ "Il n'y a plus de place pour vous dans l'équipe.");
+ }
+
+ public function attribute()
+ {
+ global $user, $team;
+
+ $user->setTeamId($this->team->getId());
+
+ if ($user->getRole() == Role::ENCADRANT)
+ $this->team->setEncadrant($this->min_null_index, $user->getId());
+ else
+ $this->team->setParticipant($this->min_null_index, $user->getId());
+
+ Mailer::sendJoinTeamMail($user, $this->team, Tournament::fromId($this->team->getTournamentId()));
+
+ $team = $this->team;
+ }
+}
+
+if ($team != null)
+ $documents = $user->getAllDocuments($team->getTournamentId());
+
require_once "server_files/views/informations.php";
diff --git a/server_files/controllers/inscription.php b/server_files/controllers/inscription.php
index 3f1462a..2ab593b 100644
--- a/server_files/controllers/inscription.php
+++ b/server_files/controllers/inscription.php
@@ -3,7 +3,7 @@
$has_error = false;
$error_message = null;
-if (isset($_POST["submitted"])) {
+if (isset($_POST["register"])) {
$user = new NewUser($_POST);
try {
diff --git a/server_files/controllers/organisateurs.php b/server_files/controllers/organisateurs.php
new file mode 100644
index 0000000..446dccc
--- /dev/null
+++ b/server_files/controllers/organisateurs.php
@@ -0,0 +1,8 @@
+getId();
+ if ($user_id == -1)
+ $user_id = $user->getId();
+ else
+ $user = User::fromId($user_id);
$role = $user->getRole();
if ($role == Role::ADMIN || $role == Role::ORGANIZER)
@@ -161,17 +164,22 @@ function canValidate(Team $team, Tournament $tournament)
function printDocuments($documents)
{
- global $URL_BASE;
+ if (sizeof($documents) == 0) {
+ echo "\nPas de document envoyé pour le moment.\n
\n";
+ return;
+ }
+ echo "\n";
foreach ($documents as $document) {
$file_id = $document->getFileId();
$user = User::fromId($document->getUserId());
$surname = $user->getSurname();
$first_name = $user->getFirstName();
- $name = DocumentType::getTranslatedName($document->getType());
+ $name = "Autorisation de droit à l'image";
$version = $document->getVersion();
- echo "$name de $first_name $surname (version $version) :
Télécharger";
+ echo "$name de $first_name $surname (version $version) :
Télécharger\n";
}
+ echo "
\n";
}
function getZipFile($document_type, $tournament_id, $team_id = -1)
diff --git a/server_files/views/ajouter_organisateur.php b/server_files/views/ajouter_organisateur.php
index 097aa41..53b1c86 100644
--- a/server_files/views/ajouter_organisateur.php
+++ b/server_files/views/ajouter_organisateur.php
@@ -35,8 +35,16 @@ require_once "header.php";
+
+
-
+
diff --git a/server_files/views/equipe.php b/server_files/views/equipe.php
index 89cabb5..e5610ba 100644
--- a/server_files/views/equipe.php
+++ b/server_files/views/equipe.php
@@ -39,7 +39,7 @@
getEncadrants()[$i] == NULL)
+ if ($team->getEncadrants()[$i - 1] == NULL)
continue;
$encadrant = User::fromId($team->getEncadrants()[$i - 1]);
$id = $encadrant->getId();
diff --git a/server_files/views/header.php b/server_files/views/header.php
index 1a8d053..a1fbe99 100644
--- a/server_files/views/header.php
+++ b/server_files/views/header.php
@@ -28,6 +28,11 @@
Liste des tournois
+
diff --git a/server_files/views/informations.php b/server_files/views/informations.php
index e9383b2..0500384 100644
--- a/server_files/views/informations.php
+++ b/server_files/views/informations.php
@@ -112,7 +112,7 @@ if ($user->getRole() == Role::ADMIN || $user->getRole() == Role::ORGANIZER) {
echo "";
}
}
-elseif ($user->getRole() == Role::PARTICIPANT || $user->getRole() == Role::ENCADRANT) { ?>
+elseif (($user->getRole() == Role::PARTICIPANT || $user->getRole() == Role::ENCADRANT) && $user->getTeamId() !== NULL) { ?>
Autorisations
+
+
+
Liste des organisateurs
+
+
+
+
+
+
+
+
+
+
= $orphans ? "Profils orphelins" : "Tous les profils" ?>
+
+
+
+ Cette page recense tous les utilisateurs inscrits= $orphans ? " mais qui n'ont pas rejoint d'équipe" : "" ?>.
+
+
+
+
+
+
+