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
219 lines
8.6 KiB
PHP
Executable File
219 lines
8.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\Migration\V5_6_0;
|
|
|
|
use Doctrine\DBAL\Schema\ForeignKeyConstraint;
|
|
use Doctrine\DBAL\Types\Type;
|
|
use Doctrine\DBAL\Types\Types;
|
|
use OrangeHRM\Installer\Util\Logger;
|
|
use OrangeHRM\Installer\Util\V1\AbstractMigration;
|
|
use OrangeHRM\Installer\Util\V1\LangStringHelper;
|
|
|
|
class Migration extends AbstractMigration
|
|
{
|
|
protected ?LangStringHelper $langStringHelper = null;
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function up(): void
|
|
{
|
|
$this->deleteLangStringTranslationByLangStringUnitId('amount', $this->getLangHelper()->getGroupIdByName('claim'));
|
|
|
|
$this->getLangHelper()->deleteLangStringByUnitId(
|
|
'amount',
|
|
$this->getLangHelper()->getGroupIdByName('claim')
|
|
);
|
|
|
|
$groups = ['admin', 'general'];
|
|
foreach ($groups as $group) {
|
|
$this->getLangStringHelper()->insertOrUpdateLangStrings(__DIR__, $group);
|
|
}
|
|
|
|
$this->updateLangStringVersion($this->getVersion());
|
|
|
|
$this->getSchemaHelper()->dropForeignKeys('ohrm_i18n_translate', ['langStringId']);
|
|
$foreignKeyConstraint = new ForeignKeyConstraint(
|
|
['lang_string_id'],
|
|
'ohrm_i18n_lang_string',
|
|
['id'],
|
|
'langStringId',
|
|
['onDelete' => 'CASCADE']
|
|
);
|
|
$this->getSchemaHelper()->addForeignKey('ohrm_i18n_translate', $foreignKeyConstraint);
|
|
|
|
$this->getDataGroupHelper()->insertApiPermissions(__DIR__ . '/permission/api.yaml');
|
|
|
|
if (!$this->getSchemaHelper()->tableExists(['ohrm_openid_provider'])) {
|
|
$this->getSchemaHelper()->createTable('ohrm_openid_provider')
|
|
->addColumn('id', Types::INTEGER, ['Autoincrement' => true, 'Notnull' => true, 'Length' => 10])
|
|
->addColumn('provider_name', Types::STRING, ['Notnull' => false, 'Length' => 40])
|
|
->addColumn('provider_url', Types::STRING, ['Notnull' => false, 'Length' => 255])
|
|
->addColumn('status', Types::SMALLINT, ['Notnull' => false, 'Length' => 1])
|
|
->setPrimaryKey(['id'])
|
|
->create();
|
|
}
|
|
|
|
if (!$this->getSchemaHelper()->tableExists(['ohrm_auth_provider_extra_details'])) {
|
|
$this->getSchemaHelper()->createTable('ohrm_auth_provider_extra_details')
|
|
->addColumn('id', Types::INTEGER, ['Autoincrement' => true])
|
|
->addColumn('provider_id', Types::INTEGER, ['Notnull' => true, 'Length' => 10])
|
|
->addColumn('provider_type', Types::INTEGER, ['Notnull' => false])
|
|
->addColumn('client_id', Types::TEXT)
|
|
->addColumn('client_secret', Types::TEXT)
|
|
->addColumn('developer_key', Types::TEXT)
|
|
->setPrimaryKey(['id'])
|
|
->create();
|
|
$foreignKeyConstraint = new ForeignKeyConstraint(
|
|
['provider_id'],
|
|
'ohrm_openid_provider',
|
|
['id'],
|
|
'Provider',
|
|
['onDelete' => 'CASCADE']
|
|
);
|
|
$this->getSchemaHelper()->addForeignKey('ohrm_auth_provider_extra_details', $foreignKeyConstraint);
|
|
}
|
|
|
|
if (!$this->getSchemaHelper()->tableExists(['ohrm_openid_user_identity'])) {
|
|
$this->getSchemaHelper()->createTable('ohrm_openid_user_identity')
|
|
->addColumn('user_id', Types::INTEGER, ['Length' => 10])
|
|
->addColumn('provider_id', Types::INTEGER, ['Length' => 10])
|
|
->addColumn('user_identity', Types::STRING, ['Notnull' => false, 'Default' => null, 'Length' => 255])
|
|
->setPrimaryKey(['user_id'])
|
|
->create();
|
|
$foreignKeyConstraint1 = new ForeignKeyConstraint(
|
|
['provider_id'],
|
|
'ohrm_openid_provider',
|
|
['id'],
|
|
'provideId',
|
|
['onDelete' => 'CASCADE']
|
|
);
|
|
$this->getSchemaHelper()->addForeignKey('ohrm_openid_user_identity', $foreignKeyConstraint1);
|
|
$foreignKeyConstraint2 = new ForeignKeyConstraint(
|
|
['user_id'],
|
|
'ohrm_user',
|
|
['id'],
|
|
'providerUserId',
|
|
['onDelete' => 'SET NULL']
|
|
);
|
|
$this->getSchemaHelper()->addForeignKey('ohrm_claim_request', $foreignKeyConstraint2);
|
|
}
|
|
|
|
$this->modifyAuthProviderTables();
|
|
$this->removeOpenIdProviders();
|
|
}
|
|
|
|
/**
|
|
* @inheritDoc
|
|
*/
|
|
public function getVersion(): string
|
|
{
|
|
return '5.6.0';
|
|
}
|
|
|
|
private function updateLangStringVersion(string $version): void
|
|
{
|
|
$qb = $this->createQueryBuilder()
|
|
->update('ohrm_i18n_lang_string', 'lang_string')
|
|
->set('lang_string.version', ':version')
|
|
->setParameter('version', $version);
|
|
$qb->andWhere($qb->expr()->isNull('lang_string.version'))
|
|
->executeStatement();
|
|
}
|
|
|
|
private function modifyAuthProviderTables(): void
|
|
{
|
|
$this->getSchemaHelper()->addOrChangeColumns('ohrm_openid_provider', [
|
|
'provider_url' => [
|
|
'Type' => Type::getType(Types::STRING),
|
|
'Length' => 2000
|
|
],
|
|
'status' => [
|
|
'Type' => Type::getType(Types::BOOLEAN),
|
|
'Notnull' => true,
|
|
'Default' => true,
|
|
'CustomSchemaOptions' => ['collation' => null, 'charset' => null]
|
|
],
|
|
]);
|
|
}
|
|
|
|
private function getLangStringHelper(): LangStringHelper
|
|
{
|
|
if (is_null($this->langStringHelper)) {
|
|
$this->langStringHelper = new LangStringHelper(
|
|
$this->getConnection()
|
|
);
|
|
}
|
|
return $this->langStringHelper;
|
|
}
|
|
|
|
private function removeOpenIdProviders(): void
|
|
{
|
|
$q = $this->createQueryBuilder();
|
|
$q->select(['extraDetails.provider_id, extraDetails.provider_type'])
|
|
->from('ohrm_auth_provider_extra_details', 'extraDetails');
|
|
$providers = $q->executeQuery();
|
|
|
|
foreach ($providers->fetchAllAssociative() as $provider) {
|
|
$providerType = $provider['provider_type'];
|
|
if ($providerType == 2) {
|
|
$this->changeGoogleProviderURL($provider['provider_id']);
|
|
} else {
|
|
$serializedProvider = serialize($provider);
|
|
Logger::getLogger()->info("Deleting: `$serializedProvider` ` from `ohrm_openid_provider`");
|
|
$qb = $this->createQueryBuilder()
|
|
->delete('ohrm_openid_provider')
|
|
->andWhere('ohrm_openid_provider.id = :id')
|
|
->setParameter('id', $provider['provider_id']);
|
|
$qb->executeQuery();
|
|
}
|
|
}
|
|
}
|
|
|
|
private function changeGoogleProviderURL(int $providerId): void
|
|
{
|
|
$qb = $this->createQueryBuilder();
|
|
$qb->update('ohrm_openid_provider', 'provider')
|
|
->set('provider.provider_url', ':providerUrl')
|
|
->setParameter('providerUrl', 'https://accounts.google.com')
|
|
->andWhere('provider.id = :id')
|
|
->setParameter('id', $providerId);
|
|
$qb->executeQuery();
|
|
}
|
|
|
|
private function deleteLangStringTranslationByLangStringUnitId(string $unitId, int $groupId): void
|
|
{
|
|
$id = $this->getConnection()->createQueryBuilder()
|
|
->select('id')
|
|
->from('ohrm_i18n_lang_string', 'langString')
|
|
->andWhere('langString.unit_id = :unitId')
|
|
->setParameter('unitId', $unitId)
|
|
->andWhere('langString.group_id = :groupId')
|
|
->setParameter('groupId', $groupId)
|
|
->executeQuery()
|
|
->fetchOne();
|
|
|
|
$this->createQueryBuilder()
|
|
->delete('ohrm_i18n_translate')
|
|
->andWhere('ohrm_i18n_translate.lang_string_id = :id')
|
|
->setParameter('id', $id)
|
|
->executeQuery();
|
|
}
|
|
}
|