Skip to content

Commit

Permalink
DBZ-4232 Fix OutboxEvent entity not found
Browse files Browse the repository at this point in the history
  • Loading branch information
Naros committed Nov 30, 2021
1 parent 487f956 commit 220d20a
Show file tree
Hide file tree
Showing 5 changed files with 42 additions and 4 deletions.

This file was deleted.

16 changes: 14 additions & 2 deletions debezium-quarkus-outbox/runtime/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,12 @@
<artifactId>quarkus-smallrye-opentracing</artifactId>
<optional>true</optional>
</dependency>
<!-- Needed specifically for AdditionalJaxbMappingProducerImpl usage -->
<dependency>
<groupId>org.jboss</groupId>
<artifactId>jandex</artifactId>
<version>2.4.0.Final</version>
</dependency>
<!-- Needed primarily for @Incubating annotation -->
<dependency>
<groupId>io.debezium</groupId>
Expand Down Expand Up @@ -91,10 +97,16 @@
<resources>
<resource>
<filtering>true</filtering>
<directory>src/main/resources-filtered</directory>
<includes>
<include>**/*</include>
</includes>
</resource>
<resource>
<filtering>false</filtering>
<directory>src/main/resources</directory>
<includes>
<!-- Inject version information into the extension's YAML automatically -->
<include>**/quarkus-extension.yaml</include>
<include>**/*</include>
</includes>
</resource>
</resources>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
*
* Licensed under the Apache Software License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
*/
package io.debezium.outbox.quarkus.deployment;
package io.debezium.outbox.quarkus.internal;

import static io.debezium.outbox.quarkus.internal.OutboxConstants.OUTBOX_ENTITY_HBMXML;

Expand All @@ -16,11 +16,16 @@
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.StringWriter;
import java.io.Writer;
import java.nio.charset.StandardCharsets;
import java.util.Collection;
import java.util.Collections;

import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Marshaller;

import org.hibernate.boot.jaxb.Origin;
import org.hibernate.boot.jaxb.SourceType;
import org.hibernate.boot.jaxb.hbm.spi.JaxbHbmHibernateMapping;
Expand Down Expand Up @@ -74,6 +79,10 @@ public Collection<MappingDocument> produceAdditionalMappings(MetadataImplementor
try (BufferedInputStream bis = new BufferedInputStream(bais)) {
final Binding<?> jaxbBinding = mappingBinder.bind(bis, origin);
final JaxbHbmHibernateMapping mapping = (JaxbHbmHibernateMapping) jaxbBinding.getRoot();

logOutboxMapping(mapping);

LOGGER.info("Contributed XML mapping for entity: {}", mapping.getClazz().get(0).getEntityName());
return Collections.singletonList(new MappingDocument(mapping, origin, buildingContext));
}
}
Expand All @@ -95,4 +104,21 @@ private InputStream getOutboxHbmXmlStream() {
// Attempt to load the XML using the current class loader
return getClass().getResourceAsStream("/" + OUTBOX_ENTITY_HBMXML);
}

private void logOutboxMapping(JaxbHbmHibernateMapping mapping) {
try {
JAXBContext context = JAXBContext.newInstance(JaxbHbmHibernateMapping.class);

Marshaller marshaller = context.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);

final StringWriter writer = new StringWriter();
marshaller.marshal(mapping, writer);

LOGGER.debug("Debezium Outbox XML Mapping:\n{}", writer);
}
catch (JAXBException e) {
throw new RuntimeException("Failed to marshal Debezium Outbox XML mapping", e);
}
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
io.debezium.outbox.quarkus.internal.AdditionalJaxbMappingProducerImpl

0 comments on commit 220d20a

Please sign in to comment.