From 092b0efd7604c9474efc8092427da51f6d247246 Mon Sep 17 00:00:00 2001 From: Andreas Kretschmer Date: Tue, 5 Mar 2024 17:54:43 +0100 Subject: [PATCH] thow unified RuntimeException in case of configuration error --- .../pki/cmpracomponent/util/ConfigLogger.java | 36 +++++++++---------- 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/src/main/java/com/siemens/pki/cmpracomponent/util/ConfigLogger.java b/src/main/java/com/siemens/pki/cmpracomponent/util/ConfigLogger.java index e1806341..3f201486 100644 --- a/src/main/java/com/siemens/pki/cmpracomponent/util/ConfigLogger.java +++ b/src/main/java/com/siemens/pki/cmpracomponent/util/ConfigLogger.java @@ -30,6 +30,7 @@ */ public class ConfigLogger { + private static final String DYNAMIC_CONFIGURATION_EXCEPTION = "DynamicConfigurationException: "; private static final Logger LOGGER = LoggerFactory.getLogger(ConfigLogger.class); private static void doInnerLogging( @@ -106,23 +107,22 @@ public static T log( try { ret = accessFunction.apply(certProfile, bodyType); } catch (final Throwable ex) { - LOGGER.error( - "exception calling " + accessFunctionName + "(" + certProfile + ", " + typeToString(bodyType) - + ") for \"" + interfaceName + "\"", - ex); + final String errorMsg = "exception calling " + accessFunctionName + "(" + certProfile + ", " + + typeToString(bodyType) + ") for \"" + interfaceName + "\""; + LOGGER.error(errorMsg, ex); Throwable cause = ex.getCause(); while (cause != null) { LOGGER.error("cause", cause); cause = cause.getCause(); } - throw ex; + throw new RuntimeException(DYNAMIC_CONFIGURATION_EXCEPTION + errorMsg, ex); } doInnerLogging(interfaceName, accessFunctionName, certProfile, bodyType, ret); if (ret == null) { final String logMsg = "calling " + accessFunctionName + "(" + certProfile + ", " + typeToString(bodyType) + ") for \"" + interfaceName + "\" returns null, but this configuration item is mandatory"; LOGGER.error(logMsg); - throw new NullPointerException(logMsg); + throw new RuntimeException(DYNAMIC_CONFIGURATION_EXCEPTION + logMsg); } return ret; } @@ -142,20 +142,21 @@ public static T log(String interfaceName, String accessFunctionName, Supplie try { ret = accessFunction.get(); } catch (final Throwable ex) { - LOGGER.error("exception calling " + accessFunctionName + " for \"" + interfaceName + "\"", ex); + final String errorMsg = "exception calling " + accessFunctionName + " for \"" + interfaceName + "\""; + LOGGER.error(errorMsg, ex); Throwable cause = ex.getCause(); while (cause != null) { LOGGER.error("cause", cause); cause = cause.getCause(); } - throw ex; + throw new RuntimeException(DYNAMIC_CONFIGURATION_EXCEPTION + errorMsg, ex); } doInnerLogging(interfaceName, accessFunctionName, ret); if (ret == null) { final String logMsg = "calling " + accessFunctionName + " for \"" + interfaceName + "\" returns null, but this configuration item is mandatory"; LOGGER.error(logMsg); - throw new NullPointerException(logMsg); + throw new RuntimeException(DYNAMIC_CONFIGURATION_EXCEPTION + logMsg); } return ret; } @@ -185,16 +186,15 @@ public static T logOptional( try { ret = accessFunction.apply(certProfile, bodyType); } catch (final Throwable ex) { - LOGGER.error( - "exception calling " + accessFunctionName + "(" + certProfile + ", " + typeToString(bodyType) - + ") for \"" + interfaceName + "\", proceed without configuration", - ex); + final String errorMsg = "exception calling " + accessFunctionName + "(" + certProfile + ", " + + typeToString(bodyType) + ") for \"" + interfaceName + "\""; + LOGGER.error(errorMsg, ex); Throwable cause = ex.getCause(); while (cause != null) { LOGGER.error("cause", cause); cause = cause.getCause(); } - return null; + throw new RuntimeException(DYNAMIC_CONFIGURATION_EXCEPTION + errorMsg, ex); } doInnerLogging(interfaceName, accessFunctionName, certProfile, bodyType, ret); return ret; @@ -216,16 +216,14 @@ public static T logOptional(String interfaceName, String accessFunctionName, try { ret = accessFunction.get(); } catch (final Throwable ex) { - LOGGER.error( - "exception while calling " + accessFunctionName + " for \"" + interfaceName - + "\", proceed without configuration", - ex); + final String errorMsg = "exception while calling " + accessFunctionName + " for \"" + interfaceName + "\""; + LOGGER.error(errorMsg, ex); Throwable cause = ex.getCause(); while (cause != null) { LOGGER.error("cause", cause); cause = cause.getCause(); } - return null; + throw new RuntimeException(DYNAMIC_CONFIGURATION_EXCEPTION + errorMsg, ex); } doInnerLogging(interfaceName, accessFunctionName, ret); return ret;