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;
|
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);
|
||||||
|
|
||||||
if (!$config = json_decode($configJSON, associative: true)) {
|
$app = new BindAPI(config: $config, argc: $argc, argv: $argv);
|
||||||
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;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
|
@ -3,5 +3,5 @@
|
||||||
"dbPort": 3306,
|
"dbPort": 3306,
|
||||||
"dbDatabase": "sampledb",
|
"dbDatabase": "sampledb",
|
||||||
"dbUser": "sampleuser",
|
"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
|
public function findAll(): bool|array
|
||||||
{
|
{
|
||||||
$sql = "
|
$sql = "
|
||||||
SELECT id, name, api_token_prefix, api_token
|
SELECT id, api_token_prefix, api_token
|
||||||
FROM " . DatabaseConnection::TABLE_USER;
|
FROM user";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->query($sql);
|
$statement = $this->dbConnection->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 ApiKeys
|
||||||
public function findByID(Int $id): bool|array
|
public function findByID(Int $id): bool|array
|
||||||
{
|
{
|
||||||
$sql = "
|
$sql = "
|
||||||
SELECT name, api_token_prefix, api_token
|
SELECT api_token_prefix, api_token
|
||||||
FROM " . DatabaseConnection::TABLE_USER . "
|
FROM user
|
||||||
WHERE id = :id;
|
WHERE id = :id;
|
||||||
";
|
";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->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 ApiKeys
|
||||||
public function findByPrefix(String $prefix): bool|array
|
public function findByPrefix(String $prefix): bool|array
|
||||||
{
|
{
|
||||||
$sql = "
|
$sql = "
|
||||||
SELECT name, api_token
|
SELECT api_token
|
||||||
FROM " . DatabaseConnection::TABLE_USER . "
|
FROM user
|
||||||
WHERE api_token_prefix = :prefix";
|
WHERE api_token_prefix = :prefix";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->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 ApiKeys
|
||||||
/**
|
/**
|
||||||
* @return array|void
|
* @return array|void
|
||||||
*/
|
*/
|
||||||
public function create(String $name = '')
|
public function create()
|
||||||
{
|
{
|
||||||
$tokenPrefix = uniqid();
|
$tokenPrefix = uniqid();
|
||||||
$result['tokenPrefix'] = $tokenPrefix;
|
$result['tokenPrefix'] = $tokenPrefix;
|
||||||
|
@ -97,17 +97,15 @@ class ApiKeys
|
||||||
$token = password_hash(password: $tokenPrefix . '.' . $key, algo: PASSWORD_ARGON2ID);
|
$token = password_hash(password: $tokenPrefix . '.' . $key, algo: PASSWORD_ARGON2ID);
|
||||||
|
|
||||||
$sql = "
|
$sql = "
|
||||||
INSERT INTO " . DatabaseConnection::TABLE_USER . " (name, api_token_prefix, api_token)
|
INSERT INTO user (api_token_prefix, api_token)
|
||||||
VALUES (:token_prefix, :token)";
|
VALUES (:token_prefix, :token)";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->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->databaseConnection->getConnection()->lastInsertId();
|
$result['row'] = $this->dbConnection->lastInsertId();
|
||||||
return $result;
|
return $result;
|
||||||
} catch (PDOException $e) {
|
} catch (PDOException $e) {
|
||||||
exit($e->getMessage());
|
exit($e->getMessage());
|
||||||
|
@ -123,11 +121,11 @@ class ApiKeys
|
||||||
public function delete($id): int
|
public function delete($id): int
|
||||||
{
|
{
|
||||||
$sql = "
|
$sql = "
|
||||||
DELETE FROM " . DatabaseConnection::TABLE_USER . "
|
DELETE FROM user
|
||||||
WHERE id = :id";
|
WHERE id = :id";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->prepare($sql);
|
||||||
$statement->bindParam(param: 'id', var: $id);
|
$statement->bindParam(param: 'id', var: $id);
|
||||||
$statement->execute();
|
$statement->execute();
|
||||||
return $statement->rowCount();
|
return $statement->rowCount();
|
|
@ -2,19 +2,21 @@
|
||||||
|
|
||||||
namespace App\Controller;
|
namespace App\Controller;
|
||||||
|
|
||||||
define('COLOR_RED', "\033[31m");
|
|
||||||
define('COLOR_GREEN', "\033[32m");
|
|
||||||
define('COLOR_YELLOW', "\033[33m");
|
define('COLOR_YELLOW', "\033[33m");
|
||||||
|
define('COLOR_GREEN', "\033[32m");
|
||||||
define('COLOR_DEFAULT', "\033[39m");
|
define('COLOR_DEFAULT', "\033[39m");
|
||||||
|
|
||||||
// TODO add to all Controllers
|
// TODO add to all Controllers
|
||||||
error_reporting(error_level: E_ALL);
|
error_reporting(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;
|
||||||
}
|
}
|
||||||
|
@ -24,86 +26,54 @@ if (php_sapi_name() !== 'cli') {
|
||||||
*/
|
*/
|
||||||
class BindAPI
|
class BindAPI
|
||||||
{
|
{
|
||||||
private DatabaseConnection $databaseConnection;
|
private PDO $dbConnection;
|
||||||
private ApiKeys $apiUsers;
|
private ApiUsers $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->databaseConnection = new DatabaseConnection(config: $this->config);
|
$this->dbConnection = (new DatabaseConnection(config: $this->config))->getConnection();
|
||||||
$this->panelController = new PanelController($this->databaseConnection);
|
$this->panelController = new PanelController($this->dbConnection);
|
||||||
$this->apiUsers = new ApiKeys($this->databaseConnection);
|
$this->apiUsers = new ApiUsers($this->dbConnection);
|
||||||
$this->domainController = new DomainController($this->databaseConnection);
|
$this->domainController = new DomainController($this->dbConnection);
|
||||||
$this->nameserverController = new NameserverController($this->databaseConnection);
|
$this->nameserverController = new NameserverController($this->dbConnection);
|
||||||
$this->checkController = new CheckController();
|
$this->checkController = new CheckController();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param bool|array $panel
|
* @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'] ?? '';
|
$a = $panel['a'] ?? '';
|
||||||
|
print(COLOR_YELLOW . $panel['name']);
|
||||||
if (!empty($a)) {
|
if (!empty($a)) {
|
||||||
if ($this->config['verbose']) {
|
if ($this->checkController->sendCommand(serverName: $panel['name'], versionIP: 4, apiKey: $panel['apikey'], command: 'ping')) {
|
||||||
echo COLOR_DEFAULT . ' ' . str_pad(string: $a, length: $maxA, pad_type: STR_PAD_LEFT) . ' ';
|
// if verbose …
|
||||||
}
|
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->config['verbose']) {
|
if ($this->checkController->sendCommand(serverName: $panel['name'], versionIP: 6, apiKey: $panel['apikey'], command: 'ping')) {
|
||||||
echo COLOR_DEFAULT . ' ' . str_pad(string: $aaaa, length: $maxAAAA, pad_type: STR_PAD_LEFT);
|
// if verbose …
|
||||||
}
|
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 handleChecks(String $subcommand)
|
function handleCheck(String $subcommand)
|
||||||
{
|
{
|
||||||
print("hable");
|
|
||||||
try {
|
try {
|
||||||
match ($subcommand) {
|
match ($subcommand) {
|
||||||
'permissions' => $this->handleCheckPermissions(),
|
'permissions' => $this->handleCheckPermissions(),
|
||||||
|
@ -115,21 +85,21 @@ class BindAPI
|
||||||
|
|
||||||
function handleCheckPermissions()
|
function handleCheckPermissions()
|
||||||
{
|
{
|
||||||
$test = fgets(stream: STDIN);
|
$test = fgets(STDIN);
|
||||||
echo "received: $test" . PHP_EOL;
|
echo "received: $test" . PHP_EOL;
|
||||||
}
|
}
|
||||||
|
|
||||||
function runCommand()
|
function runCommand()
|
||||||
{
|
{
|
||||||
if ($this->argumentsCount < 1) {
|
if ($this->argc < 2) {
|
||||||
$this->showUsage();
|
$this->showUsage();
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (str_contains(haystack: $this->arguments[0], needle: ':')) {
|
if (str_contains(haystack: $this->argv[1], needle: ':')) {
|
||||||
[$command, $subcommand] = explode(separator: ':', string: $this->arguments[0]);
|
[$command, $subcommand] = explode(separator: ':', string: $this->argv[1]);
|
||||||
} else {
|
} else {
|
||||||
$command = $this->arguments[0];
|
$command = $this->argv[1];
|
||||||
$subcommand = '';
|
$subcommand = '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,38 +123,31 @@ class BindAPI
|
||||||
function showUsage(): void
|
function showUsage(): void
|
||||||
{
|
{
|
||||||
echo 'Usage' . PHP_EOL;
|
echo 'Usage' . PHP_EOL;
|
||||||
echo COLOR_YELLOW . "check" . COLOR_DEFAULT . "\t health checks the system can perform" . PHP_EOL;
|
echo "\033[33mcheck\t\t\033[39mhealth checks the system can perform" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t check:permissions" . PHP_EOL;
|
echo "\033[32m\tcheck:permissions" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t check:panels {ID}" . PHP_EOL;
|
echo "\033[32m\tcheck:panel {ID}" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t check:domains {ID}" . PHP_EOL;
|
echo "\033[32m\tcheck:domains {ID}" . PHP_EOL;
|
||||||
|
echo "\033[33mpanels\t\033[39mall Keyhelp systems configured" . PHP_EOL;
|
||||||
echo COLOR_YELLOW . "panels" . COLOR_DEFAULT . "\t all Keyhelp systems configured" . PHP_EOL;
|
echo "\033[32m\tpanels:list" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t panels:list" . PHP_EOL;
|
echo "\033[32m\tpanels:apiping {<ID>}" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t panels:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
echo "\033[32m\tpanels: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 "\033[32m\tpanels:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t panels:delete" . PHP_EOL;
|
echo "\033[32m\tpanels:delete" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t panels:apiping {<ID>}" . PHP_EOL;
|
echo "\033[33mapikeys\t\033[39mAPI keys for other nameservers" . PHP_EOL;
|
||||||
|
echo "\033[32m\tapikeys:list" . PHP_EOL;
|
||||||
echo COLOR_YELLOW . "nameservers" . COLOR_DEFAULT . " available nameservers" . PHP_EOL;
|
echo "\033[32m\tapikeys:create" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t nameservers:list" . PHP_EOL;
|
echo "\033[32m\tapikeys:delete <ID>" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t nameservers:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
echo "\033[33mnameservers\t\033[39mother nameservers" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t nameservers:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
echo "\033[32m\tnameservers:list" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t nameservers:delete <ID>" . PHP_EOL;
|
echo "\033[32m\tnameservers:create <name> {A=<IPv4>} {AAAA=<IPv6>} {apikey=<API-Key>}" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t nameservers:apiping {<ID>}" . 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 COLOR_YELLOW . "domains" . COLOR_DEFAULT . " domains this server is responsible for" . PHP_EOL;
|
echo "\033[33mdomains\t\033[39mdomains this server is responsible for" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t domains:list" . PHP_EOL;
|
echo "\033[32m\tdomains:list" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t domains:create <name> {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
|
echo "\033[32m\tdomains:create <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:update <ID> {name=<name>} {A=<IPv4>} {AAAA=<IPv6>}" . PHP_EOL;
|
||||||
echo COLOR_GREEN . "\t domains:delete <ID>" . PHP_EOL;
|
echo "\033[32m\tdomains: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;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -232,34 +195,21 @@ 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) {
|
||||||
if ($panel = $this->panelController->findByID($id)) {
|
$panel = $this->panelController->findByID($id);
|
||||||
if (!$this->checkPing($panel)) {
|
$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) {
|
||||||
if (!$this->checkPing(panel: $panel)) {
|
$this->checkPing(panel: $panel);
|
||||||
$error = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
echo PHP_EOL;
|
|
||||||
if ($error) {
|
|
||||||
exit(1);
|
|
||||||
} else {
|
print(PHP_EOL);
|
||||||
exit(0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -268,7 +218,7 @@ class BindAPI
|
||||||
*/
|
*/
|
||||||
function handlePanelsCreate(): void
|
function handlePanelsCreate(): void
|
||||||
{
|
{
|
||||||
$name = $this->arguments[0] ?? '';
|
$name = $this->argv[2] ?? "";
|
||||||
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);
|
||||||
|
@ -290,7 +240,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 = $arguments['apikey'] ?? '';
|
$apikey = $argiments['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;
|
||||||
|
@ -308,7 +258,7 @@ class BindAPI
|
||||||
*/
|
*/
|
||||||
function handleNameserversCreate(): void
|
function handleNameserversCreate(): void
|
||||||
{
|
{
|
||||||
$name = $this->arguments[1] ?? '';
|
$name = $this->argv[2] ?? '';
|
||||||
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);
|
||||||
|
@ -349,7 +299,7 @@ class BindAPI
|
||||||
public function parseArguments(): array
|
public function parseArguments(): array
|
||||||
{
|
{
|
||||||
$arguments = [];
|
$arguments = [];
|
||||||
foreach ($this->arguments as $argument) {
|
foreach ($this->argv 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;
|
||||||
|
@ -385,7 +335,7 @@ class BindAPI
|
||||||
{
|
{
|
||||||
$arguments = $this->parseArguments();
|
$arguments = $this->parseArguments();
|
||||||
|
|
||||||
$id = $this->arguments[1] ?? 0;
|
$id = $this->argv[2] ?? 0;
|
||||||
$name = $arguments['name'] ?? '';
|
$name = $arguments['name'] ?? '';
|
||||||
$a = $arguments['a'] ?? '';
|
$a = $arguments['a'] ?? '';
|
||||||
$aaaa = $arguments['aaaa'] ?? '';
|
$aaaa = $arguments['aaaa'] ?? '';
|
||||||
|
@ -408,12 +358,12 @@ class BindAPI
|
||||||
|
|
||||||
function handlePanelsDelete()
|
function handlePanelsDelete()
|
||||||
{
|
{
|
||||||
if (empty($this->arguments[1])) {
|
if (empty($this->argv[2])) {
|
||||||
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->arguments[1]) ?? 0;
|
$id = intval($this->argv[2]) ?? 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);
|
||||||
|
@ -464,9 +414,9 @@ class BindAPI
|
||||||
$keys = $this->apiUsers->findAll();
|
$keys = $this->apiUsers->findAll();
|
||||||
if ($keys) {
|
if ($keys) {
|
||||||
$table = new ConsoleTable();
|
$table = new ConsoleTable();
|
||||||
$table->setHeaders(['ID', 'Name', 'API key prefix']);
|
$table->setHeaders(['ID', 'API key prefix']);
|
||||||
foreach ($keys as $key) {
|
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->setPadding(value: 2);
|
||||||
$table->display();
|
$table->display();
|
||||||
|
@ -481,7 +431,7 @@ class BindAPI
|
||||||
*/
|
*/
|
||||||
function handleApikeysDelete(): void
|
function handleApikeysDelete(): void
|
||||||
{
|
{
|
||||||
$id = intval($this->arguments[1]) ?? 0;
|
$id = intval($this->argv[2]) ?? 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);
|
||||||
|
@ -521,7 +471,7 @@ class BindAPI
|
||||||
*/
|
*/
|
||||||
function handleNameserversList(): void
|
function handleNameserversList(): void
|
||||||
{
|
{
|
||||||
echo 'All available nameservers:' . PHP_EOL;
|
echo 'All available nameserver:' . PHP_EOL;
|
||||||
$domains = $this->nameserverController->findAll();
|
$domains = $this->nameserverController->findAll();
|
||||||
if ($domains) {
|
if ($domains) {
|
||||||
$table = new ConsoleTable();
|
$table = new ConsoleTable();
|
||||||
|
@ -566,7 +516,7 @@ class BindAPI
|
||||||
*/
|
*/
|
||||||
function handleDomainsCreate(): void
|
function handleDomainsCreate(): void
|
||||||
{
|
{
|
||||||
$name = $this->arguments[1] ?? "";
|
$name = $this->argv[2] ?? "";
|
||||||
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);
|
||||||
|
@ -603,7 +553,7 @@ class BindAPI
|
||||||
{
|
{
|
||||||
$arguments = $this->parseArguments();
|
$arguments = $this->parseArguments();
|
||||||
|
|
||||||
$id = $this->arguments[1] ?? 0;
|
$id = $this->argv[2] ?? 0;
|
||||||
$name = $arguments['name'] ?? '';
|
$name = $arguments['name'] ?? '';
|
||||||
$a = $arguments['a'] ?? '';
|
$a = $arguments['a'] ?? '';
|
||||||
$aaaa = $arguments['aaaa'] ?? '';
|
$aaaa = $arguments['aaaa'] ?? '';
|
||||||
|
@ -628,8 +578,8 @@ class BindAPI
|
||||||
function handleNameserversUpdate()
|
function handleNameserversUpdate()
|
||||||
{
|
{
|
||||||
$arguments = $this->parseArguments();
|
$arguments = $this->parseArguments();
|
||||||
|
|
||||||
$id = $this->arguments[1] ?? 0;
|
$id = $this->argv[2] ?? 0;
|
||||||
$name = $arguments['name'] ?? '';
|
$name = $arguments['name'] ?? '';
|
||||||
$a = $arguments['a'] ?? '';
|
$a = $arguments['a'] ?? '';
|
||||||
$aaaa = $arguments['aaaa'] ?? '';
|
$aaaa = $arguments['aaaa'] ?? '';
|
||||||
|
@ -652,12 +602,12 @@ class BindAPI
|
||||||
|
|
||||||
function handleNameserversDelete()
|
function handleNameserversDelete()
|
||||||
{
|
{
|
||||||
if (empty($this->arguments[1])) {
|
if (empty($this->argv[2])) {
|
||||||
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->arguments[1]) ?? 0;
|
$id = intval($this->argv[2]) ?? 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);
|
||||||
|
@ -673,12 +623,12 @@ class BindAPI
|
||||||
|
|
||||||
function handleDomainsDelete()
|
function handleDomainsDelete()
|
||||||
{
|
{
|
||||||
if (empty($this->arguments[1])) {
|
if (empty($this->argv[2])) {
|
||||||
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->arguments[1]) ?? 0;
|
$id = intval($this->argv[2]) ?? 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);
|
||||||
|
|
|
@ -15,14 +15,15 @@ class CheckController
|
||||||
* @param String $apiKey
|
* @param String $apiKey
|
||||||
* @param String $command
|
* @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 = 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: 1000);
|
curl_setopt($curl, option: CURLOPT_TIMEOUT_MS, value: 2000);
|
||||||
|
|
||||||
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);
|
||||||
|
@ -40,23 +41,26 @@ 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 = $apiResult->response;
|
$result = true;
|
||||||
} else {
|
} else {
|
||||||
$result = $resultJSON;
|
print("Error: $httpResponse" . PHP_EOL);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$result = $resultJSON;
|
$result = $apiResult;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 401:
|
case 401:
|
||||||
$result = 'Missing or wrong API Key';
|
print("Missing or wrong API Key" . PHP_EOL);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
$result = 'Unhandled error: ' . $httpResponse;
|
print("Unhandled error: " . $httpResponse . PHP_EOL);
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
$result = curl_error($curl);
|
$error = curl_error($curl);
|
||||||
|
print("Unknown error: $error" . PHP_EOL);
|
||||||
}
|
}
|
||||||
|
|
||||||
curl_close($curl);
|
curl_close($curl);
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,12 +12,6 @@ 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);
|
||||||
|
@ -28,72 +22,8 @@ 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) {
|
||||||
echo $exception->getMessage() . PHP_EOL;
|
exit($exception->getMessage());
|
||||||
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);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,7 @@ class DomainController
|
||||||
private String $namedConfLocalFile;
|
private String $namedConfLocalFile;
|
||||||
private string $zoneCachePath;
|
private string $zoneCachePath;
|
||||||
|
|
||||||
public function __construct(private DatabaseConnection $databaseConnection)
|
public function __construct(private PDO $dbConnection)
|
||||||
{
|
{
|
||||||
$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 " . DatabaseConnection::TABLE_DOMAINS;
|
FROM domains";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->query($statement);
|
$statement = $this->dbConnection->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 " . DatabaseConnection::TABLE_DOMAINS . "
|
FROM domains
|
||||||
WHERE name = :name";
|
WHERE name = :name";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->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 . " . DatabaseConnection::TABLE_DOMAINS . "
|
FROM domains
|
||||||
WHERE id = :id";
|
WHERE id = :id";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->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 " . DatabaseConnection::TABLE_DOMAINS . " (name, a, aaaa)
|
INSERT INTO domains (name, a, aaaa)
|
||||||
VALUES (:name, :a, :aaaa)";
|
VALUES (:name, :a, :aaaa)";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->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->databaseConnection->getConnection()->lastInsertId();
|
return $this->dbConnection->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 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);
|
$current = $this->findByID($id);
|
||||||
|
|
||||||
|
@ -162,14 +162,14 @@ class DomainController
|
||||||
}
|
}
|
||||||
|
|
||||||
$sql = "
|
$sql = "
|
||||||
UPDATE " . DatabaseConnection::TABLE_DOMAINS . " SET
|
UPDATE domains SET
|
||||||
name = :name,
|
name = :name,
|
||||||
a = :a,
|
a = :a,
|
||||||
aaaa = :aaaa
|
aaaa = :aaaa
|
||||||
WHERE id = :id";
|
WHERE id = :id";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($sql);
|
$statement = $this->dbConnection->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(command: '/usr/sbin/rndc reload');
|
exec('/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 " . DatabaseConnection::TABLE_DOMAINS . "
|
DELETE FROM domains
|
||||||
WHERE id = :id";
|
WHERE id = :id";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$statement = $this->databaseConnection->getConnection()->prepare($statement);
|
$statement = $this->dbConnection->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,7 +251,6 @@ class DomainController
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param mixed $name
|
* @param mixed $name
|
||||||
* @param mixed $a
|
* @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;
|
namespace App\Controller;
|
||||||
|
|
||||||
|
use PDO;
|
||||||
use UnhandledMatchError;
|
use UnhandledMatchError;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -15,14 +16,14 @@ class RequestController
|
||||||
private String $message;
|
private String $message;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param \App\Controller\DatabaseConnection $databaseConnection
|
* @param \PDO $dbConnection
|
||||||
* @param String $requestMethod
|
* @param String $requestMethod
|
||||||
* @param array $uri
|
* @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->requestMethod = strtoupper($requestMethod);
|
||||||
$this->domainController = new DomainController($this->databaseConnection);
|
$this->domainController = new DomainController($dbConnection);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -75,7 +76,7 @@ class RequestController
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
[$prefix,] = explode('.', $apiKey);
|
[$prefix,] = explode('.', $apiKey);
|
||||||
$apiUsers = new ApiKeys($this->databaseConnection);
|
$apiUsers = new ApiUsers($this->dbConnection);
|
||||||
$apiResult = $apiUsers->findByPrefix($prefix);
|
$apiResult = $apiUsers->findByPrefix($prefix);
|
||||||
$storedHash = $apiResult['api_token'];
|
$storedHash = $apiResult['api_token'];
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue