This is an automated email from the ASF dual-hosted git repository. jamesnetherton pushed a commit to branch main in repository https://gitbox.apache.org/repos/asf/camel-quarkus.git
The following commit(s) were added to refs/heads/main by this push: new 05163b5 Add missing shiro reflective class configuration for commons-beanutils converters 05163b5 is described below commit 05163b501b2d573b1ce2450a645631e90055af17 Author: James Netherton <jamesnether...@gmail.com> AuthorDate: Wed Oct 20 10:53:47 2021 +0100 Add missing shiro reflective class configuration for commons-beanutils converters Fixes #3208 --- .../component/shiro/deployment/ShiroProcessor.java | 55 ++++++++++++++++++---- 1 file changed, 45 insertions(+), 10 deletions(-) diff --git a/extensions/shiro/deployment/src/main/java/org/apache/camel/quarkus/component/shiro/deployment/ShiroProcessor.java b/extensions/shiro/deployment/src/main/java/org/apache/camel/quarkus/component/shiro/deployment/ShiroProcessor.java index ae3dfc3..daef76b 100644 --- a/extensions/shiro/deployment/src/main/java/org/apache/camel/quarkus/component/shiro/deployment/ShiroProcessor.java +++ b/extensions/shiro/deployment/src/main/java/org/apache/camel/quarkus/component/shiro/deployment/ShiroProcessor.java @@ -16,6 +16,10 @@ */ package org.apache.camel.quarkus.component.shiro.deployment; +import java.io.File; +import java.math.BigDecimal; +import java.math.BigInteger; +import java.net.URL; import java.sql.Time; import java.sql.Timestamp; import java.util.Calendar; @@ -50,23 +54,54 @@ class ShiroProcessor { @BuildStep ReflectiveClassBuildItem registerForReflection(CombinedIndexBuildItem combinedIndex) { - List<String> dtos = combinedIndex.getIndex() + List<String> reflectiveClasses = combinedIndex.getIndex() .getAllKnownSubclasses(SHIRO_EXCEPTION_NAME) .stream() .map(c -> c.name().toString()) .filter(n -> n.startsWith("org.apache.shiro.auth")) .collect(Collectors.toList()); - dtos.add(CamelAuthorizationException.class.getName()); - dtos.add(Boolean[].class.getName()); - dtos.add(Float[].class.getName()); - dtos.add(java.util.Date[].class.getName()); - dtos.add(Calendar[].class.getName()); - dtos.add(java.sql.Date[].class.getName()); - dtos.add(Time[].class.getName()); - dtos.add(Timestamp[].class.getName()); + reflectiveClasses.add(CamelAuthorizationException.class.getName()); - return new ReflectiveClassBuildItem(false, false, dtos.toArray(new String[dtos.size()])); + // commons-beanutils converter types and their array counterparts need to be registered for reflection + reflectiveClasses.add(BigDecimal.class.getName()); + reflectiveClasses.add(BigDecimal[].class.getName()); + reflectiveClasses.add(BigInteger.class.getName()); + reflectiveClasses.add(BigInteger[].class.getName()); + reflectiveClasses.add(Boolean.class.getName()); + reflectiveClasses.add(Boolean[].class.getName()); + reflectiveClasses.add(Byte.class.getName()); + reflectiveClasses.add(Byte[].class.getName()); + reflectiveClasses.add(Calendar.class.getName()); + reflectiveClasses.add(Calendar[].class.getName()); + reflectiveClasses.add(Character.class.getName()); + reflectiveClasses.add(Character[].class.getName()); + reflectiveClasses.add(java.util.Date.class.getName()); + reflectiveClasses.add(java.util.Date[].class.getName()); + reflectiveClasses.add(java.sql.Date.class.getName()); + reflectiveClasses.add(java.sql.Date[].class.getName()); + reflectiveClasses.add(Double.class.getName()); + reflectiveClasses.add(Double[].class.getName()); + reflectiveClasses.add(File.class.getName()); + reflectiveClasses.add(File[].class.getName()); + reflectiveClasses.add(Float.class.getName()); + reflectiveClasses.add(Float[].class.getName()); + reflectiveClasses.add(Integer.class.getName()); + reflectiveClasses.add(Integer[].class.getName()); + reflectiveClasses.add(Long.class.getName()); + reflectiveClasses.add(Long[].class.getName()); + reflectiveClasses.add(Short.class.getName()); + reflectiveClasses.add(Short[].class.getName()); + reflectiveClasses.add(String.class.getName()); + reflectiveClasses.add(String[].class.getName()); + reflectiveClasses.add(Time.class.getName()); + reflectiveClasses.add(Time[].class.getName()); + reflectiveClasses.add(Timestamp.class.getName()); + reflectiveClasses.add(Timestamp[].class.getName()); + reflectiveClasses.add(URL.class.getName()); + reflectiveClasses.add(URL[].class.getName()); + + return new ReflectiveClassBuildItem(false, false, reflectiveClasses.toArray(new String[reflectiveClasses.size()])); } @BuildStep