diff --git a/pom.xml b/pom.xml
index e5ccd21164..1448ac448a 100644
--- a/pom.xml
+++ b/pom.xml
@@ -24,6 +24,7 @@
3.1.1
1.8
2.7
+ 3.3.1
3.13.0
11
11
@@ -156,6 +157,11 @@
+
+ org.apache.maven.plugins
+ maven-resources-plugin
+ ${maven-resources-plugin.version}
+
diff --git a/sdk/pom.xml b/sdk/pom.xml
index 3970b7f9fc..d0e9ad8e91 100644
--- a/sdk/pom.xml
+++ b/sdk/pom.xml
@@ -21,6 +21,7 @@
--add-opens java.base/java.util=ALL-UNNAMED
+
@@ -28,12 +29,6 @@
org.slf4j
slf4j-api
-
- org.apache.maven.plugins
- maven-resources-plugin
- 3.3.1
- maven-plugin
-
io.dapr
dapr-sdk-autogen
@@ -169,6 +164,10 @@
+
+ org.apache.maven.plugins
+ maven-resources-plugin
+
org.apache.maven.plugins
maven-source-plugin
diff --git a/sdk/src/main/java/io/dapr/utils/Version.java b/sdk/src/main/java/io/dapr/utils/Version.java
index e55e77f4a2..7b0ef2f49f 100644
--- a/sdk/src/main/java/io/dapr/utils/Version.java
+++ b/sdk/src/main/java/io/dapr/utils/Version.java
@@ -16,10 +16,11 @@
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
+import java.util.concurrent.atomic.AtomicReference;
public final class Version {
- private static String sdkVersion = null;
+ private static volatile AtomicReference sdkVersion = new AtomicReference<>();
/**
* Retrieves sdk version from resources.
@@ -27,20 +28,31 @@ public final class Version {
* @return String version of sdk.
*/
public static String getSdkVersion() {
+ var version = sdkVersion.get();
- if (sdkVersion != null) {
- return sdkVersion;
+ if ((version != null) && !version.isBlank()) {
+ return version;
}
- try (InputStream input = Version.class.getResourceAsStream("/sdk_version.properties");) {
+ try (InputStream input = Version.class.getResourceAsStream("/sdk_version.properties")) {
Properties properties = new Properties();
properties.load(input);
- sdkVersion = "dapr-sdk-java/v" + properties.getProperty("sdk_version", "unknown");
+ var v = properties.getProperty("sdk_version", null);
+ if (v == null) {
+ throw new IllegalStateException("Did not find sdk_version property!");
+ }
+
+ if (v.isBlank()) {
+ throw new IllegalStateException("Property sdk_version cannot be blank.");
+ }
+
+ version = "dapr-sdk-java/v" + v;
+ sdkVersion.set(version);
} catch (IOException e) {
- sdkVersion = "unknown";
+ throw new IllegalStateException("Could not load sdk_version property!", e);
}
- return sdkVersion;
+ return version;
}
}