2023-06-27 14:31:55 +02:00
|
|
|
<?php
|
|
|
|
class Database {
|
|
|
|
public PDO $pdo_article;
|
2023-06-28 20:38:52 +02:00
|
|
|
public PDO $pdo_teams;
|
2023-06-27 14:31:55 +02:00
|
|
|
|
|
|
|
public function __construct() {
|
|
|
|
$data_path = "/../data/";
|
|
|
|
try {
|
2023-09-01 19:00:27 -04:00
|
|
|
// Création des bases de données
|
|
|
|
// Base des énigmes :
|
2023-06-27 14:31:55 +02:00
|
|
|
$this->pdo_article = new PDO("sqlite:" . dirname(__FILE__) . $data_path . "article.db");
|
2023-06-28 20:38:52 +02:00
|
|
|
$this->pdo_article->query('CREATE TABLE IF NOT EXISTS "puzzles" (
|
|
|
|
"id" INTEGER NOT NULL UNIQUE,
|
2023-09-01 19:00:27 -04:00
|
|
|
"title" TEXT NOT NULL,
|
2023-06-28 20:38:52 +02:00
|
|
|
"text" TEXT NOT NULL,
|
|
|
|
"hint" TEXT,
|
2023-09-01 19:00:27 -04:00
|
|
|
"answer" TEXT NOT NULL,
|
|
|
|
"location" TEXT NOT NULL,
|
2023-06-28 20:38:52 +02:00
|
|
|
"code" TEXT NOT NULL,
|
|
|
|
PRIMARY KEY("id" AUTOINCREMENT)
|
|
|
|
)');
|
|
|
|
|
2023-09-01 19:00:27 -04:00
|
|
|
// Base des équipes :
|
2023-06-28 20:38:52 +02:00
|
|
|
$this->pdo_teams = new PDO("sqlite:" . dirname(__FILE__) . $data_path . "teams.db");
|
|
|
|
$this->pdo_teams->query('CREATE TABLE IF NOT EXISTS "teams" (
|
|
|
|
"id" INTEGER NOT NULL UNIQUE,
|
2024-09-01 21:02:51 +02:00
|
|
|
"bonus" INTEGER NOT NULL,
|
2023-06-28 20:38:52 +02:00
|
|
|
PRIMARY KEY("id" AUTOINCREMENT)
|
|
|
|
)');
|
2023-06-28 21:20:16 +02:00
|
|
|
|
|
|
|
$this->pdo_teams->query('CREATE TABLE IF NOT EXISTS "solved" (
|
|
|
|
"puzzle_id" INTEGER NOT NULL,
|
|
|
|
"team_id" INTEGER NOT NULL
|
|
|
|
)');
|
2023-09-01 19:00:27 -04:00
|
|
|
|
|
|
|
$this->pdo_teams->query('CREATE TABLE IF NOT EXISTS "members" (
|
|
|
|
"name" TEXT NOT NULL,
|
|
|
|
"team_id" INTEGER NOT NULL
|
|
|
|
)');
|
2023-06-27 14:31:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
catch (PDOException $exception) {
|
|
|
|
var_dump($exception);
|
|
|
|
die();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-01 21:02:51 +02:00
|
|
|
public function getArticle(int $id) {
|
|
|
|
$stmt = $this->pdo_article->prepare("SELECT * FROM puzzles WHERE id == :id");
|
2023-09-01 20:36:37 -04:00
|
|
|
$stmt->bindValue(":id", $id);
|
|
|
|
$stmt->execute();
|
2024-09-01 21:02:51 +02:00
|
|
|
return $stmt->fetch();
|
2023-09-01 20:36:37 -04:00
|
|
|
}
|
|
|
|
|
2023-09-02 00:19:09 -04:00
|
|
|
public function getArticleNb() {
|
|
|
|
$query = $this->pdo_article->query("SELECT COUNT(*) FROM puzzles");
|
|
|
|
return $query->fetch()["COUNT(*)"];
|
|
|
|
}
|
|
|
|
|
2024-09-01 21:02:51 +02:00
|
|
|
public function checkTeamExists(int $id) {
|
|
|
|
$stmt = $this->pdo_teams->prepare("SELECT * FROM teams WHERE id == :id");
|
|
|
|
$stmt->bindValue(":id", $id);
|
|
|
|
$stmt->execute();
|
|
|
|
return !empty($stmt->fetch());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function checkArticleExists(int $id) {
|
|
|
|
return !empty($this->getArticle($id));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function checkPuzzle(int $id, int $code) {
|
|
|
|
$stmt = $this->pdo_article->prepare("SELECT * FROM puzzles WHERE (id == :id AND code == :code)");
|
|
|
|
$stmt->bindValue(":id", $id);
|
|
|
|
$stmt->bindValue(":code", $code);
|
|
|
|
$stmt->execute();
|
|
|
|
return !empty($stmt->fetch());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function isPuzzleSolved(int $id, int $team) {
|
|
|
|
$stmt = $this->pdo_teams->prepare("SELECT * FROM solved WHERE (team_id == :team_id AND puzzle_id == :puzzle_id)");
|
|
|
|
$stmt->bindValue(":team_id", $team);
|
|
|
|
$stmt->bindValue(":puzzle_id", $id);
|
|
|
|
$stmt->execute();
|
|
|
|
return !empty($stmt->fetch());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function solvePuzzle(int $id, int $team) {
|
|
|
|
$stmt = $this->pdo_teams->prepare("INSERT INTO solved VALUES (:puzzle_id, :team_id)");
|
|
|
|
$stmt->bindValue(":puzzle_id", $id);
|
|
|
|
$stmt->bindValue(":team_id", $team);
|
|
|
|
$stmt->execute();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getSolvedPuzzles(int $team) {
|
|
|
|
// $team doit être une équipe existante :
|
|
|
|
$stmt = $this->pdo_teams->prepare("SELECT * FROM solved WHERE team_id == :id");
|
|
|
|
$stmt->bindValue(":id", $team);
|
|
|
|
$stmt->execute();
|
|
|
|
$res = $stmt->fetchAll();
|
|
|
|
$solved = [];
|
|
|
|
foreach ($res as $r) {
|
|
|
|
array_push($solved, $r["puzzle_id"]);
|
|
|
|
}
|
|
|
|
return $solved;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getUnsolvedPuzzles(int $team) {
|
|
|
|
$solved = $this->getSolvedPuzzles($team);
|
|
|
|
$unsolved = range(1, $this->getArticleNb());
|
|
|
|
// On supprime les énigmes résolues :
|
|
|
|
foreach ($solved as $p) {
|
|
|
|
$key = array_search($p, $unsolved);
|
|
|
|
array_splice($unsolved, $key, 1);
|
|
|
|
}
|
|
|
|
return $unsolved;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getNextPuzzle(int $team) {
|
|
|
|
$unsolved = $this->getUnsolvedPuzzles($team);
|
|
|
|
$next = -1; // Quand il n'y a plus d'autre énigme à résoudre
|
|
|
|
if (!empty($unsolved)) {
|
|
|
|
$next = $unsolved[array_rand($unsolved)];
|
|
|
|
}
|
|
|
|
return $next;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function checkTeamBonus(int $team) {
|
|
|
|
// $team doit être une équipe existante :
|
|
|
|
$stmt = $this->pdo_teams->prepare("SELECT bonus FROM teams WHERE id == :id");
|
|
|
|
$stmt->bindValue(":id", $team);
|
|
|
|
$stmt->execute();
|
|
|
|
return $stmt->fetch()[0] == 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTeams() {
|
|
|
|
$stmt = $this->pdo_teams->prepare("SELECT * FROM teams");
|
|
|
|
$stmt->execute();
|
|
|
|
return $stmt->fetchAll();
|
|
|
|
}
|
|
|
|
|
2023-09-01 19:00:27 -04:00
|
|
|
// public function getTeamsNb() {
|
|
|
|
// $query = $this->pdo_teams->query("SELECT COUNT(*) FROM teams");
|
|
|
|
// return $query->fetch()["COUNT(*)"];
|
|
|
|
// }
|
2023-06-27 14:31:55 +02:00
|
|
|
}
|
|
|
|
?>
|