From 5190da988f9b40d016b4d9c211aef7907c47f268 Mon Sep 17 00:00:00 2001 From: Jack Golding Date: Tue, 15 Oct 2024 15:00:46 +0100 Subject: [PATCH 1/2] feat: Add fall back for publication pattern numbering Added sequence to be used as fallback for serial ruleset numbering and implemented into the rulesets beforeValidate function --- .../domain/org/olf/SerialRuleset.groovy | 22 ++++++++++++++++++- .../update-mod-serials-management-1-1.groovy | 4 ++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/service/grails-app/domain/org/olf/SerialRuleset.groovy b/service/grails-app/domain/org/olf/SerialRuleset.groovy index 998d508..fb523f7 100644 --- a/service/grails-app/domain/org/olf/SerialRuleset.groovy +++ b/service/grails-app/domain/org/olf/SerialRuleset.groovy @@ -76,5 +76,25 @@ class SerialRuleset implements MultiTenant { omission nullable: true combination nullable: true templateConfig nullable: true - } + } + + def beforeValidate() { + if ( rulesetNumber == null ) { + this.rulesetNumber = generateHrid() + } + } + + private String generateHrid() { + String result = null; + + // Use this to make sessionFactory.currentSession work as expected + PublicationRequest.withSession { SessionImpl session -> + log.debug("Generate hrid"); + def sql = new Sql(session.connection()) + def query_result = sql.rows("select nextval('serial_ruleset_hrid_seq')".toString()) + log.debug("Query result: ${query_result.toString()}") + result = query_result[0].get('nextval')?.toString() + } + return result; + } } diff --git a/service/grails-app/migrations/update-mod-serials-management-1-1.groovy b/service/grails-app/migrations/update-mod-serials-management-1-1.groovy index 30ded0e..84e0cc6 100644 --- a/service/grails-app/migrations/update-mod-serials-management-1-1.groovy +++ b/service/grails-app/migrations/update-mod-serials-management-1-1.groovy @@ -81,4 +81,8 @@ databaseChangeLog = { column(name: "eluctmt_value_format_fk", type: "VARCHAR(36)") { constraints(nullable: "true") } } } + + changeSet(author: "Jack-Golding (manual)", id: "20241015-1457-001") { + createSequence(sequenceName: "serial_ruleset_hrid_seq") + } } \ No newline at end of file From 7e3c8ff12abf2fbe30982209a53f2367e3079e53 Mon Sep 17 00:00:00 2001 From: Jack Golding Date: Tue, 15 Oct 2024 15:06:24 +0100 Subject: [PATCH 2/2] fix: Incorrect class Fixed error with incorrect class being used --- service/grails-app/domain/org/olf/SerialRuleset.groovy | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/service/grails-app/domain/org/olf/SerialRuleset.groovy b/service/grails-app/domain/org/olf/SerialRuleset.groovy index fb523f7..fa99662 100644 --- a/service/grails-app/domain/org/olf/SerialRuleset.groovy +++ b/service/grails-app/domain/org/olf/SerialRuleset.groovy @@ -88,7 +88,7 @@ class SerialRuleset implements MultiTenant { String result = null; // Use this to make sessionFactory.currentSession work as expected - PublicationRequest.withSession { SessionImpl session -> + SerialRuleset.withSession { SessionImpl session -> log.debug("Generate hrid"); def sql = new Sql(session.connection()) def query_result = sql.rows("select nextval('serial_ruleset_hrid_seq')".toString())