removed old table stuff

This commit is contained in:
tracer 2022-01-19 21:07:22 +01:00
parent fb6fc90bc1
commit da1f7203b0

View File

@ -0,0 +1,248 @@
<?php
namespace App\Controller;
// TODO add to all Controllers
error_reporting(E_ALL);
// 61e6ce5dd8a1b.bc1c314ce364f6878084c254fe4c6345801c43a49bb8eb71
use LucidFrame\Console\ConsoleTable;
use PDO;
use UnhandledMatchError;
if (php_sapi_name() !== 'cli') {
exit;
}
/**
*
*/
class BindAPI
{
private PDO $dbConnection;
private ApiUsers $apiUsers;
private DomainController $domainController;
public function __construct(private int $argc, private array $argv)
{
$this->dbConnection = (new DatabaseConnection())->getConnection();
$this->apiUsers = new ApiUsers($this->dbConnection);
$this->domainController = new DomainController($this->dbConnection);
}
function runCommand()
{
if ($this->argc < 2) {
$this->showUsage();
}
[$command, $subcommand] = explode(':', $this->argv[1]);
try {
match ($command) {
'apikeys' => $this->handleApiKeys($subcommand),
'domains' => $this->handleDomains($subcommand)
};
} catch(UnhandledMatchError) {
echo 'Unknown command: ' . $command . PHP_EOL;
exit(1);
}
}
/**
* @return void
*/
function showUsage(): void
{
echo 'Usage' . PHP_EOL;
echo "\033[33mapikeys" . PHP_EOL;
echo "\033[32m\tapikeys:list" . PHP_EOL;
echo "\033[32m\tapikeys:create" . PHP_EOL;
echo "\033[32m\tapikeys:delete {ID}" . PHP_EOL;
echo "\033[33mdomains" . PHP_EOL;
echo "\033[32m\tdomains:list" . PHP_EOL;
echo "\033[32m\tdomains:create <name> {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
echo "\033[32m\tdomains:update <ID> {name} {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
echo "\033[32m\tdomains:delete" . PHP_EOL;
echo "\033[32m\tdomains:check" . PHP_EOL;
echo PHP_EOL . "\033[39me.g. ./bin/console apikey:list" . PHP_EOL;
exit(0);
}
/**
* @param \App\Controller\ApiUsers $apiUsers
*
* @return void
*/
function handleApikeysCreate(ApiUsers $apiUsers): void
{
$result = $apiUsers->create();
echo 'API key ' . $result['row'] . ' has been generated. Store it in a save place, it cannot be recovered.' . PHP_EOL;
echo "\033[32m\t" . $result['tokenPrefix'] . '.' . $result['key'] . PHP_EOL;
exit(0);
}
/**
* @param ApiUsers $apiUsers
*
* @return void
*/
function handleApikeysList(ApiUsers $apiUsers): void
{
echo 'All valid API keys:' . PHP_EOL;
$keys = $apiUsers->findAll();
if ($keys) {
$table = new ConsoleTable();
$table->setHeaders(['ID', 'API key prefix']);
foreach ($keys as $key) {
$table->addRow([$key['id'], $key['api_token_prefix']]);
}
$table->setPadding(2);
$table->display();
} else {
echo 'No keys found.' . PHP_EOL;
}
exit(0);
}
/**
* @param ApiUsers $apiUsers
*
* @return void
*/
function handleApikeysDelete(ApiUsers $apiUsers): void
{
$id = $argv[2] ?? 0;
if ($id == 0) {
echo 'You need to add the ID of the token.' . PHP_EOL;
exit(1);
}
if ($apiUsers->findByID($id)) {
$apiUsers->delete($id);
echo 'Token ' . $id . ' has been deleted.' . PHP_EOL;
exit(0);
} else {
echo 'Unknown ID: ' . $id . PHP_EOL;
exit(1);
}
}
/**
* @param \App\Controller\DomainController $domainController
*
* @return void
*/
function handleDomainsList(DomainController $domainController): void
{
echo 'All available domains:' . PHP_EOL;
$domains = $domainController->findAll();
if ($domains) {
$table = new ConsoleTable();
$table->setHeaders(['ID', 'Name', 'A', 'AAAA']);
foreach ($domains as $domain) {
$table->addRow([$domain['id'], $domain['name'], $domain['a'], $domain['aaaa']]);
}
$table->setPadding(2);
$table->display();
} else {
echo 'No domains found.' . PHP_EOL;
exit(1);
}
exit(0);
}
/**
* @param \App\Controller\DomainController $domainController
*
* @return void
*/
function handleDomainCreate(DomainController $domainController): void
{
$name = $this->argv[2] ?? "";
if (empty($name)) {
echo 'You need to supply the domain name.' . PHP_EOL;
exit(1);
}
$filteredName = filter_var($name, FILTER_VALIDATE_DOMAIN, FILTER_FLAG_HOSTNAME);
if (!empty($filteredName) && str_contains($filteredName, '.')) {
$name = $filteredName;
} else {
echo "$name is no valid DNS domain name." . PHP_EOL;
exit(1);
}
foreach ($this->argv as $argument) {
if (str_contains($argument, '=')) {
[$key, $value] = explode('=', $argument);
$arguments[$key] = $value;
}
}
$a = $arguments['a'] ?? "";
$aaaa = $arguments['aaaa'] ?? "";
if (empty($a) && empty($aaaa)) {
echo 'At least one IP address is required.';
exit(0);
}
if ($domainController->findByName($name)) {
echo "Domain: $name already exists." . PHP_EOL;
exit(1);
} else {
$dcResult = $domainController->insert($name, $a, $aaaa);
echo "Domain $name has been created" . PHP_EOL;
exit(0);
}
}
/**
* @param string $subcommand
*
* @return void
*/
public function handleApiKeys(string $subcommand): void
{
try {
match ($subcommand) {
'create' => $this->handleApikeysCreate($this->apiUsers),
'list' => $this->handleApikeysList($this->apiUsers),
'delete' => $this->handleApikeysDelete($this->apiUsers),
};
} catch (UnhandledMatchError $error) {
echo 'Unknown action: ' . $subcommand . PHP_EOL;
}
}
/**
* @param string $subcommand
*
* @return void
*/
public function handleDomains(string $subcommand): void
{
try {
match ($subcommand) {
'list' => $this->handleDomainsList($this->domainController),
'create' => $this->handleDomainCreate($this->domainController),
};
} catch (UnhandledMatchError $error) {
echo "Unknown Command: $subcommand" . PHP_EOL;
exit(1);
}
}
}