Some checks failed
Upgrade Test (4.x) / upgrade_test (map[file:V4_0.sql version:4.0]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_1.sql version:4.1]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_10.sql version:4.10]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_10_1.sql version:4.10.1]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_1_1.sql version:4.1.1]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_1_2.sql version:4.1.2]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_1_2_1.sql version:4.1.2.1]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_2_0_1.sql version:4.2.0.1]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_3.sql version:4.3]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_3_1.sql version:4.3.1]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_3_2.sql version:4.3.2]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_3_3.sql version:4.3.3]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_3_4.sql version:4.3.4]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_3_5.sql version:4.3.5]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_4.sql version:4.4]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_5.sql version:4.5]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_6.sql version:4.6]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_6_0_1.sql version:4.6.0.1]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_7.sql version:4.7]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_8.sql version:4.8]) (push) Has been cancelled
Upgrade Test (4.x) / upgrade_test (map[file:V4_9.sql version:4.9]) (push) Has been cancelled
Build / build (push) Has been cancelled
Cypress / cypress (push) Has been cancelled
Docker Build Test / build (push) Has been cancelled
Lint / lint (push) Has been cancelled
Scheduled Test / db_test (map[admin:mariadb-admin image:mariadb:11.0]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mariadb-admin image:mariadb:11.1]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mariadb-admin image:mariadb:11.2]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mariadb-admin image:mariadb:11.3]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mariadb-admin image:mariadb:11.4]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.0]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.10]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.11]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.1]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.2]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.3]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.4]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.5]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.6]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.7]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.8]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:10.9]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mariadb:5.5]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:5.5]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:5.6]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:5.7]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:8.0]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:8.1]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:8.2]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:8.3]) (push) Has been cancelled
Scheduled Test / db_test (map[admin:mysqladmin image:mysql:8.4]) (push) Has been cancelled
Scheduled Test / php_test (php7.4) (push) Has been cancelled
Scheduled Test / php_test (php8.0) (push) Has been cancelled
Scheduled Test / php_test (php8.1) (push) Has been cancelled
Scheduled Test / php_test (php8.2) (push) Has been cancelled
Scheduled Test / php_test (php8.3) (push) Has been cancelled
Test / test (map[image:mariadb:10.3 name:mariadb103]) (push) Has been cancelled
Test / test (map[image:mysql:5.7 name:mysql57]) (push) Has been cancelled
Test / composer_check (push) Has been cancelled
Test / installation (push) Has been cancelled
180 lines
7.6 KiB
PHP
Executable File
180 lines
7.6 KiB
PHP
Executable File
<?php
|
|
/**
|
|
* OrangeHRM is a comprehensive Human Resource Management (HRM) System that captures
|
|
* all the essential functionalities required for any enterprise.
|
|
* Copyright (C) 2006 OrangeHRM Inc., http://www.orangehrm.com
|
|
*
|
|
* OrangeHRM is free software: you can redistribute it and/or modify it under the terms of
|
|
* the GNU General Public License as published by the Free Software Foundation, either
|
|
* version 3 of the License, or (at your option) any later version.
|
|
*
|
|
* OrangeHRM is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
* See the GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along with OrangeHRM.
|
|
* If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
namespace OrangeHRM\Installer\Controller\Installer\Api;
|
|
|
|
use OrangeHRM\Authentication\Dto\UserCredential;
|
|
use OrangeHRM\Framework\Http\Request;
|
|
use OrangeHRM\Framework\Http\Response;
|
|
use OrangeHRM\Installer\Controller\AbstractInstallerRestController;
|
|
use OrangeHRM\Installer\Util\AppSetupUtility;
|
|
use OrangeHRM\Installer\Util\StateContainer;
|
|
|
|
class DatabaseConfigAPI extends AbstractInstallerRestController
|
|
{
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
protected function handlePost(Request $request): array
|
|
{
|
|
$dbType = $request->request->get('dbType');
|
|
$dbHost = $request->request->get('dbHost');
|
|
$dbPort = $request->request->get('dbPort');
|
|
$dbUser = $request->request->get('dbUser');
|
|
$dbPassword = $request->request->get('dbPassword');
|
|
$dbName = $request->request->get('dbName');
|
|
$enableDataEncryption = $request->request->getBoolean('enableDataEncryption');
|
|
|
|
if ($dbType === AppSetupUtility::INSTALLATION_DB_TYPE_EXISTING &&
|
|
($request->request->has('useSameDbUserForOrangeHRM') ||
|
|
$request->request->has('ohrmDbUser') ||
|
|
$request->request->has('ohrmDbPassword'))) {
|
|
$this->getResponse()->setStatusCode(Response::HTTP_BAD_REQUEST);
|
|
return [
|
|
'error' => [
|
|
'status' => $this->getResponse()->getStatusCode(),
|
|
'message' => 'Unexpected Parameter `useSameDbUserForOrangeHRM` or `ohrmDbUser` or `ohrmDbPassword` Received'
|
|
]
|
|
];
|
|
}
|
|
|
|
$appSetupUtility = new AppSetupUtility();
|
|
if ($dbType === AppSetupUtility::INSTALLATION_DB_TYPE_NEW) {
|
|
$useSameDbUserForOrangeHRM = $request->request->getBoolean('useSameDbUserForOrangeHRM', false);
|
|
$ohrmDbUser = $dbUser;
|
|
$ohrmDbPassword = $dbPassword;
|
|
if (!$useSameDbUserForOrangeHRM) {
|
|
$ohrmDbUser = $request->request->get('ohrmDbUser');
|
|
$ohrmDbPassword = $request->request->get('ohrmDbPassword');
|
|
}
|
|
|
|
StateContainer::getInstance()->storeDbInfo(
|
|
$dbHost,
|
|
$dbPort,
|
|
new UserCredential($dbUser, $dbPassword),
|
|
$dbName,
|
|
new UserCredential($ohrmDbUser, $ohrmDbPassword),
|
|
$enableDataEncryption
|
|
);
|
|
StateContainer::getInstance()->setDbType(AppSetupUtility::INSTALLATION_DB_TYPE_NEW);
|
|
|
|
$connection = $appSetupUtility->connectToDatabaseServer();
|
|
if ($connection->hasError()) {
|
|
$this->getResponse()->setStatusCode(Response::HTTP_BAD_REQUEST);
|
|
return [
|
|
'error' => [
|
|
'status' => $this->getResponse()->getStatusCode(),
|
|
'message' => $connection->getErrorMessage(),
|
|
]
|
|
];
|
|
} elseif ($appSetupUtility->isDatabaseExist($dbName)) {
|
|
$this->getResponse()->setStatusCode(Response::HTTP_BAD_REQUEST);
|
|
return [
|
|
'error' => [
|
|
'status' => $this->getResponse()->getStatusCode(),
|
|
'message' => 'Database Already Exist'
|
|
]
|
|
];
|
|
} elseif (!$useSameDbUserForOrangeHRM && $appSetupUtility->isDatabaseUserExist($ohrmDbUser)) {
|
|
$this->getResponse()->setStatusCode(Response::HTTP_BAD_REQUEST);
|
|
return [
|
|
'error' => [
|
|
'status' => $this->getResponse()->getStatusCode(),
|
|
'message' => "Database User `$ohrmDbUser` Already Exist. Please Use Another Username for `OrangeHRM Database Username`."
|
|
]
|
|
];
|
|
} else {
|
|
return [
|
|
'data' => [
|
|
'dbHost' => $dbHost,
|
|
'dbPort' => $dbPort,
|
|
'dbUser' => $dbUser,
|
|
'dbName' => $dbName,
|
|
'useSameDbUserForOrangeHRM' => $useSameDbUserForOrangeHRM,
|
|
'ohrmDbUser' => $useSameDbUserForOrangeHRM ? null : ($dbInfo[StateContainer::ORANGEHRM_DB_USER] ?? null),
|
|
'enableDataEncryption' => $enableDataEncryption,
|
|
],
|
|
'meta' => []
|
|
];
|
|
}
|
|
}
|
|
|
|
// `existing` database
|
|
StateContainer::getInstance()->storeDbInfo(
|
|
$dbHost,
|
|
$dbPort,
|
|
new UserCredential($dbUser, $dbPassword),
|
|
$dbName,
|
|
null,
|
|
$enableDataEncryption
|
|
);
|
|
StateContainer::getInstance()->setDbType(AppSetupUtility::INSTALLATION_DB_TYPE_EXISTING);
|
|
|
|
$connection = $appSetupUtility->connectToDatabase();
|
|
if ($connection->hasError()) {
|
|
$this->getResponse()->setStatusCode(Response::HTTP_BAD_REQUEST);
|
|
return [
|
|
'error' => [
|
|
'status' => $this->getResponse()->getStatusCode(),
|
|
'message' => $connection->getErrorMessage(),
|
|
]
|
|
];
|
|
} elseif (!$appSetupUtility->isExistingDatabaseEmpty()) {
|
|
$this->getResponse()->setStatusCode(Response::HTTP_BAD_REQUEST);
|
|
return [
|
|
'error' => [
|
|
'status' => $this->getResponse()->getStatusCode(),
|
|
'message' => 'Provided Database Not Empty'
|
|
]
|
|
];
|
|
} else {
|
|
return [
|
|
'data' => [
|
|
'dbHost' => $dbHost,
|
|
'dbPort' => $dbPort,
|
|
'dbUser' => $dbUser,
|
|
'dbName' => $dbName,
|
|
],
|
|
'meta' => []
|
|
];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
protected function handleGet(Request $request): array
|
|
{
|
|
$dbInfo = StateContainer::getInstance()->getDbInfo();
|
|
$useSameDbUserForOrangeHRM = isset($dbInfo[StateContainer::ORANGEHRM_DB_USER]) && $dbInfo[StateContainer::DB_USER] == $dbInfo[StateContainer::ORANGEHRM_DB_USER];
|
|
return [
|
|
'data' => [
|
|
'dbHost' => $dbInfo[StateContainer::DB_HOST],
|
|
'dbPort' => $dbInfo[StateContainer::DB_PORT],
|
|
'dbName' => $dbInfo[StateContainer::DB_NAME],
|
|
'dbUser' => $dbInfo[StateContainer::DB_USER],
|
|
'dbType' => StateContainer::getInstance()->getDbType(),
|
|
'useSameDbUserForOrangeHRM' => $useSameDbUserForOrangeHRM,
|
|
'ohrmDbUser' => $useSameDbUserForOrangeHRM ? null : ($dbInfo[StateContainer::ORANGEHRM_DB_USER] ?? null),
|
|
'enableDataEncryption' => $dbInfo[StateContainer::ENABLE_DATA_ENCRYPTION],
|
|
],
|
|
'meta' => []
|
|
];
|
|
}
|
|
}
|