Compare commits
No commits in common. "69659bb33f53f11bc1fea8397568f19ffbe6502b" and "657eeb0496ac19755ff97c1263979b6315c69d1e" have entirely different histories.
69659bb33f
...
657eeb0496
|
@ -4,108 +4,15 @@ if (php_sapi_name() !== 'cli') {
|
|||
exit;
|
||||
}
|
||||
|
||||
// version, store that somewhere else
|
||||
$version = '0.0.1';
|
||||
|
||||
|
||||
require dirname(path: __DIR__) . '/vendor/autoload.php';
|
||||
|
||||
use App\Controller\BindAPI;
|
||||
|
||||
$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);
|
||||
$config = json_decode($configJSON, associative: true);
|
||||
|
||||
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 = new BindAPI(config: $config, argc: $argc, argv: $argv);
|
||||
$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;
|
||||
}
|
||||
|
||||
|
|
|
@ -3,5 +3,5 @@
|
|||
"dbPort": 3306,
|
||||
"dbDatabase": "sampledb",
|
||||
"dbUser": "sampleuser",
|
||||
"dbPassword": "secret",
|
||||
"dbPassword": "secret"
|
||||
}
|
|
@ -9,9 +9,9 @@ use PDOException;
|
|||
/**
|
||||
*
|
||||
*/
|
||||
class ApiKeys
|
||||
class ApiUsers
|
||||
{
|
||||
public function __construct(private DatabaseConnection $databaseConnection)
|
||||
public function __construct(private PDO $dbConnection)
|
||||
{}
|
||||
|
||||
|
||||
|
@ -21,11 +21,11 @@ class ApiKeys
|
|||
public function findAll(): bool|array
|
||||
{
|
||||
$sql = "
|
||||
SELECT id, name, api_token_prefix, api_token
|
||||
FROM " . DatabaseConnection::TABLE_USER;
|
||||
SELECT id, api_token_prefix, api_token
|
||||
FROM user";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->query($sql);
|
||||
$statement = $this->dbConnection->query($sql);
|
||||
return $statement->fetchAll(mode: PDO::FETCH_ASSOC);
|
||||
} catch (PDOException $e) {
|
||||
exit($e->getMessage());
|
||||
|
@ -41,13 +41,13 @@ class ApiKeys
|
|||
public function findByID(Int $id): bool|array
|
||||
{
|
||||
$sql = "
|
||||
SELECT name, api_token_prefix, api_token
|
||||
FROM " . DatabaseConnection::TABLE_USER . "
|
||||
SELECT api_token_prefix, api_token
|
||||
FROM user
|
||||
WHERE id = :id;
|
||||
";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param: ':id', var: $id);
|
||||
$statement->execute();
|
||||
return $statement->fetch(mode: PDO::FETCH_ASSOC);
|
||||
|
@ -65,12 +65,12 @@ class ApiKeys
|
|||
public function findByPrefix(String $prefix): bool|array
|
||||
{
|
||||
$sql = "
|
||||
SELECT name, api_token
|
||||
FROM " . DatabaseConnection::TABLE_USER . "
|
||||
SELECT api_token
|
||||
FROM user
|
||||
WHERE api_token_prefix = :prefix";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param: ':prefix', var: $prefix);
|
||||
$statement->execute();
|
||||
return $statement->fetch(mode: PDO::FETCH_ASSOC);
|
||||
|
@ -83,7 +83,7 @@ class ApiKeys
|
|||
/**
|
||||
* @return array|void
|
||||
*/
|
||||
public function create(String $name = '')
|
||||
public function create()
|
||||
{
|
||||
$tokenPrefix = uniqid();
|
||||
$result['tokenPrefix'] = $tokenPrefix;
|
||||
|
@ -97,17 +97,15 @@ class ApiKeys
|
|||
$token = password_hash(password: $tokenPrefix . '.' . $key, algo: PASSWORD_ARGON2ID);
|
||||
|
||||
$sql = "
|
||||
INSERT INTO " . DatabaseConnection::TABLE_USER . " (name, api_token_prefix, api_token)
|
||||
INSERT INTO user (api_token_prefix, api_token)
|
||||
VALUES (:token_prefix, :token)";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param: ':token_prefix', var: $tokenPrefix);
|
||||
$statement->bindParam(param: ':token', var: $token);
|
||||
$statement->bindParam(param: ':name', var: $name);
|
||||
|
||||
$statement->execute();
|
||||
$result['row'] = $this->databaseConnection->getConnection()->lastInsertId();
|
||||
$result['row'] = $this->dbConnection->lastInsertId();
|
||||
return $result;
|
||||
} catch (PDOException $e) {
|
||||
exit($e->getMessage());
|
||||
|
@ -123,11 +121,11 @@ class ApiKeys
|
|||
public function delete($id): int
|
||||
{
|
||||
$sql = "
|
||||
DELETE FROM " . DatabaseConnection::TABLE_USER . "
|
||||
DELETE FROM user
|
||||
WHERE id = :id";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param: 'id', var: $id);
|
||||
$statement->execute();
|
||||
return $statement->rowCount();
|
|
@ -2,19 +2,21 @@
|
|||
|
||||
namespace App\Controller;
|
||||
|
||||
define('COLOR_RED', "\033[31m");
|
||||
define('COLOR_GREEN', "\033[32m");
|
||||
define('COLOR_YELLOW', "\033[33m");
|
||||
define('COLOR_GREEN', "\033[32m");
|
||||
define('COLOR_DEFAULT', "\033[39m");
|
||||
|
||||
// TODO add to all Controllers
|
||||
error_reporting(error_level: E_ALL);
|
||||
error_reporting(E_ALL);
|
||||
|
||||
// 61e6ce5dd8a1b.bc1c314ce364f6878084c254fe4c6345801c43a49bb8eb71
|
||||
|
||||
|
||||
use LucidFrame\Console\ConsoleTable;
|
||||
use PDO;
|
||||
use UnhandledMatchError;
|
||||
|
||||
|
||||
if (php_sapi_name() !== 'cli') {
|
||||
exit;
|
||||
}
|
||||
|
@ -24,86 +26,54 @@ if (php_sapi_name() !== 'cli') {
|
|||
*/
|
||||
class BindAPI
|
||||
{
|
||||
private DatabaseConnection $databaseConnection;
|
||||
private ApiKeys $apiUsers;
|
||||
private PDO $dbConnection;
|
||||
private ApiUsers $apiUsers;
|
||||
private DomainController $domainController;
|
||||
private PanelController $panelController;
|
||||
private NameserverController $nameserverController;
|
||||
private CheckController $checkController;
|
||||
|
||||
|
||||
public function __construct(private array $config, private int $argumentsCount, private array $arguments)
|
||||
public function __construct(private array $config, private int $argc, private array $argv)
|
||||
{
|
||||
$this->databaseConnection = new DatabaseConnection(config: $this->config);
|
||||
$this->panelController = new PanelController($this->databaseConnection);
|
||||
$this->apiUsers = new ApiKeys($this->databaseConnection);
|
||||
$this->domainController = new DomainController($this->databaseConnection);
|
||||
$this->nameserverController = new NameserverController($this->databaseConnection);
|
||||
$this->dbConnection = (new DatabaseConnection(config: $this->config))->getConnection();
|
||||
$this->panelController = new PanelController($this->dbConnection);
|
||||
$this->apiUsers = new ApiUsers($this->dbConnection);
|
||||
$this->domainController = new DomainController($this->dbConnection);
|
||||
$this->nameserverController = new NameserverController($this->dbConnection);
|
||||
$this->checkController = new CheckController();
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param bool|array $panel
|
||||
*
|
||||
* @return bool
|
||||
* @return void
|
||||
*/
|
||||
public function checkPing(bool|array $panel): Bool
|
||||
public function checkPing(bool|array $panel): void
|
||||
{
|
||||
$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'] ?? '';
|
||||
print(COLOR_YELLOW . $panel['name']);
|
||||
if (!empty($a)) {
|
||||
if ($this->config['verbose']) {
|
||||
echo COLOR_DEFAULT . ' ' . str_pad(string: $a, length: $maxA, pad_type: STR_PAD_LEFT) . ' ';
|
||||
}
|
||||
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;
|
||||
}
|
||||
}
|
||||
if ($this->checkController->sendCommand(serverName: $panel['name'], versionIP: 4, apiKey: $panel['apikey'], command: 'ping')) {
|
||||
// if verbose …
|
||||
print(COLOR_DEFAULT . ' ' . $panel['a'] . ': ' . COLOR_GREEN . 'pong');
|
||||
} else {
|
||||
$error = true;
|
||||
}
|
||||
}
|
||||
$aaaa = $panel['aaaa'] ?? '';
|
||||
if (!empty($aaaa)) {
|
||||
if ($this->config['verbose']) {
|
||||
echo COLOR_DEFAULT . ' ' . str_pad(string: $aaaa, length: $maxAAAA, pad_type: STR_PAD_LEFT);
|
||||
}
|
||||
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;
|
||||
}
|
||||
}
|
||||
if ($this->checkController->sendCommand(serverName: $panel['name'], versionIP: 6, apiKey: $panel['apikey'], command: 'ping')) {
|
||||
// if verbose …
|
||||
print(COLOR_DEFAULT . ' ' . $panel['aaaa'] . ': ' . COLOR_GREEN . 'pong' . PHP_EOL);
|
||||
} else {
|
||||
$error = true;
|
||||
}
|
||||
}
|
||||
if ($this->config['verbose']) {
|
||||
echo PHP_EOL;
|
||||
}
|
||||
return $error;
|
||||
}
|
||||
|
||||
|
||||
function handleChecks(String $subcommand)
|
||||
function handleCheck(String $subcommand)
|
||||
{
|
||||
print("hable");
|
||||
try {
|
||||
match ($subcommand) {
|
||||
'permissions' => $this->handleCheckPermissions(),
|
||||
|
@ -115,21 +85,21 @@ class BindAPI
|
|||
|
||||
function handleCheckPermissions()
|
||||
{
|
||||
$test = fgets(stream: STDIN);
|
||||
$test = fgets(STDIN);
|
||||
echo "received: $test" . PHP_EOL;
|
||||
}
|
||||
|
||||
function runCommand()
|
||||
{
|
||||
if ($this->argumentsCount < 1) {
|
||||
if ($this->argc < 2) {
|
||||
$this->showUsage();
|
||||
exit(0);
|
||||
}
|
||||
|
||||
if (str_contains(haystack: $this->arguments[0], needle: ':')) {
|
||||
[$command, $subcommand] = explode(separator: ':', string: $this->arguments[0]);
|
||||
if (str_contains(haystack: $this->argv[1], needle: ':')) {
|
||||
[$command, $subcommand] = explode(separator: ':', string: $this->argv[1]);
|
||||
} else {
|
||||
$command = $this->arguments[0];
|
||||
$command = $this->argv[1];
|
||||
$subcommand = '';
|
||||
}
|
||||
|
||||
|
@ -153,38 +123,31 @@ class BindAPI
|
|||
function showUsage(): void
|
||||
{
|
||||
echo 'Usage' . PHP_EOL;
|
||||
echo COLOR_YELLOW . "check" . COLOR_DEFAULT . "\t health checks the system can perform" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t check:permissions" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t check:panels {ID}" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t check:domains {ID}" . PHP_EOL;
|
||||
|
||||
echo COLOR_YELLOW . "panels" . COLOR_DEFAULT . "\t all Keyhelp systems configured" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t panels:list" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t panels:create <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 COLOR_GREEN . "\t panels:delete" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t panels:apiping {<ID>}" . PHP_EOL;
|
||||
|
||||
echo COLOR_YELLOW . "nameservers" . COLOR_DEFAULT . " available nameservers" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t nameservers:list" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t nameservers:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t nameservers:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t nameservers:delete <ID>" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t nameservers:apiping {<ID>}" . PHP_EOL;
|
||||
|
||||
echo COLOR_YELLOW . "domains" . COLOR_DEFAULT . " domains this server is responsible for" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t domains:list" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t domains:create <name> {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t domains:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
|
||||
echo COLOR_GREEN . "\t domains:delete <ID>" . 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;
|
||||
echo "\033[33mcheck\t\t\033[39mhealth checks the system can perform" . PHP_EOL;
|
||||
echo "\033[32m\tcheck:permissions" . PHP_EOL;
|
||||
echo "\033[32m\tcheck:panel {ID}" . PHP_EOL;
|
||||
echo "\033[32m\tcheck:domains {ID}" . PHP_EOL;
|
||||
echo "\033[33mpanels\t\033[39mall Keyhelp systems configured" . PHP_EOL;
|
||||
echo "\033[32m\tpanels:list" . PHP_EOL;
|
||||
echo "\033[32m\tpanels:apiping {<ID>}" . PHP_EOL;
|
||||
echo "\033[32m\tpanels: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 "\033[32m\tpanels:delete" . PHP_EOL;
|
||||
echo "\033[33mapikeys\t\033[39mAPI keys for other nameservers" . 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[33mnameservers\t\033[39mother nameservers" . PHP_EOL;
|
||||
echo "\033[32m\tnameservers:list" . PHP_EOL;
|
||||
echo "\033[32m\tnameservers:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
||||
echo "\033[32m\tnameservers:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
||||
echo "\033[32m\tnameservers:delete <ID>" . PHP_EOL;
|
||||
echo "\033[33mdomains\t\033[39mdomains this server is responsible for" . 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=<name>} {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
|
||||
echo "\033[32m\tdomains:delete <ID>" . PHP_EOL;
|
||||
echo PHP_EOL . "\033[39me.g. ./bin/console apikey:list" . PHP_EOL;
|
||||
}
|
||||
|
||||
|
||||
|
@ -232,34 +195,21 @@ class BindAPI
|
|||
function handlePanelsAPIPing()
|
||||
{
|
||||
$error = false;
|
||||
|
||||
$id = $this->arguments[1] ?? 0;
|
||||
$id = $this->argv[2] ?? 0;
|
||||
|
||||
if ($id != 0) {
|
||||
if ($panel = $this->panelController->findByID($id)) {
|
||||
if (!$this->checkPing($panel)) {
|
||||
$error = true;
|
||||
}
|
||||
} else {
|
||||
if ($this->config['verbose']) {
|
||||
echo 'Unknown panel ID: $id' . PHP_EOL;
|
||||
}
|
||||
$error = true;
|
||||
}
|
||||
$panel = $this->panelController->findByID($id);
|
||||
$this->checkPing($panel);
|
||||
} else {
|
||||
$panels = $this->panelController->findAll();
|
||||
foreach ($panels as $panel) {
|
||||
if (!$this->checkPing(panel: $panel)) {
|
||||
$error = true;
|
||||
}
|
||||
$this->checkPing(panel: $panel);
|
||||
}
|
||||
}
|
||||
echo PHP_EOL;
|
||||
if ($error) {
|
||||
exit(1);
|
||||
} else {
|
||||
exit(0);
|
||||
}
|
||||
|
||||
|
||||
|
||||
print(PHP_EOL);
|
||||
}
|
||||
|
||||
|
||||
|
@ -268,7 +218,7 @@ class BindAPI
|
|||
*/
|
||||
function handlePanelsCreate(): void
|
||||
{
|
||||
$name = $this->arguments[0] ?? '';
|
||||
$name = $this->argv[2] ?? "";
|
||||
if (empty($name)) {
|
||||
echo 'You need to supply the panel name.' . PHP_EOL;
|
||||
exit(1);
|
||||
|
@ -290,7 +240,7 @@ class BindAPI
|
|||
echo 'At least one IP address is required.' . PHP_EOL;
|
||||
exit(0);
|
||||
}
|
||||
$apikey = $arguments['apikey'] ?? '';
|
||||
$apikey = $argiments['apikey'] ?? '';
|
||||
|
||||
if ($this->panelController->findByName($name)) {
|
||||
echo "Panel: $name already exists." . PHP_EOL;
|
||||
|
@ -308,7 +258,7 @@ class BindAPI
|
|||
*/
|
||||
function handleNameserversCreate(): void
|
||||
{
|
||||
$name = $this->arguments[1] ?? '';
|
||||
$name = $this->argv[2] ?? '';
|
||||
if (empty($name)) {
|
||||
echo 'You need to supply the nameserver name.' . PHP_EOL;
|
||||
exit(1);
|
||||
|
@ -349,7 +299,7 @@ class BindAPI
|
|||
public function parseArguments(): array
|
||||
{
|
||||
$arguments = [];
|
||||
foreach ($this->arguments as $argument) {
|
||||
foreach ($this->argv as $argument) {
|
||||
if (str_contains(haystack: $argument, needle: '=')) {
|
||||
[$key, $value] = explode(separator: '=', string: $argument);
|
||||
$arguments[strtolower($key)] = $value;
|
||||
|
@ -385,7 +335,7 @@ class BindAPI
|
|||
{
|
||||
$arguments = $this->parseArguments();
|
||||
|
||||
$id = $this->arguments[1] ?? 0;
|
||||
$id = $this->argv[2] ?? 0;
|
||||
$name = $arguments['name'] ?? '';
|
||||
$a = $arguments['a'] ?? '';
|
||||
$aaaa = $arguments['aaaa'] ?? '';
|
||||
|
@ -408,12 +358,12 @@ class BindAPI
|
|||
|
||||
function handlePanelsDelete()
|
||||
{
|
||||
if (empty($this->arguments[1])) {
|
||||
if (empty($this->argv[2])) {
|
||||
echo "You need to supply an ID." . PHP_EOL;
|
||||
exit(1);
|
||||
}
|
||||
|
||||
$id = intval($this->arguments[1]) ?? 0;
|
||||
$id = intval($this->argv[2]) ?? 0;
|
||||
if ($id == 0) {
|
||||
echo "Panel with ID $id not found." . PHP_EOL;
|
||||
exit(1);
|
||||
|
@ -464,9 +414,9 @@ class BindAPI
|
|||
$keys = $this->apiUsers->findAll();
|
||||
if ($keys) {
|
||||
$table = new ConsoleTable();
|
||||
$table->setHeaders(['ID', 'Name', 'API key prefix']);
|
||||
$table->setHeaders(['ID', 'API key prefix']);
|
||||
foreach ($keys as $key) {
|
||||
$table->addRow([$key['id'], $key['name'], $key['api_token_prefix']]);
|
||||
$table->addRow([$key['id'], $key['api_token_prefix']]);
|
||||
}
|
||||
$table->setPadding(value: 2);
|
||||
$table->display();
|
||||
|
@ -481,7 +431,7 @@ class BindAPI
|
|||
*/
|
||||
function handleApikeysDelete(): void
|
||||
{
|
||||
$id = intval($this->arguments[1]) ?? 0;
|
||||
$id = intval($this->argv[2]) ?? 0;
|
||||
if ($id == 0) {
|
||||
echo 'You need to add the ID of the API key.' . PHP_EOL;
|
||||
exit(1);
|
||||
|
@ -521,7 +471,7 @@ class BindAPI
|
|||
*/
|
||||
function handleNameserversList(): void
|
||||
{
|
||||
echo 'All available nameservers:' . PHP_EOL;
|
||||
echo 'All available nameserver:' . PHP_EOL;
|
||||
$domains = $this->nameserverController->findAll();
|
||||
if ($domains) {
|
||||
$table = new ConsoleTable();
|
||||
|
@ -566,7 +516,7 @@ class BindAPI
|
|||
*/
|
||||
function handleDomainsCreate(): void
|
||||
{
|
||||
$name = $this->arguments[1] ?? "";
|
||||
$name = $this->argv[2] ?? "";
|
||||
if (empty($name)) {
|
||||
echo 'You need to supply the domain name.' . PHP_EOL;
|
||||
exit(1);
|
||||
|
@ -603,7 +553,7 @@ class BindAPI
|
|||
{
|
||||
$arguments = $this->parseArguments();
|
||||
|
||||
$id = $this->arguments[1] ?? 0;
|
||||
$id = $this->argv[2] ?? 0;
|
||||
$name = $arguments['name'] ?? '';
|
||||
$a = $arguments['a'] ?? '';
|
||||
$aaaa = $arguments['aaaa'] ?? '';
|
||||
|
@ -629,7 +579,7 @@ class BindAPI
|
|||
{
|
||||
$arguments = $this->parseArguments();
|
||||
|
||||
$id = $this->arguments[1] ?? 0;
|
||||
$id = $this->argv[2] ?? 0;
|
||||
$name = $arguments['name'] ?? '';
|
||||
$a = $arguments['a'] ?? '';
|
||||
$aaaa = $arguments['aaaa'] ?? '';
|
||||
|
@ -652,12 +602,12 @@ class BindAPI
|
|||
|
||||
function handleNameserversDelete()
|
||||
{
|
||||
if (empty($this->arguments[1])) {
|
||||
if (empty($this->argv[2])) {
|
||||
echo "You need to supply an ID." . PHP_EOL;
|
||||
exit(1);
|
||||
}
|
||||
|
||||
$id = intval($this->arguments[1]) ?? 0;
|
||||
$id = intval($this->argv[2]) ?? 0;
|
||||
if ($id == 0) {
|
||||
echo "Nameserver with ID $id not found." . PHP_EOL;
|
||||
exit(1);
|
||||
|
@ -673,12 +623,12 @@ class BindAPI
|
|||
|
||||
function handleDomainsDelete()
|
||||
{
|
||||
if (empty($this->arguments[1])) {
|
||||
if (empty($this->argv[2])) {
|
||||
echo "You need to supply an ID." . PHP_EOL;
|
||||
exit(1);
|
||||
}
|
||||
|
||||
$id = intval($this->arguments[1]) ?? 0;
|
||||
$id = intval($this->argv[2]) ?? 0;
|
||||
if ($id == 0) {
|
||||
echo "Domain with ID $id not found." . PHP_EOL;
|
||||
exit(1);
|
||||
|
|
|
@ -15,14 +15,15 @@ class CheckController
|
|||
* @param String $apiKey
|
||||
* @param String $command
|
||||
*
|
||||
* @return String
|
||||
* @return bool|array
|
||||
*/
|
||||
function sendCommand(String $serverName, int $versionIP, String $apiKey, String $command): String
|
||||
function sendCommand(String $serverName, int $versionIP, String $apiKey, String $command) : Bool|Array
|
||||
{
|
||||
$result = false;
|
||||
$curl = curl_init();
|
||||
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_TIMEOUT_MS, value: 1000);
|
||||
curl_setopt($curl, option: CURLOPT_TIMEOUT_MS, value: 2000);
|
||||
|
||||
if ($versionIP == 4) {
|
||||
curl_setopt($curl, option: CURLOPT_IPRESOLVE, value: CURL_IPRESOLVE_V4);
|
||||
|
@ -40,23 +41,26 @@ class CheckController
|
|||
$apiResult = json_decode($resultJSON);
|
||||
if ($command == "ping" ) {
|
||||
if ($apiResult->response == "pong") {
|
||||
$result = $apiResult->response;
|
||||
$result = true;
|
||||
} else {
|
||||
$result = $resultJSON;
|
||||
print("Error: $httpResponse" . PHP_EOL);
|
||||
}
|
||||
} else {
|
||||
$result = $resultJSON;
|
||||
$result = $apiResult;
|
||||
}
|
||||
break;
|
||||
case 401:
|
||||
$result = 'Missing or wrong API Key';
|
||||
print("Missing or wrong API Key" . PHP_EOL);
|
||||
break;
|
||||
default:
|
||||
$result = 'Unhandled error: ' . $httpResponse;
|
||||
print("Unhandled error: " . $httpResponse . PHP_EOL);
|
||||
}
|
||||
|
||||
} else {
|
||||
$result = curl_error($curl);
|
||||
$error = curl_error($curl);
|
||||
print("Unknown error: $error" . PHP_EOL);
|
||||
}
|
||||
|
||||
curl_close($curl);
|
||||
return $result;
|
||||
}
|
||||
|
|
|
@ -12,12 +12,6 @@ class DatabaseConnection
|
|||
{
|
||||
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)
|
||||
{
|
||||
extract($this->config);
|
||||
|
@ -28,72 +22,8 @@ class DatabaseConnection
|
|||
username: $dbUser,
|
||||
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) {
|
||||
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);
|
||||
exit($exception->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -15,7 +15,7 @@ class DomainController
|
|||
private String $namedConfLocalFile;
|
||||
private string $zoneCachePath;
|
||||
|
||||
public function __construct(private DatabaseConnection $databaseConnection)
|
||||
public function __construct(private PDO $dbConnection)
|
||||
{
|
||||
$this->localZoneFile = '/etc/bind/local.zones';
|
||||
$this->localZonesDir = '/etc/bind/zones/';
|
||||
|
@ -31,10 +31,10 @@ class DomainController
|
|||
{
|
||||
$statement = "
|
||||
SELECT id, name, a, aaaa
|
||||
FROM " . DatabaseConnection::TABLE_DOMAINS;
|
||||
FROM domains";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->query($statement);
|
||||
$statement = $this->dbConnection->query($statement);
|
||||
return $statement->fetchAll(mode: PDO::FETCH_ASSOC);
|
||||
} catch (PDOException $e) {
|
||||
exit($e->getMessage());
|
||||
|
@ -51,11 +51,11 @@ class DomainController
|
|||
{
|
||||
$sql = "
|
||||
SELECT id, name, a, aaaa
|
||||
FROM " . DatabaseConnection::TABLE_DOMAINS . "
|
||||
FROM domains
|
||||
WHERE name = :name";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param: ':name', var: $name);
|
||||
$statement->execute();
|
||||
return $statement->fetch(PDO::FETCH_ASSOC);
|
||||
|
@ -74,11 +74,11 @@ class DomainController
|
|||
{
|
||||
$sql = "
|
||||
SELECT id, name, a, aaaa
|
||||
FROM . " . DatabaseConnection::TABLE_DOMAINS . "
|
||||
FROM domains
|
||||
WHERE id = :id";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param:':id', var: $id);
|
||||
$statement->execute();
|
||||
return $statement->fetch(PDO::FETCH_ASSOC);
|
||||
|
@ -99,11 +99,11 @@ class DomainController
|
|||
{
|
||||
// TODO create zone file and include
|
||||
$sql = "
|
||||
INSERT INTO " . DatabaseConnection::TABLE_DOMAINS . " (name, a, aaaa)
|
||||
INSERT INTO domains (name, a, aaaa)
|
||||
VALUES (:name, :a, :aaaa)";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param: ':name', var: $name);
|
||||
$statement->bindParam(param: ':a', var: $a);
|
||||
$statement->bindParam(param: ':aaaa', var: $aaaa);
|
||||
|
@ -121,7 +121,7 @@ class DomainController
|
|||
exit(1);
|
||||
}
|
||||
|
||||
return $this->databaseConnection->getConnection()->lastInsertId();
|
||||
return $this->dbConnection->lastInsertId();
|
||||
} catch (PDOException $e) {
|
||||
exit($e->getMessage());
|
||||
}
|
||||
|
@ -135,9 +135,9 @@ class DomainController
|
|||
* @param String $a
|
||||
* @param String $aaaa
|
||||
*
|
||||
* @return false|int
|
||||
* @return int|void
|
||||
*/
|
||||
public function update(Int $id, String $name, String $a, String $aaaa): bool|int
|
||||
public function update(Int $id, String $name, String $a, String $aaaa)
|
||||
{
|
||||
$current = $this->findByID($id);
|
||||
|
||||
|
@ -162,14 +162,14 @@ class DomainController
|
|||
}
|
||||
|
||||
$sql = "
|
||||
UPDATE " . DatabaseConnection::TABLE_DOMAINS . " SET
|
||||
UPDATE domains SET
|
||||
name = :name,
|
||||
a = :a,
|
||||
aaaa = :aaaa
|
||||
WHERE id = :id";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
||||
$statement = $this->dbConnection->prepare($sql);
|
||||
$statement->bindParam(param: 'id', var: $id);
|
||||
$statement->bindParam(param: 'name', var: $name);
|
||||
$statement->bindParam(param: 'a', var: $a);
|
||||
|
@ -178,7 +178,7 @@ class DomainController
|
|||
|
||||
// recreate zonefile
|
||||
$this->createZoneFile(name: $name, a: $a, aaaa: $aaaa);
|
||||
exec(command: '/usr/sbin/rndc reload');
|
||||
exec('/usr/sbin/rndc reload');
|
||||
|
||||
return $statement->rowCount();
|
||||
} catch (PDOException $e) {
|
||||
|
@ -197,11 +197,11 @@ class DomainController
|
|||
{
|
||||
// TODO delete zone file and include
|
||||
$statement = "
|
||||
DELETE FROM " . DatabaseConnection::TABLE_DOMAINS . "
|
||||
DELETE FROM domains
|
||||
WHERE id = :id";
|
||||
|
||||
try {
|
||||
$statement = $this->databaseConnection->getConnection()->prepare($statement);
|
||||
$statement = $this->dbConnection->prepare($statement);
|
||||
$statement->bindParam(param: 'id', var: $id);
|
||||
$statement->execute();
|
||||
return $statement->rowCount();
|
||||
|
@ -251,7 +251,6 @@ class DomainController
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* @param mixed $name
|
||||
* @param mixed $a
|
||||
|
|
|
@ -1,181 +0,0 @@
|
|||
<?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());
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,204 +0,0 @@
|
|||
<?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());
|
||||
}
|
||||
}
|
||||
}
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
namespace App\Controller;
|
||||
|
||||
use PDO;
|
||||
use UnhandledMatchError;
|
||||
|
||||
/**
|
||||
|
@ -15,14 +16,14 @@ class RequestController
|
|||
private String $message;
|
||||
|
||||
/**
|
||||
* @param \App\Controller\DatabaseConnection $databaseConnection
|
||||
* @param String $requestMethod
|
||||
* @param array $uri
|
||||
* @param \PDO $dbConnection
|
||||
* @param String $requestMethod
|
||||
* @param array $uri
|
||||
*/
|
||||
public function __construct(private DatabaseConnection $databaseConnection, private String $requestMethod, private array $uri)
|
||||
public function __construct(private PDO $dbConnection, private String $requestMethod, private array $uri)
|
||||
{
|
||||
$this->requestMethod = strtoupper($requestMethod);
|
||||
$this->domainController = new DomainController($this->databaseConnection);
|
||||
$this->domainController = new DomainController($dbConnection);
|
||||
}
|
||||
|
||||
|
||||
|
@ -75,7 +76,7 @@ class RequestController
|
|||
return false;
|
||||
} else {
|
||||
[$prefix,] = explode('.', $apiKey);
|
||||
$apiUsers = new ApiKeys($this->databaseConnection);
|
||||
$apiUsers = new ApiUsers($this->dbConnection);
|
||||
$apiResult = $apiUsers->findByPrefix($prefix);
|
||||
$storedHash = $apiResult['api_token'];
|
||||
|
||||
|
|
Loading…
Reference in New Issue