mirror of
				https://gitlab.com/animath/si/plateforme-corres2math.git
				synced 2025-11-04 13:12:20 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			172 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
class Team
 | 
						|
{
 | 
						|
	private $id;
 | 
						|
	private $name;
 | 
						|
	private $trigram;
 | 
						|
	private $problem;
 | 
						|
	private $encadrant;
 | 
						|
	private $participants;
 | 
						|
	private $inscription_date;
 | 
						|
	private $validation_status;
 | 
						|
	private $access_code;
 | 
						|
	private $year;
 | 
						|
 | 
						|
	private function __construct() {}
 | 
						|
 | 
						|
	public static function fromId($id)
 | 
						|
	{
 | 
						|
		global $DB;
 | 
						|
		$req = $DB->prepare("SELECT * FROM `teams` WHERE `id` = ?;");
 | 
						|
		$req->execute([htmlspecialchars($id)]);
 | 
						|
		$data = $req->fetch();
 | 
						|
 | 
						|
		if ($data === false)
 | 
						|
			return null;
 | 
						|
 | 
						|
		$team = new Team();
 | 
						|
		$team->fill($data);
 | 
						|
		return $team;
 | 
						|
	}
 | 
						|
 | 
						|
	public static function fromTrigram($trigram)
 | 
						|
	{
 | 
						|
		global $DB, $YEAR;
 | 
						|
		$req = $DB->prepare("SELECT * FROM `teams` WHERE `trigram` = ? AND `year` = $YEAR;");
 | 
						|
		$req->execute([htmlspecialchars($trigram)]);
 | 
						|
		$data = $req->fetch();
 | 
						|
 | 
						|
		if ($data === false)
 | 
						|
			return null;
 | 
						|
 | 
						|
		$team = new Team();
 | 
						|
		$team->fill($data);
 | 
						|
		return $team;
 | 
						|
	}
 | 
						|
 | 
						|
	public static function fromAccessCode($access_code)
 | 
						|
	{
 | 
						|
		global $DB, $YEAR;
 | 
						|
		$req = $DB->prepare("SELECT * FROM `teams` WHERE `access_code` = ? AND `year` = $YEAR;");
 | 
						|
		$req->execute([htmlspecialchars($access_code)]);
 | 
						|
		$data = $req->fetch();
 | 
						|
 | 
						|
		if ($data === false)
 | 
						|
			return null;
 | 
						|
 | 
						|
		$team = new Team();
 | 
						|
		$team->fill($data);
 | 
						|
		return $team;
 | 
						|
	}
 | 
						|
 | 
						|
	private function fill($data)
 | 
						|
	{
 | 
						|
		$this->id = $data["id"];
 | 
						|
		$this->name = $data["name"];
 | 
						|
		$this->trigram = $data["trigram"];
 | 
						|
		$this->problem = $data["problem"];
 | 
						|
		$this->encadrant = $data["encadrant"];
 | 
						|
		$this->participants = [$data["participant_1"], $data["participant_2"], $data["participant_3"], $data["participant_4"], $data["participant_5"]];
 | 
						|
		$this->inscription_date = $data["inscription_date"];
 | 
						|
		$this->validation_status = ValidationStatus::fromName($data["validation_status"]);
 | 
						|
		$this->access_code = $data["access_code"];
 | 
						|
		$this->year = $data["year"];
 | 
						|
	}
 | 
						|
 | 
						|
	public function getId()
 | 
						|
	{
 | 
						|
		return $this->id;
 | 
						|
	}
 | 
						|
 | 
						|
	public function getName()
 | 
						|
	{
 | 
						|
		return $this->name;
 | 
						|
	}
 | 
						|
 | 
						|
	public function setName($name)
 | 
						|
	{
 | 
						|
		global $DB;
 | 
						|
		$this->name = $name;
 | 
						|
		$DB->prepare("UPDATE `teams` SET `name` = ? WHERE `id` = ?;")->execute([$name, $this->id]);
 | 
						|
	}
 | 
						|
 | 
						|
	public function getTrigram()
 | 
						|
	{
 | 
						|
		return $this->trigram;
 | 
						|
	}
 | 
						|
 | 
						|
	public function setTrigram($trigram)
 | 
						|
	{
 | 
						|
		global $DB;
 | 
						|
		$this->trigram = $trigram;
 | 
						|
		$DB->prepare("UPDATE `teams` SET `trigram` = ? WHERE `id` = ?;")->execute([$trigram, $this->id]);
 | 
						|
	}
 | 
						|
 | 
						|
	public function getProblem()
 | 
						|
	{
 | 
						|
		return $this->problem;
 | 
						|
	}
 | 
						|
 | 
						|
	public function setProblem($problem)
 | 
						|
	{
 | 
						|
		global $DB;
 | 
						|
		$this->problem = $problem;
 | 
						|
		$DB->prepare("UPDATE `teams` SET `problem` = ? WHERE `id` = ?;")->execute([$problem, $this->id]);
 | 
						|
	}
 | 
						|
 | 
						|
	public function getEncadrantId()
 | 
						|
	{
 | 
						|
		return $this->encadrant;
 | 
						|
	}
 | 
						|
 | 
						|
	public function setEncadrant($encadrant)
 | 
						|
	{
 | 
						|
		global $DB;
 | 
						|
		$this->encadrant = $encadrant;
 | 
						|
		/** @noinspection SqlResolve */
 | 
						|
		$DB->prepare("UPDATE `teams` SET `encadrant` = ? WHERE `id` = ?;")->execute([$encadrant, $this->id]);
 | 
						|
	}
 | 
						|
 | 
						|
	public function getParticipants()
 | 
						|
	{
 | 
						|
		return $this->participants;
 | 
						|
	}
 | 
						|
 | 
						|
	public function setParticipant($i, $participant)
 | 
						|
	{
 | 
						|
		global $DB;
 | 
						|
		$this->participants[$i - 1] = $participant;
 | 
						|
		/** @noinspection SqlResolve */
 | 
						|
		$DB->prepare("UPDATE `teams` SET `participant_$i` = ? WHERE `id` = ?;")->execute([$participant, $this->id]);
 | 
						|
	}
 | 
						|
 | 
						|
	public function getInscriptionDate()
 | 
						|
	{
 | 
						|
		return $this->inscription_date;
 | 
						|
	}
 | 
						|
 | 
						|
	public function getValidationStatus()
 | 
						|
	{
 | 
						|
		return $this->validation_status;
 | 
						|
	}
 | 
						|
 | 
						|
	public function setValidationStatus($status)
 | 
						|
	{
 | 
						|
		global $DB;
 | 
						|
		$this->validation_status = $status;
 | 
						|
		/** @noinspection PhpUndefinedMethodInspection */
 | 
						|
		$DB->prepare("UPDATE `teams` SET `validation_status` = ? WHERE `id` = ?;")->execute([ValidationStatus::getName($status), $this->id]);
 | 
						|
	}
 | 
						|
 | 
						|
	public function getAccessCode()
 | 
						|
	{
 | 
						|
		return $this->access_code;
 | 
						|
	}
 | 
						|
 | 
						|
	public function getYear()
 | 
						|
	{
 | 
						|
		return $this->year;
 | 
						|
	}
 | 
						|
}
 |