From afe112ed48cc2b128fcf1d10d904023723cd481f Mon Sep 17 00:00:00 2001 From: Albert Louis Rossi Date: Wed, 27 Sep 2023 16:18:33 -0500 Subject: [PATCH] dcache-bulk: guard against erroneous argument names Motivation: Giving the `PIN` activity an argument it does not recognize will provoke an NPE, e.g., ``` 20 Sep 2023 11:28:10 [pool-11-thread-1] [] Uncaught exception in thread pool-11-thread-1java.lang.NullPointerException: null at java.base/jdk.internal.math.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:1838) at java.base/jdk.internal.math.FloatingDecimal.parseDouble(FloatingDecimal.java:110) at java.base/java.lang.Double.parseDouble(Double.java:543) at org.dcache.services.bulk.activity.plugin.pin.PinActivity.configure(PinActivity.java:138) ... ``` Modification: Check for undefined lifetime property. Result: No more NPE/stack trace. Target: master Request: 9.1 Request: 9.0 Request: 8.2 Requires-notes: yes Patch: https://rb.dcache.org/r/14108/ Acked-by: Lea --- .../bulk/activity/plugin/pin/PinActivity.java | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/modules/dcache-bulk/src/main/java/org/dcache/services/bulk/activity/plugin/pin/PinActivity.java b/modules/dcache-bulk/src/main/java/org/dcache/services/bulk/activity/plugin/pin/PinActivity.java index bd95b3142e3..d602bcba35d 100644 --- a/modules/dcache-bulk/src/main/java/org/dcache/services/bulk/activity/plugin/pin/PinActivity.java +++ b/modules/dcache-bulk/src/main/java/org/dcache/services/bulk/activity/plugin/pin/PinActivity.java @@ -127,6 +127,7 @@ public ListenableFuture perform(String rid, long tid, FsPath target, @Override protected void configure(Map arguments) { TimeUnit defaultUnit = TimeUnit.valueOf(lifetimeUnitDefault()); + Long defaultValue = Long.parseLong(lifetimeDefault()); if (arguments == null) { @@ -135,11 +136,17 @@ protected void configure(Map arguments) { String expire = arguments.get(LIFETIME); String unit = arguments.get(LIFETIME_UNIT); - Long value = (long) (Double.parseDouble(expire)); - - lifetimeInMillis = expire == null ? defaultUnit.toMillis(defaultValue) - : unit == null ? defaultUnit.toMillis(value) - : TimeUnit.valueOf(unit).toMillis(value); + /* + * Guard against erroneous argument names ... + */ + if (expire == null) { + lifetimeInMillis = unit == null ? defaultUnit.toMillis(defaultValue): + TimeUnit.valueOf(unit).toMillis(defaultValue); + } else { + Long value = (long) (Double.parseDouble(expire)); + lifetimeInMillis = unit == null ? defaultUnit.toMillis(value) + : TimeUnit.valueOf(unit).toMillis(value); + } } id = arguments == null ? null : arguments.get(PIN_REQUEST_ID);