diff --git a/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/JaxRsResourceImplementor.java b/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/JaxRsResourceImplementor.java index ecbce04af98a68..462c609f7c29f1 100644 --- a/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/JaxRsResourceImplementor.java +++ b/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/JaxRsResourceImplementor.java @@ -26,7 +26,7 @@ import io.quarkus.rest.data.panache.deployment.methods.ListMethodImplementor; import io.quarkus.rest.data.panache.deployment.methods.MethodImplementor; import io.quarkus.rest.data.panache.deployment.methods.UpdateMethodImplementor; -import io.quarkus.rest.data.panache.deployment.methods.UserMethodsWithTransactionalImplementor; +import io.quarkus.rest.data.panache.deployment.methods.UserMethodsWithAnnotationsImplementor; import io.quarkus.rest.data.panache.deployment.methods.hal.ListHalMethodImplementor; import io.quarkus.rest.data.panache.deployment.properties.ResourceProperties; import io.quarkus.runtime.util.HashUtil; @@ -49,7 +49,7 @@ class JaxRsResourceImplementor { new AddMethodImplementor(capabilities), new UpdateMethodImplementor(capabilities), new DeleteMethodImplementor(capabilities), - new UserMethodsWithTransactionalImplementor(capabilities), + new UserMethodsWithAnnotationsImplementor(), // The list hal endpoint needs to be added for both resteasy classic and resteasy reactive // because the pagination links are programmatically added. new ListHalMethodImplementor(capabilities)); diff --git a/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/methods/UserMethodsWithTransactionalImplementor.java b/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/methods/UserMethodsWithAnnotationsImplementor.java similarity index 70% rename from extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/methods/UserMethodsWithTransactionalImplementor.java rename to extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/methods/UserMethodsWithAnnotationsImplementor.java index e1992090435e70..6c27d84c6011cd 100644 --- a/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/methods/UserMethodsWithTransactionalImplementor.java +++ b/extensions/panache/rest-data-panache/deployment/src/main/java/io/quarkus/rest/data/panache/deployment/methods/UserMethodsWithAnnotationsImplementor.java @@ -1,10 +1,7 @@ package io.quarkus.rest.data.panache.deployment.methods; import org.jboss.jandex.AnnotationTarget; -import org.jboss.jandex.DotName; -import io.quarkus.deployment.Capabilities; -import io.quarkus.deployment.Capability; import io.quarkus.gizmo.ClassCreator; import io.quarkus.gizmo.FieldDescriptor; import io.quarkus.gizmo.MethodCreator; @@ -14,26 +11,18 @@ import io.quarkus.rest.data.panache.deployment.properties.ResourceProperties; /** - * Propagate the user methods annotated with `@Transactional`. - * This implementor is only used if Hibernate ORM is present. + * Propagate all the user methods that have annotations. + * + * This is necessary when users use annotations with an interceptor binding like `@Transactional`. */ -public final class UserMethodsWithTransactionalImplementor implements MethodImplementor { - - public static final DotName TRANSACTIONAL = DotName.createSimple("jakarta.transaction.Transactional"); - - private final Capabilities capabilities; - - public UserMethodsWithTransactionalImplementor(Capabilities capabilities) { - this.capabilities = capabilities; - } +public final class UserMethodsWithAnnotationsImplementor implements MethodImplementor { @Override public void implement(ClassCreator classCreator, ResourceMetadata resourceMetadata, ResourceProperties resourceProperties, FieldDescriptor resourceField) { - if (capabilities.isPresent(Capability.HIBERNATE_ORM) && resourceMetadata.getResourceInterface() != null) { + if (resourceMetadata.getResourceInterface() != null) { for (var methodInfo : resourceMetadata.getResourceInterface().methods()) { - // we only need to propagate the user methods annotated with `@Transactional` - if (methodInfo.hasAnnotation(TRANSACTIONAL)) { + if (methodInfo.isDefault() && !methodInfo.annotations().isEmpty()) { MethodCreator methodCreator = classCreator.getMethodCreator(MethodDescriptor.of(methodInfo)); methodCreator.setSignature(methodInfo.genericSignatureIfRequired()); for (var annotation : methodInfo.annotations()) {