diff --git a/bom/application/pom.xml b/bom/application/pom.xml index 3718d72ac7c9b..197ccbbe85a4b 100644 --- a/bom/application/pom.xml +++ b/bom/application/pom.xml @@ -168,7 +168,9 @@ 1.1.1 9.21.2 3.0.3 - 4.20.0 + + 4.23.1 + 4.23.0 2.1 6.0.0 4.10.2 @@ -5900,6 +5902,10 @@ javax.xml.bind jaxb-api + + javax.activation + * + @@ -5911,7 +5917,7 @@ org.liquibase.ext liquibase-mongodb - ${liquibase.version} + ${liquibase-mongodb.version} org.codehaus.groovy diff --git a/extensions/liquibase-mongodb/deployment/src/main/java/io/quarkus/liquibase/mongodb/deployment/LiquibaseMongodbProcessor.java b/extensions/liquibase-mongodb/deployment/src/main/java/io/quarkus/liquibase/mongodb/deployment/LiquibaseMongodbProcessor.java index 64eb0713a8faf..f043f34fb046f 100644 --- a/extensions/liquibase-mongodb/deployment/src/main/java/io/quarkus/liquibase/mongodb/deployment/LiquibaseMongodbProcessor.java +++ b/extensions/liquibase-mongodb/deployment/src/main/java/io/quarkus/liquibase/mongodb/deployment/LiquibaseMongodbProcessor.java @@ -33,10 +33,10 @@ import io.quarkus.deployment.builditem.ApplicationInfoBuildItem; import io.quarkus.deployment.builditem.CombinedIndexBuildItem; import io.quarkus.deployment.builditem.FeatureBuildItem; +import io.quarkus.deployment.builditem.IndexDependencyBuildItem; import io.quarkus.deployment.builditem.InitTaskBuildItem; import io.quarkus.deployment.builditem.InitTaskCompletedBuildItem; import io.quarkus.deployment.builditem.ServiceStartBuildItem; -import io.quarkus.deployment.builditem.SystemPropertyBuildItem; import io.quarkus.deployment.builditem.nativeimage.NativeImageResourceBuildItem; import io.quarkus.deployment.builditem.nativeimage.NativeImageResourceBundleBuildItem; import io.quarkus.deployment.builditem.nativeimage.ReflectiveClassBuildItem; @@ -61,6 +61,7 @@ import liquibase.exception.LiquibaseException; import liquibase.parser.ChangeLogParser; import liquibase.parser.ChangeLogParserFactory; +import liquibase.plugin.AbstractPluginFactory; import liquibase.resource.ClassLoaderResourceAccessor; class LiquibaseMongodbProcessor { @@ -74,12 +75,11 @@ FeatureBuildItem feature() { return new FeatureBuildItem(Feature.LIQUIBASE_MONGODB); } - @BuildStep - public SystemPropertyBuildItem disableHub() { - // Don't block app startup with prompt: - // Do you want to see this operation's report in Liquibase Hub, which improves team collaboration? - // If so, enter your email. If not, enter [N] to no longer be prompted, or [S] to skip for now, but ask again next time (default "S"): - return new SystemPropertyBuildItem("liquibase.hub.mode", "off"); + @BuildStep(onlyIf = NativeOrNativeSourcesBuild.class) + List indexLiquibase() { + return List.of( + new IndexDependencyBuildItem("org.liquibase", "liquibase-core"), + new IndexDependencyBuildItem("org.liquibase.ext", "liquibase-mongodb")); } @BuildStep(onlyIf = NativeOrNativeSourcesBuild.class) @@ -103,18 +103,23 @@ void nativeImageConfiguration( liquibase.database.jvm.JdbcConnection.class.getName()) .methods().build()); + reflective.produce(ReflectiveClassBuildItem + .builder(combinedIndex.getIndex().getAllKnownSubclasses(AbstractPluginFactory.class).stream() + .map(classInfo -> classInfo.name().toString()) + .toArray(String[]::new)) + .constructors().build()); + + reflective.produce(ReflectiveClassBuildItem + .builder(liquibase.command.CommandFactory.class.getName(), + // deprecated, but still used by liquibase.nosql.lockservice.AbstractNoSqlLockService + liquibase.configuration.GlobalConfiguration.class.getName()) + .constructors().build()); + reflective.produce(ReflectiveClassBuildItem.builder( liquibase.parser.ChangeLogParserConfiguration.class.getName(), - liquibase.hub.HubServiceFactory.class.getName(), - liquibase.logging.core.DefaultLoggerConfiguration.class.getName(), - // deprecated, but still used by liquibase.nosql.lockservice.AbstractNoSqlLockService - liquibase.configuration.GlobalConfiguration.class.getName(), liquibase.GlobalConfiguration.class.getName(), - liquibase.license.LicenseServiceFactory.class.getName(), liquibase.executor.ExecutorService.class.getName(), liquibase.change.ChangeFactory.class.getName(), - liquibase.logging.core.LogServiceFactory.class.getName(), - liquibase.logging.LogFactory.class.getName(), liquibase.change.ColumnConfig.class.getName(), liquibase.change.AddColumnConfig.class.getName(), liquibase.change.core.LoadDataColumnConfig.class.getName(), @@ -122,9 +127,7 @@ void nativeImageConfiguration( liquibase.sql.visitor.ReplaceSqlVisitor.class.getName(), liquibase.sql.visitor.AppendSqlVisitor.class.getName(), liquibase.sql.visitor.RegExpReplaceSqlVisitor.class.getName(), - liquibase.ext.mongodb.database.MongoClientDriver.class.getName(), - liquibase.resource.PathHandlerFactory.class.getName(), - liquibase.logging.mdc.MdcManagerFactory.class.getName()) + liquibase.ext.mongodb.database.MongoClientDriver.class.getName()) .constructors().methods().fields().build()); reflective.produce(ReflectiveClassBuildItem.builder( @@ -170,7 +173,6 @@ void nativeImageConfiguration( liquibase.snapshot.SnapshotGenerator.class, liquibase.sqlgenerator.SqlGenerator.class, liquibase.structure.DatabaseObject.class, - liquibase.hub.HubService.class, liquibase.logging.mdc.MdcManager.class) .forEach(t -> addService(services, reflective, t, false)); @@ -196,6 +198,10 @@ void nativeImageConfiguration( "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.17.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.18.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.19.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.20.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.21.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.22.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.23.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-latest.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd", "liquibase.build.properties")); diff --git a/extensions/liquibase-mongodb/runtime/src/main/java/io/quarkus/liquibase/mongodb/LiquibaseMongodbFactory.java b/extensions/liquibase-mongodb/runtime/src/main/java/io/quarkus/liquibase/mongodb/LiquibaseMongodbFactory.java index e8744a52b193a..e98532a448bae 100644 --- a/extensions/liquibase-mongodb/runtime/src/main/java/io/quarkus/liquibase/mongodb/LiquibaseMongodbFactory.java +++ b/extensions/liquibase-mongodb/runtime/src/main/java/io/quarkus/liquibase/mongodb/LiquibaseMongodbFactory.java @@ -3,6 +3,7 @@ import java.util.Map; import java.util.regex.Matcher; import java.util.regex.Pattern; +import java.util.stream.Collectors; import io.quarkus.liquibase.mongodb.runtime.LiquibaseMongodbBuildTimeConfig; import io.quarkus.liquibase.mongodb.runtime.LiquibaseMongodbConfig; @@ -91,7 +92,9 @@ public LiquibaseMongodbConfig getConfiguration() { * @return the label expression */ public LabelExpression createLabels() { - return new LabelExpression(liquibaseMongodbConfig.labels.orElse(null)); + // need to join because of https://github.com/liquibase/liquibase/issues/4763 + return new LabelExpression( + liquibaseMongodbConfig.labels.map(labels -> labels.stream().collect(Collectors.joining(","))).orElse(null)); } /** diff --git a/extensions/liquibase/deployment/src/main/java/io/quarkus/liquibase/deployment/LiquibaseProcessor.java b/extensions/liquibase/deployment/src/main/java/io/quarkus/liquibase/deployment/LiquibaseProcessor.java index 4d6c65e2b30f5..52b2e76afd401 100644 --- a/extensions/liquibase/deployment/src/main/java/io/quarkus/liquibase/deployment/LiquibaseProcessor.java +++ b/extensions/liquibase/deployment/src/main/java/io/quarkus/liquibase/deployment/LiquibaseProcessor.java @@ -49,7 +49,6 @@ import io.quarkus.deployment.builditem.InitTaskBuildItem; import io.quarkus.deployment.builditem.InitTaskCompletedBuildItem; import io.quarkus.deployment.builditem.ServiceStartBuildItem; -import io.quarkus.deployment.builditem.SystemPropertyBuildItem; import io.quarkus.deployment.builditem.nativeimage.NativeImageResourceBuildItem; import io.quarkus.deployment.builditem.nativeimage.NativeImageResourceBundleBuildItem; import io.quarkus.deployment.builditem.nativeimage.ReflectiveClassBuildItem; @@ -75,6 +74,7 @@ import liquibase.exception.LiquibaseException; import liquibase.parser.ChangeLogParser; import liquibase.parser.ChangeLogParserFactory; +import liquibase.plugin.AbstractPluginFactory; import liquibase.resource.ClassLoaderResourceAccessor; class LiquibaseProcessor { @@ -90,14 +90,6 @@ FeatureBuildItem feature() { return new FeatureBuildItem(Feature.LIQUIBASE); } - @BuildStep - public SystemPropertyBuildItem disableHub() { - // Don't block app startup with prompt: - // Do you want to see this operation's report in Liquibase Hub, which improves team collaboration? - // If so, enter your email. If not, enter [N] to no longer be prompted, or [S] to skip for now, but ask again next time (default "S"): - return new SystemPropertyBuildItem("liquibase.hub.mode", "off"); - } - @BuildStep(onlyIf = NativeOrNativeSourcesBuild.class) IndexDependencyBuildItem indexLiquibase() { return new IndexDependencyBuildItem("org.liquibase", "liquibase-core"); @@ -126,29 +118,26 @@ void nativeImageConfiguration( .build()); reflective.produce(ReflectiveClassBuildItem - .builder("liquibase.command.LiquibaseCommandFactory", - liquibase.command.CommandFactory.class.getName()) + .builder(combinedIndex.getIndex().getAllKnownSubclasses(AbstractPluginFactory.class).stream() + .map(classInfo -> classInfo.name().toString()) + .toArray(String[]::new)) + .constructors().build()); + + reflective.produce(ReflectiveClassBuildItem + .builder(liquibase.command.CommandFactory.class.getName()) .constructors().build()); reflective.produce(ReflectiveClassBuildItem.builder( liquibase.parser.ChangeLogParserConfiguration.class.getName(), - liquibase.hub.HubServiceFactory.class.getName(), - liquibase.logging.core.DefaultLoggerConfiguration.class.getName(), liquibase.GlobalConfiguration.class.getName(), - liquibase.license.LicenseServiceFactory.class.getName(), liquibase.executor.ExecutorService.class.getName(), - liquibase.change.ChangeFactory.class.getName(), - liquibase.logging.core.LogServiceFactory.class.getName(), - liquibase.logging.LogFactory.class.getName(), liquibase.change.ColumnConfig.class.getName(), liquibase.change.AddColumnConfig.class.getName(), liquibase.change.core.LoadDataColumnConfig.class.getName(), liquibase.sql.visitor.PrependSqlVisitor.class.getName(), liquibase.sql.visitor.ReplaceSqlVisitor.class.getName(), liquibase.sql.visitor.AppendSqlVisitor.class.getName(), - liquibase.sql.visitor.RegExpReplaceSqlVisitor.class.getName(), - liquibase.resource.PathHandlerFactory.class.getName(), - liquibase.logging.mdc.MdcManagerFactory.class.getName()) + liquibase.sql.visitor.RegExpReplaceSqlVisitor.class.getName()) .constructors().methods().fields().build()); reflective.produce(ReflectiveClassBuildItem.builder( @@ -201,7 +190,6 @@ void nativeImageConfiguration( liquibase.snapshot.SnapshotGenerator.class, liquibase.sqlgenerator.SqlGenerator.class, liquibase.structure.DatabaseObject.class, - liquibase.hub.HubService.class, liquibase.logging.mdc.MdcManager.class) .forEach(t -> consumeService(t, (serviceClass, implementations) -> { services.produce( @@ -244,6 +232,10 @@ void nativeImageConfiguration( "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.17.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.18.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.19.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.20.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.21.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.22.xsd", + "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-4.23.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-latest.xsd", "www.liquibase.org/xml/ns/dbchangelog/dbchangelog-ext.xsd", "liquibase.build.properties")); diff --git a/extensions/liquibase/runtime/src/main/java/io/quarkus/liquibase/LiquibaseFactory.java b/extensions/liquibase/runtime/src/main/java/io/quarkus/liquibase/LiquibaseFactory.java index 00b34a5af882c..dd66fe3cb15ac 100644 --- a/extensions/liquibase/runtime/src/main/java/io/quarkus/liquibase/LiquibaseFactory.java +++ b/extensions/liquibase/runtime/src/main/java/io/quarkus/liquibase/LiquibaseFactory.java @@ -1,6 +1,7 @@ package io.quarkus.liquibase; import java.util.Map; +import java.util.stream.Collectors; import javax.sql.DataSource; @@ -71,7 +72,10 @@ public LiquibaseConfig getConfiguration() { * @return the label expression */ public LabelExpression createLabels() { - return new LabelExpression(config.labels); + // need to join because of https://github.com/liquibase/liquibase/issues/4763 + return new LabelExpression(config.labels != null + ? config.labels.stream().collect(Collectors.joining(",")) + : null); } /**