Compare commits

...

19 Commits

Author SHA1 Message Date
tracer 69659bb33f renamed ApiUser to ApiKeys
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 16:36:04 +01:00
tracer 4f02c68cc5 replaced PDI with DatabaseConnection
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 16:35:17 +01:00
tracer 079f46dd18 renamed ApiUsers to ApiKeys
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 16:33:13 +01:00
tracer b7df1220fb added getLongest entry
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 16:32:22 +01:00
tracer 37e358e4ad removed unneeded TODO item
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 16:31:49 +01:00
tracer aa706c9e6a added table check/creation
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 16:31:18 +01:00
tracer 28b2738c3e overhauled error check
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 16:28:46 +01:00
tracer eb56d78a9e added name parameter to error_reporting;
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 15:24:12 +01:00
tracer 504992bf21 finished check ping
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 15:22:20 +01:00
tracer 115a42baa3 added check for config file
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 15:21:41 +01:00
tracer 1dfc68b974 added options
Signed-off-by: tracer <tracer@24unix.net>
2022-01-23 13:48:15 +01:00
tracer fa36673943 initial commit
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 19:09:44 +01:00
tracer 42ac2136a4 changed exit code if error
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 18:52:17 +01:00
tracer e6ed2271d5 moved from PDO to DatabaseConnection
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 18:46:28 +01:00
tracer bc50b00127 added table names as const
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 18:45:34 +01:00
tracer d769a5cc0b reverted prefix, prefix must be set in Database Class
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 18:45:00 +01:00
tracer f01efa342f changed from PDO to DatabaseConnection
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 18:43:51 +01:00
tracer 9287ea22db initial commit
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 18:43:16 +01:00
tracer 53e942f077 replaced PDO with DatabaseConnection
Signed-off-by: tracer <tracer@24unix.net>
2022-01-22 18:25:18 +01:00
10 changed files with 734 additions and 138 deletions

View File

@ -4,15 +4,108 @@ if (php_sapi_name() !== 'cli') {
exit; exit;
} }
// version, store that somewhere else
$version = '0.0.1';
require dirname(path: __DIR__) . '/vendor/autoload.php'; require dirname(path: __DIR__) . '/vendor/autoload.php';
use App\Controller\BindAPI; use App\Controller\BindAPI;
$configFile = dirname(path: __DIR__) ."/config.json"; $configFile = dirname(path: __DIR__) ."/config.json";
if (!file_exists($configFile)) {
echo 'Missing config file' . PHP_EOL;
if (confirm(message: 'Should I create a new config based on config.json.sample?')) {
copy(from: 'config.json.sample', to: 'config.json');
echo 'Config file has been generated. Adjust it to your needs, then proceed to database setup.' . PHP_EOL;
} else {
echo 'You first have to setup the bindAPI. Bye.' . PHP_EOL;
exit(0);
}
exit(1);
}
$configJSON = file_get_contents($configFile); $configJSON = file_get_contents($configFile);
$config = json_decode($configJSON, associative: true);
$app = new BindAPI(config: $config, argc: $argc, argv: $argv); if (!$config = json_decode($configJSON, associative: true)) {
echo 'Error parsing the config file.' . PHP_EOL;
echo $configJSON;
}
$shortOpts = 'v::'; // version
$shortOpts .= "V::"; // verbose
$shortOpts .= "h::"; // help
$longOpts = [
'version::',
'verbose::',
'help::'
];
$options = getopt($shortOpts, $longOpts, rest_index: $restIndex);
if (array_key_exists('v', $options) || array_key_exists('version', $options) ) {
print("bindAPI version: $version" . PHP_EOL);
exit(0);
}
if (array_key_exists('h', $options) || array_key_exists('help', $options) ) {
print("Help …" . PHP_EOL);
exit(0);
}
if (array_key_exists('V', $options) || array_key_exists('verbose', $options) ) {
$config['verbose'] = true;
} else {
$config['verbose'] = false;
}
$arguments = array_slice($argv, $restIndex);
$app = new BindAPI(config: $config, argumentsCount: count($arguments), arguments: $arguments);
$app->runCommand(); $app->runCommand();
/**
* @param String $message
* @param array $options
* @param string $default
*
* @return bool
*/
function confirm(String $message = 'Are you sure? ', array $options = ['y', 'n'], string $default ='n'): bool
{
// first $options means true, any other false
echo $message, ' (';
$first = true;
foreach ($options as $option) {
// mark default
if ($option == $default) {
$option = strtoupper($option);
}
if ($first) {
echo $option;
$first = false;
} else {
echo '/', $option;
}
}
echo '): ';
$handle = fopen("php://stdin", 'r');
$line = trim(fgetc($handle));
fclose($handle);
if ($line == '') {
// enter
$line = $default;
}
if ($line == $options[0]) {
$result = true;
} else {
$result = false;
}
return $result;
}

View File

@ -3,5 +3,5 @@
"dbPort": 3306, "dbPort": 3306,
"dbDatabase": "sampledb", "dbDatabase": "sampledb",
"dbUser": "sampleuser", "dbUser": "sampleuser",
"dbPassword": "secret" "dbPassword": "secret",
} }

View File

@ -9,9 +9,9 @@ use PDOException;
/** /**
* *
*/ */
class ApiUsers class ApiKeys
{ {
public function __construct(private PDO $dbConnection) public function __construct(private DatabaseConnection $databaseConnection)
{} {}
@ -21,11 +21,11 @@ class ApiUsers
public function findAll(): bool|array public function findAll(): bool|array
{ {
$sql = " $sql = "
SELECT id, api_token_prefix, api_token SELECT id, name, api_token_prefix, api_token
FROM user"; FROM " . DatabaseConnection::TABLE_USER;
try { try {
$statement = $this->dbConnection->query($sql); $statement = $this->databaseConnection->getConnection()->query($sql);
return $statement->fetchAll(mode: PDO::FETCH_ASSOC); return $statement->fetchAll(mode: PDO::FETCH_ASSOC);
} catch (PDOException $e) { } catch (PDOException $e) {
exit($e->getMessage()); exit($e->getMessage());
@ -41,13 +41,13 @@ class ApiUsers
public function findByID(Int $id): bool|array public function findByID(Int $id): bool|array
{ {
$sql = " $sql = "
SELECT api_token_prefix, api_token SELECT name, api_token_prefix, api_token
FROM user FROM " . DatabaseConnection::TABLE_USER . "
WHERE id = :id; WHERE id = :id;
"; ";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':id', var: $id); $statement->bindParam(param: ':id', var: $id);
$statement->execute(); $statement->execute();
return $statement->fetch(mode: PDO::FETCH_ASSOC); return $statement->fetch(mode: PDO::FETCH_ASSOC);
@ -65,12 +65,12 @@ class ApiUsers
public function findByPrefix(String $prefix): bool|array public function findByPrefix(String $prefix): bool|array
{ {
$sql = " $sql = "
SELECT api_token SELECT name, api_token
FROM user FROM " . DatabaseConnection::TABLE_USER . "
WHERE api_token_prefix = :prefix"; WHERE api_token_prefix = :prefix";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':prefix', var: $prefix); $statement->bindParam(param: ':prefix', var: $prefix);
$statement->execute(); $statement->execute();
return $statement->fetch(mode: PDO::FETCH_ASSOC); return $statement->fetch(mode: PDO::FETCH_ASSOC);
@ -83,7 +83,7 @@ class ApiUsers
/** /**
* @return array|void * @return array|void
*/ */
public function create() public function create(String $name = '')
{ {
$tokenPrefix = uniqid(); $tokenPrefix = uniqid();
$result['tokenPrefix'] = $tokenPrefix; $result['tokenPrefix'] = $tokenPrefix;
@ -97,15 +97,17 @@ class ApiUsers
$token = password_hash(password: $tokenPrefix . '.' . $key, algo: PASSWORD_ARGON2ID); $token = password_hash(password: $tokenPrefix . '.' . $key, algo: PASSWORD_ARGON2ID);
$sql = " $sql = "
INSERT INTO user (api_token_prefix, api_token) INSERT INTO " . DatabaseConnection::TABLE_USER . " (name, api_token_prefix, api_token)
VALUES (:token_prefix, :token)"; VALUES (:token_prefix, :token)";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':token_prefix', var: $tokenPrefix); $statement->bindParam(param: ':token_prefix', var: $tokenPrefix);
$statement->bindParam(param: ':token', var: $token); $statement->bindParam(param: ':token', var: $token);
$statement->bindParam(param: ':name', var: $name);
$statement->execute(); $statement->execute();
$result['row'] = $this->dbConnection->lastInsertId(); $result['row'] = $this->databaseConnection->getConnection()->lastInsertId();
return $result; return $result;
} catch (PDOException $e) { } catch (PDOException $e) {
exit($e->getMessage()); exit($e->getMessage());
@ -121,11 +123,11 @@ class ApiUsers
public function delete($id): int public function delete($id): int
{ {
$sql = " $sql = "
DELETE FROM user DELETE FROM " . DatabaseConnection::TABLE_USER . "
WHERE id = :id"; WHERE id = :id";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: 'id', var: $id); $statement->bindParam(param: 'id', var: $id);
$statement->execute(); $statement->execute();
return $statement->rowCount(); return $statement->rowCount();

View File

@ -2,21 +2,19 @@
namespace App\Controller; namespace App\Controller;
define('COLOR_YELLOW', "\033[33m"); define('COLOR_RED', "\033[31m");
define('COLOR_GREEN', "\033[32m"); define('COLOR_GREEN', "\033[32m");
define('COLOR_YELLOW', "\033[33m");
define('COLOR_DEFAULT', "\033[39m"); define('COLOR_DEFAULT', "\033[39m");
// TODO add to all Controllers // TODO add to all Controllers
error_reporting(E_ALL); error_reporting(error_level: E_ALL);
// 61e6ce5dd8a1b.bc1c314ce364f6878084c254fe4c6345801c43a49bb8eb71 // 61e6ce5dd8a1b.bc1c314ce364f6878084c254fe4c6345801c43a49bb8eb71
use LucidFrame\Console\ConsoleTable; use LucidFrame\Console\ConsoleTable;
use PDO;
use UnhandledMatchError; use UnhandledMatchError;
if (php_sapi_name() !== 'cli') { if (php_sapi_name() !== 'cli') {
exit; exit;
} }
@ -26,54 +24,86 @@ if (php_sapi_name() !== 'cli') {
*/ */
class BindAPI class BindAPI
{ {
private PDO $dbConnection; private DatabaseConnection $databaseConnection;
private ApiUsers $apiUsers; private ApiKeys $apiUsers;
private DomainController $domainController; private DomainController $domainController;
private PanelController $panelController; private PanelController $panelController;
private NameserverController $nameserverController; private NameserverController $nameserverController;
private CheckController $checkController; private CheckController $checkController;
public function __construct(private array $config, private int $argc, private array $argv)
public function __construct(private array $config, private int $argumentsCount, private array $arguments)
{ {
$this->dbConnection = (new DatabaseConnection(config: $this->config))->getConnection(); $this->databaseConnection = new DatabaseConnection(config: $this->config);
$this->panelController = new PanelController($this->dbConnection); $this->panelController = new PanelController($this->databaseConnection);
$this->apiUsers = new ApiUsers($this->dbConnection); $this->apiUsers = new ApiKeys($this->databaseConnection);
$this->domainController = new DomainController($this->dbConnection); $this->domainController = new DomainController($this->databaseConnection);
$this->nameserverController = new NameserverController($this->dbConnection); $this->nameserverController = new NameserverController($this->databaseConnection);
$this->checkController = new CheckController(); $this->checkController = new CheckController();
} }
/** /**
* @param bool|array $panel * @param bool|array $panel
* *
* @return void * @return bool
*/ */
public function checkPing(bool|array $panel): void public function checkPing(bool|array $panel): Bool
{ {
$maxName = $this->panelController->getLongestEntry(field: 'name');
$maxA = $this->panelController->getLongestEntry(field: 'a');
$maxAAAA = $this->panelController->getLongestEntry(field: 'aaaa');
$error = false;
if ($this->config['verbose']) {
print(COLOR_YELLOW . str_pad(string: $panel['name'], length: $maxName));
}
$a = $panel['a'] ?? ''; $a = $panel['a'] ?? '';
print(COLOR_YELLOW . $panel['name']);
if (!empty($a)) { if (!empty($a)) {
if ($this->checkController->sendCommand(serverName: $panel['name'], versionIP: 4, apiKey: $panel['apikey'], command: 'ping')) { if ($this->config['verbose']) {
// if verbose … echo COLOR_DEFAULT . ' ' . str_pad(string: $a, length: $maxA, pad_type: STR_PAD_LEFT) . ' ';
print(COLOR_DEFAULT . ' ' . $panel['a'] . ': ' . COLOR_GREEN . 'pong'); }
if ($result = $this->checkController->sendCommand(serverName: $panel['name'], versionIP: 4, apiKey: $panel['apikey'], command: 'ping')) {
if ($this->config['verbose']) {
if ($result == 'pong') {
echo COLOR_GREEN . $result;
} else {
echo COLOR_RED . $result;
}
}
} else { } else {
$error = true; $error = true;
} }
} }
$aaaa = $panel['aaaa'] ?? ''; $aaaa = $panel['aaaa'] ?? '';
if (!empty($aaaa)) { if (!empty($aaaa)) {
if ($this->checkController->sendCommand(serverName: $panel['name'], versionIP: 6, apiKey: $panel['apikey'], command: 'ping')) { if ($this->config['verbose']) {
// if verbose … echo COLOR_DEFAULT . ' ' . str_pad(string: $aaaa, length: $maxAAAA, pad_type: STR_PAD_LEFT);
print(COLOR_DEFAULT . ' ' . $panel['aaaa'] . ': ' . COLOR_GREEN . 'pong' . PHP_EOL); }
if ($result = $this->checkController->sendCommand(serverName: $panel['name'], versionIP: 6, apiKey: $panel['apikey'], command: 'ping')) {
if ($this->config['verbose']) {
if ($result == 'pong') {
echo COLOR_GREEN . $result;
} else {
echo COLOR_RED . $result;
}
}
} else { } else {
$error = true; $error = true;
} }
} }
if ($this->config['verbose']) {
echo PHP_EOL;
}
return $error;
} }
function handleCheck(String $subcommand) function handleChecks(String $subcommand)
{ {
print("hable");
try { try {
match ($subcommand) { match ($subcommand) {
'permissions' => $this->handleCheckPermissions(), 'permissions' => $this->handleCheckPermissions(),
@ -85,21 +115,21 @@ class BindAPI
function handleCheckPermissions() function handleCheckPermissions()
{ {
$test = fgets(STDIN); $test = fgets(stream: STDIN);
echo "received: $test" . PHP_EOL; echo "received: $test" . PHP_EOL;
} }
function runCommand() function runCommand()
{ {
if ($this->argc < 2) { if ($this->argumentsCount < 1) {
$this->showUsage(); $this->showUsage();
exit(0); exit(0);
} }
if (str_contains(haystack: $this->argv[1], needle: ':')) { if (str_contains(haystack: $this->arguments[0], needle: ':')) {
[$command, $subcommand] = explode(separator: ':', string: $this->argv[1]); [$command, $subcommand] = explode(separator: ':', string: $this->arguments[0]);
} else { } else {
$command = $this->argv[1]; $command = $this->arguments[0];
$subcommand = ''; $subcommand = '';
} }
@ -123,31 +153,38 @@ class BindAPI
function showUsage(): void function showUsage(): void
{ {
echo 'Usage' . PHP_EOL; echo 'Usage' . PHP_EOL;
echo "\033[33mcheck\t\t\033[39mhealth checks the system can perform" . PHP_EOL; echo COLOR_YELLOW . "check" . COLOR_DEFAULT . "\t health checks the system can perform" . PHP_EOL;
echo "\033[32m\tcheck:permissions" . PHP_EOL; echo COLOR_GREEN . "\t check:permissions" . PHP_EOL;
echo "\033[32m\tcheck:panel {ID}" . PHP_EOL; echo COLOR_GREEN . "\t check:panels {ID}" . PHP_EOL;
echo "\033[32m\tcheck:domains {ID}" . PHP_EOL; echo COLOR_GREEN . "\t check:domains {ID}" . PHP_EOL;
echo "\033[33mpanels\t\033[39mall Keyhelp systems configured" . PHP_EOL;
echo "\033[32m\tpanels:list" . PHP_EOL; echo COLOR_YELLOW . "panels" . COLOR_DEFAULT . "\t all Keyhelp systems configured" . PHP_EOL;
echo "\033[32m\tpanels:apiping {<ID>}" . PHP_EOL; echo COLOR_GREEN . "\t panels:list" . PHP_EOL;
echo "\033[32m\tpanels:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL; echo COLOR_GREEN . "\t panels:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
echo "\033[32m\tpanels:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL; echo COLOR_GREEN . "\t panels:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
echo "\033[32m\tpanels:delete" . PHP_EOL; echo COLOR_GREEN . "\t panels:delete" . PHP_EOL;
echo "\033[33mapikeys\t\033[39mAPI keys for other nameservers" . PHP_EOL; echo COLOR_GREEN . "\t panels:apiping {<ID>}" . PHP_EOL;
echo "\033[32m\tapikeys:list" . PHP_EOL;
echo "\033[32m\tapikeys:create" . PHP_EOL; echo COLOR_YELLOW . "nameservers" . COLOR_DEFAULT . " available nameservers" . PHP_EOL;
echo "\033[32m\tapikeys:delete <ID>" . PHP_EOL; echo COLOR_GREEN . "\t nameservers:list" . PHP_EOL;
echo "\033[33mnameservers\t\033[39mother nameservers" . PHP_EOL; echo COLOR_GREEN . "\t nameservers:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
echo "\033[32m\tnameservers:list" . PHP_EOL; echo COLOR_GREEN . "\t nameservers:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
echo "\033[32m\tnameservers:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL; echo COLOR_GREEN . "\t nameservers:delete <ID>" . PHP_EOL;
echo "\033[32m\tnameservers:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL; echo COLOR_GREEN . "\t nameservers:apiping {<ID>}" . PHP_EOL;
echo "\033[32m\tnameservers:delete <ID>" . PHP_EOL;
echo "\033[33mdomains\t\033[39mdomains this server is responsible for" . PHP_EOL; echo COLOR_YELLOW . "domains" . COLOR_DEFAULT . " domains this server is responsible for" . PHP_EOL;
echo "\033[32m\tdomains:list" . PHP_EOL; echo COLOR_GREEN . "\t domains:list" . PHP_EOL;
echo "\033[32m\tdomains:create <name> {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL; echo COLOR_GREEN . "\t domains:create <name> {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
echo "\033[32m\tdomains:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL; echo COLOR_GREEN . "\t domains:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
echo "\033[32m\tdomains:delete <ID>" . PHP_EOL; echo COLOR_GREEN . "\t domains:delete <ID>" . PHP_EOL;
echo PHP_EOL . "\033[39me.g. ./bin/console apikey:list" . PHP_EOL;
echo COLOR_YELLOW . "apikeys" . COLOR_DEFAULT . "\t API keys for other nameservers" . PHP_EOL;
echo COLOR_GREEN . "\t apikeys:list" . PHP_EOL;
echo COLOR_GREEN . "\t apikeys:create" . PHP_EOL;
echo COLOR_GREEN . "\t apikeys:update <ID>" . PHP_EOL;
echo COLOR_GREEN . "\t apikeys:delete <ID>" . PHP_EOL;
echo PHP_EOL . "\033[39me.g. ./bin/console apikeys:list" . PHP_EOL;
} }
@ -195,21 +232,34 @@ class BindAPI
function handlePanelsAPIPing() function handlePanelsAPIPing()
{ {
$error = false; $error = false;
$id = $this->argv[2] ?? 0;
$id = $this->arguments[1] ?? 0;
if ($id != 0) { if ($id != 0) {
$panel = $this->panelController->findByID($id); if ($panel = $this->panelController->findByID($id)) {
$this->checkPing($panel); if (!$this->checkPing($panel)) {
$error = true;
}
} else {
if ($this->config['verbose']) {
echo 'Unknown panel ID: $id' . PHP_EOL;
}
$error = true;
}
} else { } else {
$panels = $this->panelController->findAll(); $panels = $this->panelController->findAll();
foreach ($panels as $panel) { foreach ($panels as $panel) {
$this->checkPing(panel: $panel); if (!$this->checkPing(panel: $panel)) {
$error = true;
}
} }
} }
echo PHP_EOL;
if ($error) {
exit(1);
print(PHP_EOL); } else {
exit(0);
}
} }
@ -218,7 +268,7 @@ class BindAPI
*/ */
function handlePanelsCreate(): void function handlePanelsCreate(): void
{ {
$name = $this->argv[2] ?? ""; $name = $this->arguments[0] ?? '';
if (empty($name)) { if (empty($name)) {
echo 'You need to supply the panel name.' . PHP_EOL; echo 'You need to supply the panel name.' . PHP_EOL;
exit(1); exit(1);
@ -240,7 +290,7 @@ class BindAPI
echo 'At least one IP address is required.' . PHP_EOL; echo 'At least one IP address is required.' . PHP_EOL;
exit(0); exit(0);
} }
$apikey = $argiments['apikey'] ?? ''; $apikey = $arguments['apikey'] ?? '';
if ($this->panelController->findByName($name)) { if ($this->panelController->findByName($name)) {
echo "Panel: $name already exists." . PHP_EOL; echo "Panel: $name already exists." . PHP_EOL;
@ -258,7 +308,7 @@ class BindAPI
*/ */
function handleNameserversCreate(): void function handleNameserversCreate(): void
{ {
$name = $this->argv[2] ?? ''; $name = $this->arguments[1] ?? '';
if (empty($name)) { if (empty($name)) {
echo 'You need to supply the nameserver name.' . PHP_EOL; echo 'You need to supply the nameserver name.' . PHP_EOL;
exit(1); exit(1);
@ -299,7 +349,7 @@ class BindAPI
public function parseArguments(): array public function parseArguments(): array
{ {
$arguments = []; $arguments = [];
foreach ($this->argv as $argument) { foreach ($this->arguments as $argument) {
if (str_contains(haystack: $argument, needle: '=')) { if (str_contains(haystack: $argument, needle: '=')) {
[$key, $value] = explode(separator: '=', string: $argument); [$key, $value] = explode(separator: '=', string: $argument);
$arguments[strtolower($key)] = $value; $arguments[strtolower($key)] = $value;
@ -335,7 +385,7 @@ class BindAPI
{ {
$arguments = $this->parseArguments(); $arguments = $this->parseArguments();
$id = $this->argv[2] ?? 0; $id = $this->arguments[1] ?? 0;
$name = $arguments['name'] ?? ''; $name = $arguments['name'] ?? '';
$a = $arguments['a'] ?? ''; $a = $arguments['a'] ?? '';
$aaaa = $arguments['aaaa'] ?? ''; $aaaa = $arguments['aaaa'] ?? '';
@ -358,12 +408,12 @@ class BindAPI
function handlePanelsDelete() function handlePanelsDelete()
{ {
if (empty($this->argv[2])) { if (empty($this->arguments[1])) {
echo "You need to supply an ID." . PHP_EOL; echo "You need to supply an ID." . PHP_EOL;
exit(1); exit(1);
} }
$id = intval($this->argv[2]) ?? 0; $id = intval($this->arguments[1]) ?? 0;
if ($id == 0) { if ($id == 0) {
echo "Panel with ID $id not found." . PHP_EOL; echo "Panel with ID $id not found." . PHP_EOL;
exit(1); exit(1);
@ -414,9 +464,9 @@ class BindAPI
$keys = $this->apiUsers->findAll(); $keys = $this->apiUsers->findAll();
if ($keys) { if ($keys) {
$table = new ConsoleTable(); $table = new ConsoleTable();
$table->setHeaders(['ID', 'API key prefix']); $table->setHeaders(['ID', 'Name', 'API key prefix']);
foreach ($keys as $key) { foreach ($keys as $key) {
$table->addRow([$key['id'], $key['api_token_prefix']]); $table->addRow([$key['id'], $key['name'], $key['api_token_prefix']]);
} }
$table->setPadding(value: 2); $table->setPadding(value: 2);
$table->display(); $table->display();
@ -431,7 +481,7 @@ class BindAPI
*/ */
function handleApikeysDelete(): void function handleApikeysDelete(): void
{ {
$id = intval($this->argv[2]) ?? 0; $id = intval($this->arguments[1]) ?? 0;
if ($id == 0) { if ($id == 0) {
echo 'You need to add the ID of the API key.' . PHP_EOL; echo 'You need to add the ID of the API key.' . PHP_EOL;
exit(1); exit(1);
@ -471,7 +521,7 @@ class BindAPI
*/ */
function handleNameserversList(): void function handleNameserversList(): void
{ {
echo 'All available nameserver:' . PHP_EOL; echo 'All available nameservers:' . PHP_EOL;
$domains = $this->nameserverController->findAll(); $domains = $this->nameserverController->findAll();
if ($domains) { if ($domains) {
$table = new ConsoleTable(); $table = new ConsoleTable();
@ -516,7 +566,7 @@ class BindAPI
*/ */
function handleDomainsCreate(): void function handleDomainsCreate(): void
{ {
$name = $this->argv[2] ?? ""; $name = $this->arguments[1] ?? "";
if (empty($name)) { if (empty($name)) {
echo 'You need to supply the domain name.' . PHP_EOL; echo 'You need to supply the domain name.' . PHP_EOL;
exit(1); exit(1);
@ -553,7 +603,7 @@ class BindAPI
{ {
$arguments = $this->parseArguments(); $arguments = $this->parseArguments();
$id = $this->argv[2] ?? 0; $id = $this->arguments[1] ?? 0;
$name = $arguments['name'] ?? ''; $name = $arguments['name'] ?? '';
$a = $arguments['a'] ?? ''; $a = $arguments['a'] ?? '';
$aaaa = $arguments['aaaa'] ?? ''; $aaaa = $arguments['aaaa'] ?? '';
@ -579,7 +629,7 @@ class BindAPI
{ {
$arguments = $this->parseArguments(); $arguments = $this->parseArguments();
$id = $this->argv[2] ?? 0; $id = $this->arguments[1] ?? 0;
$name = $arguments['name'] ?? ''; $name = $arguments['name'] ?? '';
$a = $arguments['a'] ?? ''; $a = $arguments['a'] ?? '';
$aaaa = $arguments['aaaa'] ?? ''; $aaaa = $arguments['aaaa'] ?? '';
@ -602,12 +652,12 @@ class BindAPI
function handleNameserversDelete() function handleNameserversDelete()
{ {
if (empty($this->argv[2])) { if (empty($this->arguments[1])) {
echo "You need to supply an ID." . PHP_EOL; echo "You need to supply an ID." . PHP_EOL;
exit(1); exit(1);
} }
$id = intval($this->argv[2]) ?? 0; $id = intval($this->arguments[1]) ?? 0;
if ($id == 0) { if ($id == 0) {
echo "Nameserver with ID $id not found." . PHP_EOL; echo "Nameserver with ID $id not found." . PHP_EOL;
exit(1); exit(1);
@ -623,12 +673,12 @@ class BindAPI
function handleDomainsDelete() function handleDomainsDelete()
{ {
if (empty($this->argv[2])) { if (empty($this->arguments[1])) {
echo "You need to supply an ID." . PHP_EOL; echo "You need to supply an ID." . PHP_EOL;
exit(1); exit(1);
} }
$id = intval($this->argv[2]) ?? 0; $id = intval($this->arguments[1]) ?? 0;
if ($id == 0) { if ($id == 0) {
echo "Domain with ID $id not found." . PHP_EOL; echo "Domain with ID $id not found." . PHP_EOL;
exit(1); exit(1);

View File

@ -15,15 +15,14 @@ class CheckController
* @param String $apiKey * @param String $apiKey
* @param String $command * @param String $command
* *
* @return bool|array * @return String
*/ */
function sendCommand(String $serverName, int $versionIP, String $apiKey, String $command) : Bool|Array function sendCommand(String $serverName, int $versionIP, String $apiKey, String $command): String
{ {
$result = false;
$curl = curl_init(); $curl = curl_init();
curl_setopt($curl, option: CURLOPT_URL, value: "https://$serverName/api/v2/" . $command); curl_setopt($curl, option: CURLOPT_URL, value: "https://$serverName/api/v2/" . $command);
curl_setopt($curl, option: CURLOPT_RETURNTRANSFER, value: 1); curl_setopt($curl, option: CURLOPT_RETURNTRANSFER, value: 1);
curl_setopt($curl, option: CURLOPT_TIMEOUT_MS, value: 2000); curl_setopt($curl, option: CURLOPT_TIMEOUT_MS, value: 1000);
if ($versionIP == 4) { if ($versionIP == 4) {
curl_setopt($curl, option: CURLOPT_IPRESOLVE, value: CURL_IPRESOLVE_V4); curl_setopt($curl, option: CURLOPT_IPRESOLVE, value: CURL_IPRESOLVE_V4);
@ -41,26 +40,23 @@ class CheckController
$apiResult = json_decode($resultJSON); $apiResult = json_decode($resultJSON);
if ($command == "ping" ) { if ($command == "ping" ) {
if ($apiResult->response == "pong") { if ($apiResult->response == "pong") {
$result = true; $result = $apiResult->response;
} else { } else {
print("Error: $httpResponse" . PHP_EOL); $result = $resultJSON;
} }
} else { } else {
$result = $apiResult; $result = $resultJSON;
} }
break; break;
case 401: case 401:
print("Missing or wrong API Key" . PHP_EOL); $result = 'Missing or wrong API Key';
break; break;
default: default:
print("Unhandled error: " . $httpResponse . PHP_EOL); $result = 'Unhandled error: ' . $httpResponse;
} }
} else { } else {
$error = curl_error($curl); $result = curl_error($curl);
print("Unknown error: $error" . PHP_EOL);
} }
curl_close($curl); curl_close($curl);
return $result; return $result;
} }

View File

@ -12,6 +12,12 @@ class DatabaseConnection
{ {
private PDO $dbConnection; private PDO $dbConnection;
const TABLE_PREFIX = '';
const TABLE_DOMAINS = self::TABLE_PREFIX . "domains";
const TABLE_NAMESERVERS = self::TABLE_PREFIX . "nameservers";
const TABLE_PANELS = self::TABLE_PREFIX . "panels";
const TABLE_USER = self::TABLE_PREFIX . "apikeys";
public function __construct(private array $config) public function __construct(private array $config)
{ {
extract($this->config); extract($this->config);
@ -22,8 +28,72 @@ class DatabaseConnection
username: $dbUser, username: $dbUser,
password: $dbPassword password: $dbPassword
); );
$sql = "SHOW TABLES";
$statement = $this->dbConnection->prepare($sql);
if (!$statement->execute()) {
echo 'Error: Cannot find tables.' . PHP_EOL;
if (confirm('Should I try to create them?')) {
$sql = "
CREATE TABLE `apikeys` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`api_token_prefix` varchar(13) COLLATE utf8mb4_unicode_ci NOT NULL,
`api_token` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci";
$statement = $this->dbConnection->prepare($sql);
$statement->execute();
$sql = "
CREATE TABLE `domains` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
`a` varbinary(255) DEFAULT NULL,
`aaaa` varbinary(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=20 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci";
$statement = $this->dbConnection->prepare($sql);
$statement->execute();
$sql = "
CREATE TABLE `nameservers` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
`a` varbinary(255) DEFAULT NULL,
`aaaa` varbinary(255) DEFAULT NULL,
`apikey` varbinary(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=24 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci";
$statement = $this->dbConnection->prepare($sql);
$statement->execute();
$sql = "
CREATE TABLE `panels` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
`a` varbinary(255) DEFAULT NULL,
`aaaa` varbinary(255) DEFAULT NULL,
`apikey` varbinary(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=28 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci";
$statement = $this->dbConnection->prepare($sql);
$statement->execute();
echo 'Tables have been created.' . PHP_EOL;
}
exit(1);
}
} catch (PDOException $exception) { } catch (PDOException $exception) {
exit($exception->getMessage()); echo $exception->getMessage() . PHP_EOL;
echo 'Did you create the database and adjust the config file?' . PHP_EOL;
echo PHP_EOL . 'You can create database an user via a panel or manually in mysql shell:' . PHP_EOL;
echo 'CREATE DATABASE databasename;' . PHP_EOL;
echo "CREATE USER 'user'@'localhost' IDENTIFIED BY 'secret';" . PHP_EOL;
echo "GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, INDEX, DROP, ALTER, CREATE TEMPORARY TABLES, LOCK TABLES ON databasename.* TO 'user'@'localhost';" . PHP_EOL;
echo 'There is no need to run FLUSH PRIVILEGES when using GRANT!' . PHP_EOL;
exit(1);
} }
} }

View File

@ -15,7 +15,7 @@ class DomainController
private String $namedConfLocalFile; private String $namedConfLocalFile;
private string $zoneCachePath; private string $zoneCachePath;
public function __construct(private PDO $dbConnection) public function __construct(private DatabaseConnection $databaseConnection)
{ {
$this->localZoneFile = '/etc/bind/local.zones'; $this->localZoneFile = '/etc/bind/local.zones';
$this->localZonesDir = '/etc/bind/zones/'; $this->localZonesDir = '/etc/bind/zones/';
@ -31,10 +31,10 @@ class DomainController
{ {
$statement = " $statement = "
SELECT id, name, a, aaaa SELECT id, name, a, aaaa
FROM domains"; FROM " . DatabaseConnection::TABLE_DOMAINS;
try { try {
$statement = $this->dbConnection->query($statement); $statement = $this->databaseConnection->getConnection()->query($statement);
return $statement->fetchAll(mode: PDO::FETCH_ASSOC); return $statement->fetchAll(mode: PDO::FETCH_ASSOC);
} catch (PDOException $e) { } catch (PDOException $e) {
exit($e->getMessage()); exit($e->getMessage());
@ -51,11 +51,11 @@ class DomainController
{ {
$sql = " $sql = "
SELECT id, name, a, aaaa SELECT id, name, a, aaaa
FROM domains FROM " . DatabaseConnection::TABLE_DOMAINS . "
WHERE name = :name"; WHERE name = :name";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':name', var: $name); $statement->bindParam(param: ':name', var: $name);
$statement->execute(); $statement->execute();
return $statement->fetch(PDO::FETCH_ASSOC); return $statement->fetch(PDO::FETCH_ASSOC);
@ -74,11 +74,11 @@ class DomainController
{ {
$sql = " $sql = "
SELECT id, name, a, aaaa SELECT id, name, a, aaaa
FROM domains FROM . " . DatabaseConnection::TABLE_DOMAINS . "
WHERE id = :id"; WHERE id = :id";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param:':id', var: $id); $statement->bindParam(param:':id', var: $id);
$statement->execute(); $statement->execute();
return $statement->fetch(PDO::FETCH_ASSOC); return $statement->fetch(PDO::FETCH_ASSOC);
@ -99,11 +99,11 @@ class DomainController
{ {
// TODO create zone file and include // TODO create zone file and include
$sql = " $sql = "
INSERT INTO domains (name, a, aaaa) INSERT INTO " . DatabaseConnection::TABLE_DOMAINS . " (name, a, aaaa)
VALUES (:name, :a, :aaaa)"; VALUES (:name, :a, :aaaa)";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':name', var: $name); $statement->bindParam(param: ':name', var: $name);
$statement->bindParam(param: ':a', var: $a); $statement->bindParam(param: ':a', var: $a);
$statement->bindParam(param: ':aaaa', var: $aaaa); $statement->bindParam(param: ':aaaa', var: $aaaa);
@ -121,7 +121,7 @@ class DomainController
exit(1); exit(1);
} }
return $this->dbConnection->lastInsertId(); return $this->databaseConnection->getConnection()->lastInsertId();
} catch (PDOException $e) { } catch (PDOException $e) {
exit($e->getMessage()); exit($e->getMessage());
} }
@ -135,9 +135,9 @@ class DomainController
* @param String $a * @param String $a
* @param String $aaaa * @param String $aaaa
* *
* @return int|void * @return false|int
*/ */
public function update(Int $id, String $name, String $a, String $aaaa) public function update(Int $id, String $name, String $a, String $aaaa): bool|int
{ {
$current = $this->findByID($id); $current = $this->findByID($id);
@ -162,14 +162,14 @@ class DomainController
} }
$sql = " $sql = "
UPDATE domains SET UPDATE " . DatabaseConnection::TABLE_DOMAINS . " SET
name = :name, name = :name,
a = :a, a = :a,
aaaa = :aaaa aaaa = :aaaa
WHERE id = :id"; WHERE id = :id";
try { try {
$statement = $this->dbConnection->prepare($sql); $statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: 'id', var: $id); $statement->bindParam(param: 'id', var: $id);
$statement->bindParam(param: 'name', var: $name); $statement->bindParam(param: 'name', var: $name);
$statement->bindParam(param: 'a', var: $a); $statement->bindParam(param: 'a', var: $a);
@ -178,7 +178,7 @@ class DomainController
// recreate zonefile // recreate zonefile
$this->createZoneFile(name: $name, a: $a, aaaa: $aaaa); $this->createZoneFile(name: $name, a: $a, aaaa: $aaaa);
exec('/usr/sbin/rndc reload'); exec(command: '/usr/sbin/rndc reload');
return $statement->rowCount(); return $statement->rowCount();
} catch (PDOException $e) { } catch (PDOException $e) {
@ -197,11 +197,11 @@ class DomainController
{ {
// TODO delete zone file and include // TODO delete zone file and include
$statement = " $statement = "
DELETE FROM domains DELETE FROM " . DatabaseConnection::TABLE_DOMAINS . "
WHERE id = :id"; WHERE id = :id";
try { try {
$statement = $this->dbConnection->prepare($statement); $statement = $this->databaseConnection->getConnection()->prepare($statement);
$statement->bindParam(param: 'id', var: $id); $statement->bindParam(param: 'id', var: $id);
$statement->execute(); $statement->execute();
return $statement->rowCount(); return $statement->rowCount();
@ -251,6 +251,7 @@ class DomainController
} }
} }
/** /**
* @param mixed $name * @param mixed $name
* @param mixed $a * @param mixed $a

View File

@ -0,0 +1,181 @@
<?php
namespace App\Controller;
use PDO;
use PDOException;
/**
*
*/
class NameserverController
{
public function __construct(private DatabaseConnection $databaseConnection)
{}
/**
* @return array|false
*/
public function findAll(): bool|array
{
$statement = "
SELECT id, name, a, aaaa, apikey
FROM " . DatabaseConnection::TABLE_NAMESERVERS;
try {
$statement = $this->databaseConnection->getConnection()->query($statement);
return $statement->fetchAll(mode: PDO::FETCH_ASSOC);
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param String $name
*
* @return array|false
*/
public function findByName(String $name): bool|array
{
$sql = "
SELECT id, name, a, aaaa, apikey
FROM " . DatabaseConnection::TABLE_NAMESERVERS . "
WHERE name = :name";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':name', var: $name);
$statement->execute();
return $statement->fetch(PDO::FETCH_ASSOC);
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param Int $id
*
* @return array|false
*/
public function findByID(Int $id): bool|array
{
$sql = "
SELECT id, name, a, aaaa, apikey
FROM " . DatabaseConnection::TABLE_NAMESERVERS . "
WHERE id = :id";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param:':id', var: $id);
$statement->execute();
return $statement->fetch(PDO::FETCH_ASSOC);
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param String $name
* @param String $a
* @param String $aaaa
* @param String $apikey
*
* @return int
*/
public function insert(String $name, String $a, String $aaaa, String $apikey): int
{
$sql = "
INSERT INTO " . DatabaseConnection::TABLE_NAMESERVERS . " (name, a, aaaa, apikey)
VALUES (:name, :a, :aaaa, :apikey)";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':name', var: $name);
$statement->bindParam(param: ':a', var: $a);
$statement->bindParam(param: ':aaaa', var: $aaaa);
$statement->bindParam(param: ':apikey', var: $apikey);
$statement->execute();
return $this->databaseConnection->getConnection()->lastInsertId();
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param Int $id
* @param String $name
* @param String $a
* @param String $aaaa
* @param String $apikey
*
* @return false|int
*/
public function update(Int $id, String $name, String $a, String $aaaa, String $apikey): bool|int
{
$current = $this->findByID($id);
if (empty($name)) {
$name = $current['name'] ?? '';
}
if (empty($a)) {
$a = $current['a'] ?? '';
}
if (empty($aaaa)) {
$aaaa = $current['aaaa'] ?? '';
}
if (empty($apikey)) {
$apikey = $current['apikey'] ?? '';
}
$sql = "
UPDATE " . DatabaseConnection::TABLE_NAMESERVERS . " SET
name = :name,
a = :a,
aaaa = :aaaa,
apikey = :apikey
WHERE id = :id";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: 'id', var: $id);
$statement->bindParam(param: 'name', var: $name);
$statement->bindParam(param: 'a', var: $a);
$statement->bindParam(param: 'aaaa', var: $aaaa);
$statement->bindParam(param: 'apikey', var: $apikey);
$statement->execute();
return $statement->rowCount();
} catch (PDOException $e) {
print($e->getMessage());
return false;
}
}
/**
* @param $id
*
* @return int
*/
public function delete($id): int
{
$statement = "
DELETE FROM " . DatabaseConnection::TABLE_NAMESERVERS . "
WHERE id = :id";
try {
$statement = $this->databaseConnection->getConnection()->prepare($statement);
$statement->bindParam(param: 'id', var: $id);
$statement->execute();
return $statement->rowCount();
} catch (PDOException $e) {
exit($e->getMessage());
}
}
}

View File

@ -0,0 +1,204 @@
<?php
namespace App\Controller;
use PDO;
use PDOException;
/**
*
*/
class PanelController
{
public function __construct(private DatabaseConnection $databaseConnection)
{}
/**
* @return array|false
*/
public function findAll(): bool|array
{
$statement = "
SELECT id, name, a, aaaa, apikey
FROM " . DatabaseConnection::TABLE_PANELS;
try {
$statement = $this->databaseConnection->getConnection()->query($statement);
return $statement->fetchAll(mode: PDO::FETCH_ASSOC);
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param String $name
*
* @return array|false
*/
public function findByName(String $name): bool|array
{
$sql = "
SELECT id, name, a, aaaa, apikey
FROM " . DatabaseConnection::TABLE_PANELS . "
WHERE name = :name";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':name', var: $name);
$statement->execute();
return $statement->fetch(PDO::FETCH_ASSOC);
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param Int $id
*
* @return array|false
*/
public function findByID(Int $id): bool|array
{
$sql = "
SELECT id, name, a, aaaa, apikey
FROM ". DatabaseConnection::TABLE_PANELS . "
WHERE id = :id";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param:':id', var: $id);
$statement->execute();
return $statement->fetch(mode: PDO::FETCH_ASSOC);
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param String $name
* @param String $a
* @param String $aaaa
* @param String $apikey
*
* @return int
*/
public function insert(String $name, String $a, String $aaaa, String $apikey): int
{
$sql = "
INSERT INTO " . DatabaseConnection::TABLE_PANELS . " (name, a, aaaa, apikey)
VALUES (:name, :a, :aaaa, :apikey)";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: ':name', var: $name);
$statement->bindParam(param: ':a', var: $a);
$statement->bindParam(param: ':aaaa', var: $aaaa);
$statement->bindParam(param: ':apikey', var: $apikey);
$statement->execute();
return $this->databaseConnection->getConnection()->lastInsertId();
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param Int $id
* @param String $name
* @param String $a
* @param String $aaaa
* @param String $apikey
*
* @return false|int
*/
public function update(Int $id, String $name, String $a, String $aaaa, String $apikey): bool|int
{
$current = $this->findByID($id);
if (empty($name)) {
$name = $current['name'];
}
if (empty($a)) {
$a = $current['a'] ?? '';
}
if (empty($aaaa)) {
$aaaa = $current['aaaa'] ?? '';
}
if (empty($apikey)) {
$apikey = $current['apikey'] ?? '';
}
$sql = "
UPDATE " . DatabaseConnection::TABLE_PANELS . " SET
name = :name,
a = :a,
aaaa = :aaaa,
apikey = :apikey
WHERE id = :id";
try {
$statement = $this->databaseConnection->getConnection()->prepare($sql);
$statement->bindParam(param: 'id', var: $id);
$statement->bindParam(param: 'name', var: $name);
$statement->bindParam(param: 'a', var: $a);
$statement->bindParam(param: 'aaaa', var: $aaaa);
$statement->bindParam(param: 'apikey', var: $apikey);
$statement->execute();
return $statement->rowCount();
} catch (PDOException $e) {
print($e->getMessage());
return false;
}
}
/**
* @param $id
*
* @return int
*/
public function delete($id): int
{
$statement = "
DELETE FROM " . DatabaseConnection::TABLE_PANELS . "
WHERE id = :id";
try {
$statement = $this->databaseConnection->getConnection()->prepare($statement);
$statement->bindParam(param: 'id', var: $id);
$statement->execute();
return $statement->rowCount();
} catch (PDOException $e) {
exit($e->getMessage());
}
}
/**
* @param $id
*
* @return int
*/
public function getLongestEntry(String $field): int
{
$statement = "
SELECT MAX(LENGTH(" . $field . ")) as length FROM " . DatabaseConnection::TABLE_PANELS;
try {
$statement = $this->databaseConnection->getConnection()->prepare($statement);
$statement->execute();
$result = $statement->fetch();
return $result['length'];
} catch (PDOException $e) {
exit($e->getMessage());
}
}
}

View File

@ -2,7 +2,6 @@
namespace App\Controller; namespace App\Controller;
use PDO;
use UnhandledMatchError; use UnhandledMatchError;
/** /**
@ -16,14 +15,14 @@ class RequestController
private String $message; private String $message;
/** /**
* @param \PDO $dbConnection * @param \App\Controller\DatabaseConnection $databaseConnection
* @param String $requestMethod * @param String $requestMethod
* @param array $uri * @param array $uri
*/ */
public function __construct(private PDO $dbConnection, private String $requestMethod, private array $uri) public function __construct(private DatabaseConnection $databaseConnection, private String $requestMethod, private array $uri)
{ {
$this->requestMethod = strtoupper($requestMethod); $this->requestMethod = strtoupper($requestMethod);
$this->domainController = new DomainController($dbConnection); $this->domainController = new DomainController($this->databaseConnection);
} }
@ -76,7 +75,7 @@ class RequestController
return false; return false;
} else { } else {
[$prefix,] = explode('.', $apiKey); [$prefix,] = explode('.', $apiKey);
$apiUsers = new ApiUsers($this->dbConnection); $apiUsers = new ApiKeys($this->databaseConnection);
$apiResult = $apiUsers->findByPrefix($prefix); $apiResult = $apiUsers->findByPrefix($prefix);
$storedHash = $apiResult['api_token']; $storedHash = $apiResult['api_token'];