<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
/**
* Auto-generated Migration: Please modify to your needs!
*/
final class Version20260226192422 extends AbstractMigration
{
public function getDescription(): string
{
return '';
}
public function up(Schema $schema): void
{
// this up() migration is auto-generated, please modify it to your needs
$this->addSql('CREATE TABLE zkbio_sync (id INT AUTO_INCREMENT NOT NULL, establishment_id INT NOT NULL, sync_uid VARCHAR(60) NOT NULL, period_start DATE NOT NULL, period_end DATE NOT NULL, status VARCHAR(20) NOT NULL, fetched_count INT NOT NULL, inserted_count INT NOT NULL, skipped_count INT NOT NULL, error_message LONGTEXT DEFAULT NULL, started_at DATETIME DEFAULT NULL, completed_at DATETIME DEFAULT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', UNIQUE INDEX UNIQ_1EB9035DEDD57FB5 (sync_uid), INDEX IDX_1EB9035D8565851 (establishment_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('CREATE TABLE zkbio_transactions (id INT AUTO_INCREMENT NOT NULL, sync_id INT NOT NULL, establishment_id INT NOT NULL, rh_salary_id INT DEFAULT NULL, emp_code VARCHAR(60) NOT NULL, terminal_sn VARCHAR(60) DEFAULT NULL, terminal_alias VARCHAR(100) DEFAULT NULL, punch_time DATETIME NOT NULL, punch_state SMALLINT NOT NULL, verify_type SMALLINT DEFAULT NULL, zkbio_id INT DEFAULT NULL, is_processed TINYINT(1) NOT NULL, created_at DATETIME NOT NULL COMMENT \'(DC2Type:datetime_immutable)\', UNIQUE INDEX UNIQ_95FA224EFA580A34 (zkbio_id), INDEX IDX_95FA224E8565851 (establishment_id), INDEX IDX_95FA224E4758967C (rh_salary_id), INDEX idx_zkbio_emp_code (emp_code), INDEX idx_zkbio_punch_time (punch_time), INDEX idx_zkbio_sync (sync_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('ALTER TABLE zkbio_sync ADD CONSTRAINT FK_1EB9035D8565851 FOREIGN KEY (establishment_id) REFERENCES establishment (id)');
$this->addSql('ALTER TABLE zkbio_transactions ADD CONSTRAINT FK_95FA224EFA50C422 FOREIGN KEY (sync_id) REFERENCES zkbio_sync (id)');
$this->addSql('ALTER TABLE zkbio_transactions ADD CONSTRAINT FK_95FA224E8565851 FOREIGN KEY (establishment_id) REFERENCES establishment (id)');
$this->addSql('ALTER TABLE zkbio_transactions ADD CONSTRAINT FK_95FA224E4758967C FOREIGN KEY (rh_salary_id) REFERENCES rh_salary (id)');
$this->addSql('ALTER TABLE bank_transaction ADD is_cancelled TINYINT(1) NOT NULL, ADD cancelled_at DATETIME DEFAULT NULL, ADD cancelled_by INT DEFAULT NULL, ADD cancel_reason VARCHAR(500) DEFAULT NULL');
$this->addSql('ALTER TABLE establishment ADD zkbio_server_ip VARCHAR(64) DEFAULT NULL, ADD zkbio_server_port INT DEFAULT NULL, ADD zkbio_username VARCHAR(128) DEFAULT NULL, ADD zkbio_password VARCHAR(128) DEFAULT NULL, ADD zkbio_default_area_id INT DEFAULT NULL');
$this->addSql('ALTER TABLE rh_department ADD zkbio_dept_code VARCHAR(60) DEFAULT NULL');
$this->addSql('ALTER TABLE rh_job ADD zkbio_position_code VARCHAR(60) DEFAULT NULL');
$this->addSql('ALTER TABLE rh_salary ADD zkbio_emp_code VARCHAR(60) DEFAULT NULL');
$this->addSql('ALTER TABLE school_year ADD begin_at DATE DEFAULT NULL COMMENT \'(DC2Type:date_immutable)\', ADD end_at DATE DEFAULT NULL COMMENT \'(DC2Type:date_immutable)\'');
}
public function down(Schema $schema): void
{
// this down() migration is auto-generated, please modify it to your needs
$this->addSql('ALTER TABLE zkbio_transactions DROP FOREIGN KEY FK_95FA224EFA50C422');
$this->addSql('DROP TABLE zkbio_sync');
$this->addSql('DROP TABLE zkbio_transactions');
$this->addSql('ALTER TABLE bank_transaction DROP is_cancelled, DROP cancelled_at, DROP cancelled_by, DROP cancel_reason');
$this->addSql('ALTER TABLE establishment DROP zkbio_server_ip, DROP zkbio_server_port, DROP zkbio_username, DROP zkbio_password, DROP zkbio_default_area_id');
$this->addSql('ALTER TABLE rh_department DROP zkbio_dept_code');
$this->addSql('ALTER TABLE rh_job DROP zkbio_position_code');
$this->addSql('ALTER TABLE rh_salary DROP zkbio_emp_code');
$this->addSql('ALTER TABLE school_year DROP begin_at, DROP end_at');
}
}