<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
/**
* Create user_session_log table for tracking user sessions and activity
*/
final class Version20251006100030 extends AbstractMigration
{
public function getDescription(): string
{
return 'Create user_session_log table to track user logins, logouts and session activity';
}
public function up(Schema $schema): void
{
$this->addSql('CREATE TABLE perseo.user_session_log (
id BIGINT UNSIGNED AUTO_INCREMENT NOT NULL,
user_id BIGINT UNSIGNED DEFAULT NULL,
username VARCHAR(255) DEFAULT NULL,
email VARCHAR(255) DEFAULT NULL,
login_at DATETIME NOT NULL,
logout_at DATETIME DEFAULT NULL,
last_activity_at DATETIME DEFAULT NULL,
duration INT DEFAULT NULL COMMENT \'Duration in seconds\',
ip_address VARCHAR(255) DEFAULT NULL,
user_agent VARCHAR(500) DEFAULT NULL,
session_id VARCHAR(255) NOT NULL,
deleted_at DATETIME DEFAULT NULL,
updated_at DATETIME DEFAULT \'2022-01-01 00:00:00\' NOT NULL,
created_at DATETIME DEFAULT \'2022-01-01 00:00:00\' NOT NULL,
INDEX idx_session_user_id (user_id),
INDEX idx_session_username (username),
INDEX idx_session_login_at (login_at),
INDEX idx_session_logout_at (logout_at),
INDEX idx_session_active (logout_at, last_activity_at),
INDEX idx_session_id (session_id),
PRIMARY KEY(id)
) DEFAULT CHARACTER SET utf8mb4 COLLATE `utf8mb4_unicode_ci` ENGINE = InnoDB');
$this->addSql('ALTER TABLE perseo.user_session_log
ADD CONSTRAINT FK_4DB45FC3A76ED395
FOREIGN KEY (user_id) REFERENCES perseo.user (id)
ON DELETE SET NULL');
}
public function down(Schema $schema): void
{
$this->addSql('DROP TABLE perseo.user_session_log');
}
}