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/model/Teamtable.php

76 lines
1.6 KiB
PHP
Raw Normal View History

2022-02-07 11:09:16 +01:00
<?php
2022-03-02 07:15:12 +01:00
use App\Core\Database as Database;
2022-03-02 14:26:02 +01:00
use App\Teamtable\Team as Team;
2022-03-07 07:13:17 +01:00
use App\Teamtable\TeamMapper as TeamMapper;
2022-03-02 07:15:12 +01:00
2022-03-02 14:26:02 +01:00
/**
2022-03-07 07:13:17 +01:00
* Does stuffs with the teamtable
2022-03-02 14:26:02 +01:00
*/
2022-02-07 11:09:16 +01:00
class Teamtable
{
2022-03-02 14:26:02 +01:00
/**
2022-03-07 07:13:17 +01:00
* Database connection
2022-03-02 14:26:02 +01:00
*/
2022-02-28 05:51:22 +01:00
public PDO $dbh;
2022-03-07 07:13:17 +01:00
/**
* We use a data mapper pattern
*/
public TeamMapper $teamMapper;
2022-02-07 11:09:16 +01:00
public function __construct(Database $database)
{
$this->dbh = $database->conn;
2022-03-07 07:13:17 +01:00
$this->teamMapper = new TeamMapper($this->dbh);
2022-02-07 11:09:16 +01:00
}
2022-03-02 14:26:02 +01:00
/**
* Fetch entire team table
*/
2022-03-07 07:13:17 +01:00
public function getAll(): array
2022-02-09 16:59:20 +01:00
{
2022-03-07 07:13:17 +01:00
return $this->teamMapper->getAll();
2022-02-09 16:59:20 +01:00
}
2022-03-02 07:24:27 +01:00
/**
2022-03-07 07:13:17 +01:00
* Find team with supplied id
2022-03-02 07:24:27 +01:00
*/
2022-03-07 07:13:17 +01:00
public function get(int $id): ?Team
2022-02-09 16:59:20 +01:00
{
2022-03-07 07:13:17 +01:00
return $this->teamMapper->get($id);
2022-02-09 16:59:20 +01:00
}
2022-03-02 07:24:27 +01:00
/**
2022-03-07 07:13:17 +01:00
* Inserts team into database
2022-03-02 07:24:27 +01:00
*/
2022-03-07 07:13:17 +01:00
public function create(Team $team): Team
2022-02-09 16:59:20 +01:00
{
2022-03-07 07:13:17 +01:00
return $this->teamMapper->create($team);
2022-02-09 16:59:20 +01:00
}
2022-03-07 07:13:17 +01:00
public function delete(int $id): void
2022-02-15 12:26:15 +01:00
{
2022-03-07 07:13:17 +01:00
$this->teamMapper->delete($id);
2022-02-09 16:59:20 +01:00
}
2022-02-15 12:40:57 +01:00
2022-03-02 07:24:27 +01:00
/**
* Returns TRUE if team exists, FALSE if not
*/
2022-03-07 07:13:17 +01:00
public function recieveBaton(string $cardnumber): bool
2022-02-15 12:40:57 +01:00
{
2022-03-07 07:13:17 +01:00
$team = $this->getTeamByCardnumber($cardnumber);
if ($team)
2022-02-15 12:40:57 +01:00
{
2022-03-02 07:24:27 +01:00
// team exists, insert into time table
2022-02-15 12:40:57 +01:00
$sth = $this->dbh->prepare('INSERT INTO tidtabell (LagID) VALUES (?)');
$sth->execute([$row['LagID']]);
return TRUE;
}
2022-03-07 07:13:17 +01:00
// team does not exist, lets create it
$team = new Team();
$team->cardnumber = $cardnumber;
$this->addTeam($team);
2022-02-15 12:40:57 +01:00
return FALSE;
}
2022-02-07 11:09:16 +01:00
}