HHH-17460 - Ongoing JPA 32 work

This commit is contained in:
Andrea Boriero 2024-03-21 09:20:54 +01:00 committed by Steve Ebersole
parent 2ec81bfdbf
commit d62673c640
4 changed files with 108 additions and 15 deletions

View File

@ -477,9 +477,7 @@ public class ManagedTypeProcessor {
extendsAnn.setAttributeValue( "superType", jaxbEntity.getExtends() ); extendsAnn.setAttributeValue( "superType", jaxbEntity.getExtends() );
} }
if ( jaxbEntity.getTable() != null ) {
XmlAnnotationHelper.applyTable( jaxbEntity.getTable(), classDetails, xmlDocumentContext ); XmlAnnotationHelper.applyTable( jaxbEntity.getTable(), classDetails, xmlDocumentContext );
}
final JaxbAttributesContainerImpl attributes = jaxbEntity.getAttributes(); final JaxbAttributesContainerImpl attributes = jaxbEntity.getAttributes();
if ( attributes != null ) { if ( attributes != null ) {

View File

@ -78,6 +78,7 @@ import org.hibernate.boot.jaxb.mapping.spi.JaxbNamedEntityGraphImpl;
import org.hibernate.boot.jaxb.mapping.spi.JaxbNamedSubgraphImpl; import org.hibernate.boot.jaxb.mapping.spi.JaxbNamedSubgraphImpl;
import org.hibernate.boot.jaxb.mapping.spi.JaxbNationalizedImpl; import org.hibernate.boot.jaxb.mapping.spi.JaxbNationalizedImpl;
import org.hibernate.boot.jaxb.mapping.spi.JaxbNaturalId; import org.hibernate.boot.jaxb.mapping.spi.JaxbNaturalId;
import org.hibernate.boot.jaxb.mapping.spi.JaxbSchemaAware;
import org.hibernate.boot.jaxb.mapping.spi.JaxbSequenceGeneratorImpl; import org.hibernate.boot.jaxb.mapping.spi.JaxbSequenceGeneratorImpl;
import org.hibernate.boot.jaxb.mapping.spi.JaxbTableGeneratorImpl; import org.hibernate.boot.jaxb.mapping.spi.JaxbTableGeneratorImpl;
import org.hibernate.boot.jaxb.mapping.spi.JaxbTableImpl; import org.hibernate.boot.jaxb.mapping.spi.JaxbTableImpl;
@ -87,11 +88,11 @@ import org.hibernate.boot.jaxb.mapping.spi.JaxbUuidGeneratorImpl;
import org.hibernate.boot.jaxb.mapping.spi.db.JaxbCheckable; import org.hibernate.boot.jaxb.mapping.spi.db.JaxbCheckable;
import org.hibernate.boot.jaxb.mapping.spi.db.JaxbColumnJoined; import org.hibernate.boot.jaxb.mapping.spi.db.JaxbColumnJoined;
import org.hibernate.boot.jaxb.mapping.spi.db.JaxbTableMapping; import org.hibernate.boot.jaxb.mapping.spi.db.JaxbTableMapping;
import org.hibernate.boot.models.JpaAnnotations;
import org.hibernate.boot.models.categorize.spi.JpaEventListener; import org.hibernate.boot.models.categorize.spi.JpaEventListener;
import org.hibernate.boot.models.categorize.spi.JpaEventListenerStyle; import org.hibernate.boot.models.categorize.spi.JpaEventListenerStyle;
import org.hibernate.boot.models.internal.AnnotationUsageHelper; import org.hibernate.boot.models.internal.AnnotationUsageHelper;
import org.hibernate.boot.models.xml.internal.db.ColumnProcessing; import org.hibernate.boot.models.xml.internal.db.ColumnProcessing;
import org.hibernate.boot.models.xml.spi.XmlDocument;
import org.hibernate.boot.models.xml.spi.XmlDocumentContext; import org.hibernate.boot.models.xml.spi.XmlDocumentContext;
import org.hibernate.engine.spi.ExecuteUpdateResultCheckStyle; import org.hibernate.engine.spi.ExecuteUpdateResultCheckStyle;
import org.hibernate.internal.util.KeyedConsumer; import org.hibernate.internal.util.KeyedConsumer;
@ -234,7 +235,12 @@ public class XmlAnnotationHelper {
MutableMemberDetails memberDetails, MutableMemberDetails memberDetails,
Class<A> annotationType, Class<A> annotationType,
XmlDocumentContext xmlDocumentContext) { XmlDocumentContext xmlDocumentContext) {
final MutableAnnotationUsage<A> joinColumnAnn = XmlProcessingHelper.getOrMakeAnnotation( annotationType, memberDetails, xmlDocumentContext ); final MutableAnnotationUsage<A> joinColumnAnn = XmlProcessingHelper.getOrMakeNamedAnnotation(
annotationType,
jaxbJoinColumn.getName(),
memberDetails,
xmlDocumentContext
);
final AnnotationDescriptor<A> joinColumnDescriptor = xmlDocumentContext final AnnotationDescriptor<A> joinColumnDescriptor = xmlDocumentContext
.getModelBuildingContext() .getModelBuildingContext()
.getAnnotationDescriptorRegistry() .getAnnotationDescriptorRegistry()
@ -469,7 +475,12 @@ public class XmlAnnotationHelper {
JaxbForeignKeyImpl jaxbForeignKey, JaxbForeignKeyImpl jaxbForeignKey,
MutableMemberDetails memberDetails, MutableMemberDetails memberDetails,
XmlDocumentContext xmlDocumentContext) { XmlDocumentContext xmlDocumentContext) {
final MutableAnnotationUsage<ForeignKey> foreignKeyAnn = XmlProcessingHelper.getOrMakeAnnotation( ForeignKey.class, memberDetails, xmlDocumentContext ); final MutableAnnotationUsage<ForeignKey> foreignKeyAnn = XmlProcessingHelper.getOrMakeNamedAnnotation(
ForeignKey.class,
jaxbForeignKey.getName(),
memberDetails,
xmlDocumentContext
);
final AnnotationDescriptor<ForeignKey> foreignKeyDescriptor = xmlDocumentContext final AnnotationDescriptor<ForeignKey> foreignKeyDescriptor = xmlDocumentContext
.getModelBuildingContext() .getModelBuildingContext()
.getAnnotationDescriptorRegistry() .getAnnotationDescriptorRegistry()
@ -645,18 +656,18 @@ public class XmlAnnotationHelper {
final List<JaxbJoinColumnImpl> joinColumns = jaxbJoinTable.getJoinColumn(); final List<JaxbJoinColumnImpl> joinColumns = jaxbJoinTable.getJoinColumn();
if ( CollectionHelper.isNotEmpty( joinColumns ) ) { if ( CollectionHelper.isNotEmpty( joinColumns ) ) {
joinTableAnn.setAttributeValue( "joinColumns", createJoinColumns( joinColumns, memberDetails, xmlDocumentContext ) ); joinTableAnn.setAttributeValue( "joinColumns", createJoinColumns( joinColumns, xmlDocumentContext ) );
} }
final List<JaxbJoinColumnImpl> inverseJoinColumns = jaxbJoinTable.getInverseJoinColumn(); final List<JaxbJoinColumnImpl> inverseJoinColumns = jaxbJoinTable.getInverseJoinColumn();
if ( CollectionHelper.isNotEmpty( inverseJoinColumns ) ) { if ( CollectionHelper.isNotEmpty( inverseJoinColumns ) ) {
joinTableAnn.setAttributeValue( "inverseJoinColumns", createJoinColumns( inverseJoinColumns, memberDetails, xmlDocumentContext ) ); joinTableAnn.setAttributeValue( "inverseJoinColumns", createJoinColumns( inverseJoinColumns, xmlDocumentContext ) );
} }
if ( jaxbJoinTable.getForeignKey() != null ) { if ( jaxbJoinTable.getForeignKey() != null ) {
joinTableAnn.setAttributeValue( joinTableAnn.setAttributeValue(
"foreignKey", "foreignKey",
createForeignKeyAnnotation( jaxbJoinTable.getForeignKey(), memberDetails, xmlDocumentContext ) createForeignKeyAnnotation( jaxbJoinTable.getForeignKey(), xmlDocumentContext )
); );
} }
if ( jaxbJoinTable.getInverseForeignKey() != null ) { if ( jaxbJoinTable.getInverseForeignKey() != null ) {
@ -678,7 +689,7 @@ public class XmlAnnotationHelper {
MutableAnnotationTarget target, MutableAnnotationTarget target,
MutableAnnotationUsage<A> annotationUsage, MutableAnnotationUsage<A> annotationUsage,
XmlDocumentContext xmlDocumentContext) { XmlDocumentContext xmlDocumentContext) {
if ( CollectionHelper.isNotEmpty( jaxbCheckable.getCheckConstraints() ) ) { if ( jaxbCheckable!= null && CollectionHelper.isNotEmpty( jaxbCheckable.getCheckConstraints() ) ) {
final List<AnnotationUsage<CheckConstraint>> checks = new ArrayList<>( jaxbCheckable.getCheckConstraints().size() ); final List<AnnotationUsage<CheckConstraint>> checks = new ArrayList<>( jaxbCheckable.getCheckConstraints().size() );
final AnnotationDescriptor<CheckConstraint> checkConstraintDescriptor = xmlDocumentContext.getModelBuildingContext() final AnnotationDescriptor<CheckConstraint> checkConstraintDescriptor = xmlDocumentContext.getModelBuildingContext()
.getAnnotationDescriptorRegistry() .getAnnotationDescriptorRegistry()
@ -983,9 +994,25 @@ public class XmlAnnotationHelper {
.getAnnotationDescriptorRegistry() .getAnnotationDescriptorRegistry()
.getDescriptor( Table.class ); .getDescriptor( Table.class );
if ( jaxbTable == null ) {
final XmlDocument.Defaults defaults = xmlDocumentContext.getXmlDocument().getDefaults();
final String catalog = defaults.getCatalog();
final String schema = defaults.getSchema();
if ( StringHelper.isNotEmpty( catalog ) || StringHelper.isNotEmpty( schema ) ) {
if ( StringHelper.isNotEmpty( catalog ) ) {
tableAnn.setAttributeValue( "catalog", catalog );
}
if ( StringHelper.isNotEmpty( schema ) ) {
tableAnn.setAttributeValue( "schema", schema );
}
}
}
else {
applyOr( jaxbTable, JaxbTableImpl::getName, "name", tableAnn, tableDescriptor ); applyOr( jaxbTable, JaxbTableImpl::getName, "name", tableAnn, tableDescriptor );
applyTableAttributes( jaxbTable, target, tableAnn, tableDescriptor, xmlDocumentContext ); applyTableAttributes( jaxbTable, target, tableAnn, tableDescriptor, xmlDocumentContext );
} }
}
public static void applyTableOverride( public static void applyTableOverride(
JaxbTableImpl jaxbTable, JaxbTableImpl jaxbTable,
@ -1010,8 +1037,8 @@ public class XmlAnnotationHelper {
MutableAnnotationUsage<A> tableAnn, MutableAnnotationUsage<A> tableAnn,
AnnotationDescriptor<A> annotationDescriptor, AnnotationDescriptor<A> annotationDescriptor,
XmlDocumentContext xmlDocumentContext) { XmlDocumentContext xmlDocumentContext) {
applyOr( jaxbTable, JaxbTableMapping::getCatalog, "catalog", tableAnn, annotationDescriptor ); applyOrCatalog( jaxbTable, tableAnn, annotationDescriptor, xmlDocumentContext );
applyOr( jaxbTable, JaxbTableMapping::getSchema, "schema", tableAnn, annotationDescriptor ); applyOrSchema( jaxbTable, tableAnn, annotationDescriptor, xmlDocumentContext);
applyOr( jaxbTable, JaxbTableMapping::getOptions, "options", tableAnn, annotationDescriptor ); applyOr( jaxbTable, JaxbTableMapping::getOptions, "options", tableAnn, annotationDescriptor );
applyOr( jaxbTable, JaxbTableMapping::getComment, "comment", tableAnn, annotationDescriptor ); applyOr( jaxbTable, JaxbTableMapping::getComment, "comment", tableAnn, annotationDescriptor );
applyCheckConstraints( jaxbTable, target, tableAnn, xmlDocumentContext ); applyCheckConstraints( jaxbTable, target, tableAnn, xmlDocumentContext );
@ -1709,4 +1736,52 @@ public class XmlAnnotationHelper {
return explicitName; return explicitName;
} }
public static <T, N, A extends Annotation> void applyOrSchema(
JaxbSchemaAware jaxbNode,
MutableAnnotationUsage<A> annotationUsage,
AnnotationDescriptor<A> annotationDescriptor,
XmlDocumentContext xmlDocumentContext) {
applyOr(
jaxbNode,
(collectionTable) -> {
if ( StringHelper.isNotEmpty( collectionTable.getSchema() ) ) {
return collectionTable.getSchema();
}
else if ( StringHelper.isNotEmpty( xmlDocumentContext.getXmlDocument()
.getDefaults()
.getSchema() ) ) {
return xmlDocumentContext.getXmlDocument().getDefaults().getSchema();
}
return null;
},
"schema",
annotationUsage,
annotationDescriptor
);
}
public static <T, N, A extends Annotation> void applyOrCatalog(
JaxbSchemaAware jaxbNode,
MutableAnnotationUsage<A> annotationUsage,
AnnotationDescriptor<A> annotationDescriptor,
XmlDocumentContext xmlDocumentContext) {
applyOr(
jaxbNode,
(collectionTable) -> {
if ( StringHelper.isNotEmpty( collectionTable.getCatalog() ) ) {
return collectionTable.getCatalog();
}
else if ( StringHelper.isNotEmpty( xmlDocumentContext.getXmlDocument()
.getDefaults()
.getCatalog() ) ) {
return xmlDocumentContext.getXmlDocument().getDefaults().getCatalog();
}
return null;
},
"catalog",
annotationUsage,
annotationDescriptor
);
}
} }

View File

@ -104,7 +104,19 @@ public class ElementCollectionAttributeProcessing {
.getDescriptor( CollectionTable.class ); .getDescriptor( CollectionTable.class );
XmlAnnotationHelper.applyOr( jaxbCollectionTable, JaxbCollectionTableImpl::getName, "name", collectionTableAnn, collectionTableDescriptor ); XmlAnnotationHelper.applyOr( jaxbCollectionTable, JaxbCollectionTableImpl::getName, "name", collectionTableAnn, collectionTableDescriptor );
XmlAnnotationHelper.applyOr( jaxbCollectionTable, JaxbCollectionTableImpl::getSchema, "schema", collectionTableAnn, collectionTableDescriptor ); XmlAnnotationHelper.applyOrSchema(
jaxbCollectionTable,
collectionTableAnn,
collectionTableDescriptor,
xmlDocumentContext
);
XmlAnnotationHelper.applyOrCatalog(
jaxbCollectionTable,
collectionTableAnn,
collectionTableDescriptor,
xmlDocumentContext
);
XmlAnnotationHelper.applyOr( jaxbCollectionTable, JaxbCollectionTableImpl::getOptions, "options", collectionTableAnn, collectionTableDescriptor ); XmlAnnotationHelper.applyOr( jaxbCollectionTable, JaxbCollectionTableImpl::getOptions, "options", collectionTableAnn, collectionTableDescriptor );
collectionTableAnn.setAttributeValue( "joinColumns", XmlAnnotationHelper.createJoinColumns( jaxbCollectionTable.getJoinColumns(), xmlDocumentContext ) ); collectionTableAnn.setAttributeValue( "joinColumns", XmlAnnotationHelper.createJoinColumns( jaxbCollectionTable.getJoinColumns(), xmlDocumentContext ) );

View File

@ -54,6 +54,14 @@ public class ManyToManyAttributeProcessing {
CommonPluralAttributeProcessing.applyPluralAttributeStructure( jaxbManyToMany, memberDetails, xmlDocumentContext ); CommonPluralAttributeProcessing.applyPluralAttributeStructure( jaxbManyToMany, memberDetails, xmlDocumentContext );
XmlAnnotationHelper.applyJoinTable( jaxbManyToMany.getJoinTable(), memberDetails, xmlDocumentContext );
XmlAnnotationHelper.applySqlJoinTableRestriction( jaxbManyToMany.getSqlJoinTableRestriction(), memberDetails, xmlDocumentContext );
jaxbManyToMany.getJoinTableFilters().forEach( (jaxbFilter) -> {
XmlAnnotationHelper.applyJoinTableFilter( jaxbFilter, memberDetails, xmlDocumentContext );
} );
return memberDetails; return memberDetails;
} }