mirror of
https://codeberg.org/vlw/vlw.se.git
synced 2025-09-13 21:13:40 +02:00
This PR refactors some texts on the about page (again), and also a adds two new endpoints for a database table that I have now made public that tracks the coffee cups I've had. The endpoint itself is not public now but I might make a page (something like `/about/coffee`) that presents it in a not-ugly way. Reviewed-on: https://codeberg.org/vlw/vlw.se/pulls/28
35 lines
No EOL
1.2 KiB
PHP
35 lines
No EOL
1.2 KiB
PHP
<?php
|
|
|
|
use Reflect\{Response, Path, Call};
|
|
use ReflectRules\{Ruleset, Rules, Type};
|
|
|
|
use VLW\API\Endpoints;
|
|
use VLW\Database\Database;
|
|
use VLW\Database\Tables\Coffee\{CoffeeTable, StatsTable};
|
|
|
|
require_once Path::root("src/API/Endpoints.php");
|
|
require_once Path::root("src/Database/Database.php");
|
|
require_once Path::root("src/Database/Tables/Coffee/Stats.php");
|
|
require_once Path::root("src/Database/Tables/Coffee/Coffee.php");
|
|
|
|
class POST_CoffeeStats extends Database {
|
|
protected Ruleset $ruleset;
|
|
|
|
public function __construct() {
|
|
$this->ruleset = new Ruleset(strict: true);
|
|
$this->ruleset->validate_or_exit();
|
|
|
|
parent::__construct();
|
|
}
|
|
|
|
public function main(): Response {
|
|
$truncate = $this->db->execute_query("DELETE FROM `" . StatsTable::NAME . "`");
|
|
|
|
// Add a dummy row to run the MariaDB INSERT AFTER Trigger on the coffee database table
|
|
$insert = $this->db->for(CoffeeTable::NAME)->insert([CoffeeTable::ID->value => 0]);
|
|
// Remove the dummy row
|
|
$remove = $this->db->for(CoffeeTable::NAME)->where([CoffeeTable::ID->value => 0])->delete();
|
|
|
|
return $truncate && $insert && $remove ? new Response() : new Response("Error", 500);
|
|
}
|
|
} |