This repository has been archived on 2023-01-06. You can view files and clone it, but cannot push or open issues or pull requests.
web/app/lib/App/Timetable/TimeMapper.php
2022-04-20 09:02:19 +00:00

88 lines
2.2 KiB
PHP

<?php
namespace App\Timetable;
use \PDO;
use \DateTime;
class TimeMapper
{
public PDO $dbh;
public function __construct(PDO $dbh)
{
$this->dbh = $dbh;
}
private function mapRowToTime(array $row): Time
{
$time= new Time();
$time->id = $row['TidID'];
$time->setTeamId($row['LagID']);
$time->setDate(new DateTime($row['Tidspunkt']));
return $time;
}
public function getAll(): array
{
$sth = $this->dbh->query('SELECT * FROM tidtabell');
$assoc_array = $sth->fetchAll(PDO::FETCH_ASSOC);
$times = [];
foreach ($assoc_array as $key => $row)
{
array_push($times, $this->mapRowToTime($row));
}
return $times;
}
public function getLatest(): ?Time
{
$sth = $this->dbh->prepare('SELECT * FROM tidtabell ORDER BY Tidspunkt DESC LIMIT 1');
$sth->execute();
$row = $sth->fetch(PDO::FETCH_ASSOC);
if ($row)
{
return $this->mapRowToTime($row);
}
return NULL;
}
public function getLatestByTeamId(int $team_id): ?Time
{
$sth = $this->dbh->prepare('SELECT * FROM tidtabell WHERE LagID = ? ORDER BY Tidspunkt DESC LIMIT 1');
$sth->execute([$team_id]);
$row = $sth->fetch(PDO::FETCH_ASSOC);
if ($row)
{
return $this->mapRowToTime($row);
}
return NULL;
}
public function get(int $id): ?Time
{
$sth = $this->dbh->prepare('SELECT * FROM tidtabell WHERE TidID = ? LIMIT 1');
$sth->execute([$id]);
$row = $sth->fetch(PDO::FETCH_ASSOC);
if ($row)
{
return $this->mapRowToTime($row);
}
return NULL;
}
public function create(Time $time): Time
{
$sth = $this->dbh->prepare('INSERT INTO tidtabell (LagID) VALUES (?)');
$sth->execute([$time->team_id]);
$last_id = $this->dbh->lastInsertId();
return $this->get($last_id);
}
public function delete(int $id): void
{
$sth = $this->dbh->prepare('DELETE FROM tidtabell WHERE TidID = ?');
$sth->execute([$id]);
}
}