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
121 lines
3.9 KiB
PHP
Executable File
121 lines
3.9 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_0_0;
|
|
|
|
use Doctrine\DBAL\Connection;
|
|
use Doctrine\DBAL\Query\QueryBuilder;
|
|
|
|
class AttendanceHelper
|
|
{
|
|
public const TIMEZONE_MAP = [
|
|
'Kwajalein' => '-12.00',
|
|
'Pacific/Midway' => '-11.00',
|
|
'Pacific/Honolulu' => '-10.00',
|
|
'America/Anchorage' => '-9.00',
|
|
'America/Los_Angeles' => '-8.00',
|
|
'America/Denver' => '-7.00',
|
|
'America/Tegucigalpa' => '-6.00',
|
|
'America/New_York' => '-5.00',
|
|
'America/Caracas' => '-4.50',
|
|
'America/Halifax' => -'4.00',
|
|
'America/St_Johns' => '-3.50',
|
|
'America/Argentina/Buenos_Aires' => '-3.00',
|
|
'America/Sao_Paulo' => '-3.00',
|
|
'Atlantic/South_Georgia' => '-2.00',
|
|
'Atlantic/Azores' => '-1.00',
|
|
'Europe/Dublin' => '0',
|
|
'Europe/Belgrade' => '1.00',
|
|
'Europe/Minsk' => '2.00',
|
|
'Asia/Kuwait' => '3.00',
|
|
'Asia/Tehran' => '3.50',
|
|
'Asia/Muscat' => '4.00',
|
|
'Asia/Yekaterinburg' => '5.00',
|
|
'Asia/Kolkata' => '5.5',
|
|
'Asia/Katmandu' => '5.45',
|
|
'Asia/Dhaka' => '6.00',
|
|
'Asia/Rangoon' => '6.50',
|
|
'Asia/Krasnoyarsk' => '7.00',
|
|
'Asia/Brunei' => '8.00',
|
|
'Asia/Seoul' => '9.00',
|
|
'Australia/Darwin' => '9.50',
|
|
'Australia/Canberra' => '10.00',
|
|
'Asia/Magadan' => '11.00',
|
|
'Pacific/Fiji' => '12.00',
|
|
'Pacific/Tongatapu' => '13.00'
|
|
];
|
|
|
|
private Connection $connection;
|
|
|
|
/**
|
|
* @param Connection $connection
|
|
*/
|
|
public function __construct(Connection $connection)
|
|
{
|
|
$this->connection = $connection;
|
|
}
|
|
|
|
/**
|
|
* @return Connection
|
|
*/
|
|
protected function getConnection(): Connection
|
|
{
|
|
return $this->connection;
|
|
}
|
|
|
|
/**
|
|
* @return QueryBuilder
|
|
*/
|
|
protected function createQueryBuilder(): QueryBuilder
|
|
{
|
|
return $this->getConnection()->createQueryBuilder();
|
|
}
|
|
|
|
/**
|
|
* @param string $offset
|
|
* @param string $timezone
|
|
* @return void
|
|
*/
|
|
public function updatePunchInTimezoneOffset(string $offset, string $timezone): void
|
|
{
|
|
$q = $this->createQueryBuilder();
|
|
$q->update('ohrm_attendance_record')
|
|
->set('ohrm_attendance_record.punch_in_timezone_name', ':punchInTimezone')
|
|
->where('ohrm_attendance_record.punch_in_time_offset = :offset')
|
|
->setParameter('punchInTimezone', $timezone)
|
|
->setParameter('offset', $offset)
|
|
->executeQuery();
|
|
}
|
|
|
|
/**
|
|
* @param string $offset
|
|
* @param string $timezone
|
|
* @return void
|
|
*/
|
|
public function updatePunchOutTimezoneOffset(string $offset, string $timezone): void
|
|
{
|
|
$q = $this->createQueryBuilder();
|
|
$q->update('ohrm_attendance_record')
|
|
->set('ohrm_attendance_record.punch_out_timezone_name', ':punchOutTimezone')
|
|
->where('ohrm_attendance_record.punch_out_time_offset = :offset')
|
|
->setParameter('punchOutTimezone', $timezone)
|
|
->setParameter('offset', $offset)
|
|
->executeQuery();
|
|
}
|
|
}
|