<?php

if (!isset($_SESSION["role"]))
	require_once "server_files/403.php";

$id = $_GET["id"];
$user = User::fromId($id);

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";

$teams = $user->getTeams();

$has_error = false;
$error_message = null;

if (isset($_POST["kick"])) {
	if (sizeof($teams) == 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() 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 ? 1 : 5; ++$i) {
			if (($role == Role::PARTICIPANT ? $this->team->getParticipants()[$i - 1] : $this->team->getEncadrantId()) == 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($user->getId());
		else
			$this->team->setParticipant($this->min_null_index, $user->getId());

		Mailer::sendJoinTeamMail($user, $this->team);

		$team = $this->team;
	}
}

if ($teams != null)
	$documents = $user->getAllDocuments();

require_once "server_files/views/informations.php";