Workforce/orangehrm-5.7/installer/Util/V1/LanguageHelper.php
rajesh.n 8e294d7c5b
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
first commit
2025-10-10 15:31:35 +05:30

191 lines
6.3 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\Util\V1;
use Doctrine\DBAL\Connection;
use Doctrine\DBAL\ParameterType;
use OrangeHRM\Installer\Util\V1\Dto\LangString;
use Symfony\Component\Yaml\Yaml;
class LanguageHelper
{
private Connection $connection;
private array $groupIds = [];
/**
* @param Connection $connection
*/
public function __construct(Connection $connection)
{
$this->connection = $connection;
}
/**
* @return Connection
*/
protected function getConnection(): Connection
{
return $this->connection;
}
/**
* @param string $filepath
* @param string $groupName
* @return LangString[]
*/
public function readLangStrings(string $filepath, string $groupName): array
{
$langStrings = [];
$groupId = $this->getGroupIdByName($groupName);
foreach (Yaml::parseFile($filepath)['langStrings'] as $langString) {
$langString['groupId'] = $groupId;
$langStrings[] = LangString::createFromArray($langString);
}
return $langStrings;
}
/**
* @param string $groupName
* @return int
*/
public function getGroupIdByName(string $groupName): int
{
if (!isset($this->groupIds[$groupName])) {
$qb = $this->getConnection()->createQueryBuilder()
->select('i18nGroup.id')
->from('ohrm_i18n_group', 'i18nGroup')
->where('i18nGroup.name = :groupName')
->setParameter('groupName', $groupName)
->setMaxResults(1);
$this->groupIds[$groupName] = $qb->fetchOne();
}
return $this->groupIds[$groupName];
}
/**
* @param string $unitId
* @param int|null $groupId
*/
public function deleteLangStringByUnitId(string $unitId, ?int $groupId = null)
{
$qb = $this->getConnection()->createQueryBuilder()
->delete('ohrm_i18n_lang_string')
->andWhere('ohrm_i18n_lang_string.unit_id = :unitId')
->setParameter('unitId', $unitId);
if (!is_null($groupId)) {
$qb->andWhere('ohrm_i18n_lang_string.group_id = :groupId')
->setParameter('groupId', $groupId);
}
$qb->executeQuery();
}
/**
* @param int $langId
* @param int $langStringId
* @param string|null $translation
*/
public function insertTranslation(int $langId, int $langStringId, ?string $translation): void
{
$this->getConnection()->createQueryBuilder()
->insert('ohrm_i18n_translate')
->values([
'lang_string_id' => ':langStringId',
'language_id' => ':langId',
'value' => ':translation',
])
->setParameter('langStringId', $langStringId)
->setParameter('langId', $langId)
->setParameter('translation', $translation)
->executeQuery();
}
/**
* @param string $langCode
* @return int|null
*/
public function getLanguageIdByLangCode(string $langCode): ?int
{
return $this->getConnection()->createQueryBuilder()
->select('ohrm_i18n_language.id')
->from('ohrm_i18n_language')
->where('ohrm_i18n_language.code = :langCode')
->setParameter('langCode', $langCode)
->executeQuery()
->fetchOne() ?: null;
}
/**
* @param string $langCode
* @param bool $enable
* @param bool $add
*/
public function updateLanguageStatusByLangCode(string $langCode, bool $enable, bool $add): void
{
$this->getConnection()->createQueryBuilder()
->update('ohrm_i18n_language')
->set('ohrm_i18n_language.enabled', ':enabled')
->set('ohrm_i18n_language.added', ':added')
->where('ohrm_i18n_language.code = :langCode')
->setParameter('enabled', $enable, ParameterType::BOOLEAN)
->setParameter('added', $add, ParameterType::BOOLEAN)
->setParameter('langCode', $langCode)
->executeQuery();
}
public function createTestLanguagePack(): void
{
$this->updateLanguageStatusByLangCode('zz_ZZ', true, true);
$testLangId = $this->getLanguageIdByLangCode('zz_ZZ');
$offset = 0;
$limit = 50;
$done = false;
do {
$langStrings = $this->getConnection()->createQueryBuilder()
->select('ohrm_i18n_lang_string.id', 'ohrm_i18n_lang_string.value')
->from('ohrm_i18n_lang_string')
->setFirstResult($offset)
->setMaxResults($limit)
->executeQuery()
->fetchAllAssociative();
foreach ($langStrings as $langString) {
$translation = 'tr_' . $langString['value'] ?? '';
$this->insertTranslation($testLangId, $langString['id'], $translation);
}
$offset += $limit;
if (count($langStrings) < $limit) {
$done = true;
}
} while (!$done);
}
public function deleteTestLanguagePack(): void
{
$this->updateLanguageStatusByLangCode('zz_ZZ', false, false);
$testLangId = $this->getLanguageIdByLangCode('zz_ZZ');
$this->getConnection()->createQueryBuilder()
->delete('ohrm_i18n_translate')
->where('ohrm_i18n_translate.language_id = :languageId')
->setParameter('languageId', $testLangId)
->executeQuery();
}
}