site-accueil-insa/classes/dao.php

99 lines
3.1 KiB
PHP
Raw Normal View History

2018-06-15 09:33:29 +02:00
<?php
2019-05-16 07:28:02 +02:00
class Dao
{
2018-06-15 09:33:29 +02:00
private $conn;
public function __construct()
2018-06-15 09:33:29 +02:00
{
2019-08-12 16:36:46 +02:00
$username = 'accueil_insa';
$password = $this->read_password();
$dsn = 'mysql:dbname=accueil_insa;host=127.0.0.1';
2018-06-15 09:33:29 +02:00
try {
$this->conn = new PDO($dsn, $username, $password, [PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8']);
2019-05-16 07:28:02 +02:00
} catch (PDOException $e) {
echo $e;
2018-06-15 09:33:29 +02:00
}
}
private function read_password()
2019-05-16 07:28:02 +02:00
{
2019-08-12 16:36:46 +02:00
$real_path = __DIR__.DIRECTORY_SEPARATOR.".htpassdb";
$file = fopen($real_path, "r") or die("Unable to open DB password file!");;
2018-06-15 09:33:29 +02:00
$password = fgets($file);
fclose($file);
return trim($password);
2018-06-15 09:33:29 +02:00
}
2019-05-16 07:28:02 +02:00
public function get_score_team($team)
{
$sql = 'SELECT text, points FROM scores WHERE team = ?';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$team]);
return $cursor->fetchAll(PDO::FETCH_ASSOC);
2018-06-15 09:33:29 +02:00
}
2019-05-16 07:28:02 +02:00
public function save_scores($scores_json, $team)
{
$sql = 'DELETE FROM scores WHERE team = ?';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$team]);
foreach ($scores_json as $value) {
2019-05-16 07:28:02 +02:00
$sql = 'INSERT INTO scores (text, points, team) VALUES (?, ?, ?)';
2018-06-15 09:33:29 +02:00
$cursor = $this->conn->prepare($sql);
$cursor->execute([$value['text'], $value['points'], $team]);
2018-06-15 09:33:29 +02:00
}
}
public function get_map_info($selector)
{
$sql = 'SELECT title, description FROM map_insa WHERE selector = ?';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$selector]);
return $cursor->fetchAll(PDO::FETCH_ASSOC);
}
public function get_map_selectors()
{
$sql = 'SELECT selector FROM map_insa';
$cursor = $this->conn->prepare($sql);
$cursor->execute();
return $cursor->fetchAll(PDO::FETCH_ASSOC);
}
public function save_map_info($selector, $info_json)
{
$sql = 'DELETE FROM map_insa WHERE selector = ?';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$selector]);
$sql = 'INSERT INTO map_insa (title, description, selector) VALUES (?, ?, ?)';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$info_json['title'], $info_json['description'], $selector]);
}
public function get_activities_of_day($day)
{
$sql = 'SELECT * FROM planning_insa WHERE day = ?';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$day]);
return $cursor->fetchAll(PDO::FETCH_ASSOC);
}
public function save_day_activities($day, $info_json)
{
$sql = 'DELETE FROM planning_insa WHERE day = ?';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$day]);
foreach ($info_json as $value) {
$sql = 'INSERT INTO planning_insa (day, small_title, full_title, description, color, start, length) VALUES (?, ?, ?, ?, ?, ?, ?)';
$cursor = $this->conn->prepare($sql);
$cursor->execute([$value['day'], $value['small_title'], $value['full_title'], $value['description'], $value['color'], $value['start'], $value['length']]);
}
}
2018-06-15 09:33:29 +02:00
}