Skip to content

Commit

Permalink
HHH-18625 - Add Configurable#create(GeneratorCreationContext)
Browse files Browse the repository at this point in the history
  • Loading branch information
gavinking authored and sebersole committed Sep 16, 2024
1 parent a1d0b82 commit b09b27c
Show file tree
Hide file tree
Showing 7 changed files with 79 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -529,14 +529,20 @@ private static void checkVersionGenerationAlways(XProperty property, Generator g

private static void callConfigure(GeneratorCreationContext creationContext, Generator generator) {
if ( generator instanceof Configurable ) {
final Configurable configurable = (Configurable) generator;
final Value value = creationContext.getProperty().getValue();
( (Configurable) generator ).configure( value.getType(), collectParameters(
(SimpleValue) value,
creationContext.getDatabase().getDialect(),
creationContext.getDefaultCatalog(),
creationContext.getDefaultSchema(),
creationContext.getPersistentClass().getRootClass()
), creationContext.getServiceRegistry() );
configurable.create( creationContext );
configurable.configure(
value.getType(),
collectParameters(
(SimpleValue) value,
creationContext.getDatabase().getDialect(),
creationContext.getDefaultCatalog(),
creationContext.getDefaultSchema(),
creationContext.getPersistentClass().getRootClass()
),
creationContext.getServiceRegistry()
);
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,10 +42,7 @@ protected Database database() {
}

public Identifier normalizeIdentifierQuoting(Identifier identifier) {
return getBuildingContext().getMetadataCollector()
.getDatabase()
.getJdbcEnvironment()
.getIdentifierHelper()
return database().getJdbcEnvironment().getIdentifierHelper()
.normalizeQuoting( identifier );
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
import org.hibernate.dialect.Dialect;
import org.hibernate.engine.config.spi.ConfigurationService;
import org.hibernate.engine.jdbc.batch.spi.BatchBuilder;
import org.hibernate.engine.jdbc.connections.internal.ConnectionProviderInitiator;
import org.hibernate.engine.jdbc.connections.internal.DatabaseConnectionInfoImpl;
import org.hibernate.engine.jdbc.connections.spi.ConnectionProvider;
import org.hibernate.engine.jdbc.connections.spi.DatabaseConnectionInfo;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import org.hibernate.MappingException;
import org.hibernate.boot.model.relational.Database;
import org.hibernate.boot.model.relational.SqlStringGenerationContext;
import org.hibernate.generator.GeneratorCreationContext;
import org.hibernate.service.ServiceRegistry;
import org.hibernate.type.Type;

Expand All @@ -21,6 +22,14 @@
* @author Steve Ebersole
*/
public interface Configurable {
/**
* Called before {@link #configure(Type, Properties, ServiceRegistry)},
* with an instance of {@link GeneratorCreationContext}.
*
* @since 6.6
*/
default void create(GeneratorCreationContext creationContext) throws MappingException {}

/**
* Configure this instance, given the value of parameters
* specified by the user as XML {@code <param>} elements and
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@
import java.util.Properties;

import org.hibernate.Incubating;
import org.hibernate.dialect.Dialect;
import org.hibernate.generator.GeneratorCreationContext;
import org.hibernate.id.IdentifierGenerator;
import org.hibernate.id.factory.spi.GeneratorDefinitionResolver;
import org.hibernate.service.Service;
Expand Down Expand Up @@ -71,5 +71,21 @@ Generator createIdentifierGenerator(
* @deprecated use {@link #createIdentifierGenerator(GenerationType, String, String, JavaType, Properties, GeneratorDefinitionResolver)}
*/
@Deprecated(since = "6.0")
Generator createIdentifierGenerator(String strategy, Type type, Properties parameters);
Generator createIdentifierGenerator(String strategy, Type type, GeneratorCreationContext creationContext, Properties parameters);

/**
* Given a strategy, retrieve the appropriate identifier generator instance.
*
* @param strategy The generation strategy.
* @param type The mapping type for the identifier values.
* @param parameters Any parameters properties given in the generator mapping.
*
* @return The appropriate generator instance.
*
* @deprecated use {@link #createIdentifierGenerator(GenerationType, String, String, JavaType, Properties, GeneratorDefinitionResolver)}
*/
@Deprecated(since = "6.0")
default Generator createIdentifierGenerator(String strategy, Type type, Properties parameters) {
return createIdentifierGenerator( strategy, type, null, parameters );
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -6,21 +6,26 @@
*/
package org.hibernate.id.factory.internal;

import org.hibernate.boot.model.relational.Database;
import org.hibernate.cfg.AvailableSettings;
import org.hibernate.dialect.Dialect;
import org.hibernate.engine.config.spi.ConfigurationService;
import org.hibernate.engine.config.spi.StandardConverters;
import org.hibernate.generator.GeneratorCreationContext;
import org.hibernate.id.IdentifierGenerator;
import org.hibernate.id.OptimizableGenerator;
import org.hibernate.id.PersistentIdentifierGenerator;
import org.hibernate.id.enhanced.LegacyNamingStrategy;
import org.hibernate.id.enhanced.SingleNamingStrategy;
import org.hibernate.id.factory.IdentifierGeneratorFactory;
import org.hibernate.mapping.Column;
import org.hibernate.mapping.PersistentClass;
import org.hibernate.mapping.Property;
import org.hibernate.mapping.RootClass;
import org.hibernate.mapping.SimpleValue;
import org.hibernate.mapping.Table;
import org.hibernate.generator.Generator;
import org.hibernate.service.ServiceRegistry;

import java.util.Map;
import java.util.Properties;
Expand All @@ -37,6 +42,32 @@ public static Generator createLegacyIdentifierGenerator(
return identifierGeneratorFactory.createIdentifierGenerator(
simpleValue.getIdentifierGeneratorStrategy(),
simpleValue.getType(),
new GeneratorCreationContext() {
@Override
public Database getDatabase() {
return simpleValue.getMetadata().getDatabase();
}
@Override
public ServiceRegistry getServiceRegistry() {
return simpleValue.getServiceRegistry();
}
@Override
public String getDefaultCatalog() {
return null;
}
@Override
public String getDefaultSchema() {
return null;
}
@Override
public PersistentClass getPersistentClass() {
return rootClass;
}
@Override
public Property getProperty() {
return rootClass.getIdentifierProperty();
}
},
collectParameters( simpleValue, dialect, defaultCatalog, defaultSchema, rootClass )
);
}
Expand All @@ -48,7 +79,7 @@ public static Properties collectParameters(
String defaultSchema,
RootClass rootClass) {
final ConfigurationService configService =
simpleValue.getMetadata().getMetadataBuildingOptions().getServiceRegistry()
simpleValue.getServiceRegistry()
.requireService( ConfigurationService.class );

final Properties params = new Properties();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@
import org.hibernate.engine.config.spi.ConfigurationService;
import org.hibernate.engine.jdbc.env.spi.JdbcEnvironment;
import org.hibernate.generator.Generator;
import org.hibernate.generator.GeneratorCreationContext;
import org.hibernate.id.Assigned;
import org.hibernate.id.Configurable;
import org.hibernate.id.ForeignGenerator;
Expand Down Expand Up @@ -206,7 +207,8 @@ private Dialect getDialect() {
}

@Override @Deprecated
public Generator createIdentifierGenerator(String strategy, Type type, Properties parameters) {
public Generator createIdentifierGenerator(
String strategy, Type type, GeneratorCreationContext creationContext, Properties parameters) {
try {
final Class<? extends Generator> clazz = getIdentifierGeneratorClass( strategy );
final Generator identifierGenerator;
Expand All @@ -222,7 +224,9 @@ public Generator createIdentifierGenerator(String strategy, Type type, Propertie
}

if ( identifierGenerator instanceof Configurable ) {
( (Configurable) identifierGenerator ).configure( type, parameters, serviceRegistry );
final Configurable configurable = (Configurable) identifierGenerator;
configurable.create( creationContext );
configurable.configure( type, parameters, serviceRegistry );
}
return identifierGenerator;
}
Expand Down

0 comments on commit b09b27c

Please sign in to comment.