From 14542b6e3379024fa943ac7f1b4e4d9f1bf4b083 Mon Sep 17 00:00:00 2001 From: Marcel Date: Sun, 17 May 2026 19:16:25 +0200 Subject: [PATCH] =?UTF-8?q?migration:=20V67=20=E2=80=94=20recreate=20sprin?= =?UTF-8?q?g=5Fsession=20tables=20(ADR-020)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Re-introduces tables dropped by V2. Canonical DDL from Spring Session 3.x schema-postgresql.sql. Co-Authored-By: Claude Sonnet 4.6 --- .../V67__recreate_spring_session_tables.sql | 27 +++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 backend/src/main/resources/db/migration/V67__recreate_spring_session_tables.sql diff --git a/backend/src/main/resources/db/migration/V67__recreate_spring_session_tables.sql b/backend/src/main/resources/db/migration/V67__recreate_spring_session_tables.sql new file mode 100644 index 00000000..cde53a67 --- /dev/null +++ b/backend/src/main/resources/db/migration/V67__recreate_spring_session_tables.sql @@ -0,0 +1,27 @@ +-- Re-introduces the Spring Session JDBC tables that were dropped by V2 as unused. +-- DDL copied verbatim from Spring Session 3.x schema-postgresql.sql. +-- See ADR-020 and issue #523. + +CREATE TABLE spring_session ( + PRIMARY_ID CHAR(36) NOT NULL, + SESSION_ID CHAR(36) NOT NULL, + CREATION_TIME BIGINT NOT NULL, + LAST_ACCESS_TIME BIGINT NOT NULL, + MAX_INACTIVE_INTERVAL INT NOT NULL, + EXPIRY_TIME BIGINT NOT NULL, + PRINCIPAL_NAME VARCHAR(100), + CONSTRAINT spring_session_pk PRIMARY KEY (PRIMARY_ID) +); + +CREATE UNIQUE INDEX spring_session_ix1 ON spring_session (SESSION_ID); +CREATE INDEX spring_session_ix2 ON spring_session (EXPIRY_TIME); +CREATE INDEX spring_session_ix3 ON spring_session (PRINCIPAL_NAME); + +CREATE TABLE spring_session_attributes ( + SESSION_PRIMARY_ID CHAR(36) NOT NULL, + ATTRIBUTE_NAME VARCHAR(200) NOT NULL, + ATTRIBUTE_BYTES BYTEA NOT NULL, + CONSTRAINT spring_session_attributes_pk PRIMARY KEY (SESSION_PRIMARY_ID, ATTRIBUTE_NAME), + CONSTRAINT spring_session_attributes_fk FOREIGN KEY (SESSION_PRIMARY_ID) + REFERENCES spring_session (PRIMARY_ID) ON DELETE CASCADE +);