|
|
e188e1 |
commit aaf92165ad1cbb1c9818eb60178c91293e13b053
|
|
|
e188e1 |
Author: Andrew John Hughes <andrew@openjdk.org>
|
|
|
e188e1 |
Date: Mon Jan 24 15:13:14 2022 +0000
|
|
|
e188e1 |
|
|
|
e188e1 |
RH2021263: Improve Security initialisation, now FIPS support no longer relies on crypto policy support
|
|
|
e188e1 |
|
|
|
e188e1 |
diff --git openjdk.orig/jdk/src/share/classes/java/security/Security.java openjdk/jdk/src/share/classes/java/security/Security.java
|
|
|
e188e1 |
index fa494b680f..b5aa5c749d 100644
|
|
|
e188e1 |
--- openjdk.orig/jdk/src/share/classes/java/security/Security.java
|
|
|
e188e1 |
+++ openjdk/jdk/src/share/classes/java/security/Security.java
|
|
|
e188e1 |
@@ -57,10 +57,6 @@ public final class Security {
|
|
|
e188e1 |
private static final Debug sdebug =
|
|
|
e188e1 |
Debug.getInstance("properties");
|
|
|
e188e1 |
|
|
|
e188e1 |
- /* System property file*/
|
|
|
e188e1 |
- private static final String SYSTEM_PROPERTIES =
|
|
|
e188e1 |
- "/etc/crypto-policies/back-ends/java.config";
|
|
|
e188e1 |
-
|
|
|
e188e1 |
/* The java.security properties */
|
|
|
e188e1 |
private static Properties props;
|
|
|
e188e1 |
|
|
|
e188e1 |
@@ -202,13 +198,6 @@ public final class Security {
|
|
|
e188e1 |
}
|
|
|
e188e1 |
}
|
|
|
e188e1 |
|
|
|
e188e1 |
- String disableSystemProps = System.getProperty("java.security.disableSystemPropertiesFile");
|
|
|
e188e1 |
- if (disableSystemProps == null &&
|
|
|
e188e1 |
- "true".equalsIgnoreCase(props.getProperty
|
|
|
e188e1 |
- ("security.useSystemPropertiesFile"))) {
|
|
|
e188e1 |
- loadedProps = loadedProps && SystemConfigurator.configure(props);
|
|
|
e188e1 |
- }
|
|
|
e188e1 |
-
|
|
|
e188e1 |
if (!loadedProps) {
|
|
|
e188e1 |
initializeStatic();
|
|
|
e188e1 |
if (sdebug != null) {
|
|
|
e188e1 |
@@ -217,6 +206,28 @@ public final class Security {
|
|
|
e188e1 |
}
|
|
|
e188e1 |
}
|
|
|
e188e1 |
|
|
|
e188e1 |
+ String disableSystemProps = System.getProperty("java.security.disableSystemPropertiesFile");
|
|
|
e188e1 |
+ if ((disableSystemProps == null || "false".equalsIgnoreCase(disableSystemProps)) &&
|
|
|
e188e1 |
+ "true".equalsIgnoreCase(props.getProperty("security.useSystemPropertiesFile"))) {
|
|
|
e188e1 |
+ if (!SystemConfigurator.configureSysProps(props)) {
|
|
|
e188e1 |
+ if (sdebug != null) {
|
|
|
e188e1 |
+ sdebug.println("WARNING: System properties could not be loaded.");
|
|
|
e188e1 |
+ }
|
|
|
e188e1 |
+ }
|
|
|
e188e1 |
+ }
|
|
|
e188e1 |
+
|
|
|
e188e1 |
+ // FIPS support depends on the contents of java.security so
|
|
|
e188e1 |
+ // ensure it has loaded first
|
|
|
e188e1 |
+ if (loadedProps) {
|
|
|
e188e1 |
+ boolean fipsEnabled = SystemConfigurator.configureFIPS(props);
|
|
|
e188e1 |
+ if (sdebug != null) {
|
|
|
e188e1 |
+ if (fipsEnabled) {
|
|
|
e188e1 |
+ sdebug.println("FIPS support enabled.");
|
|
|
e188e1 |
+ } else {
|
|
|
e188e1 |
+ sdebug.println("FIPS support disabled.");
|
|
|
e188e1 |
+ }
|
|
|
e188e1 |
+ }
|
|
|
e188e1 |
+ }
|
|
|
e188e1 |
}
|
|
|
e188e1 |
|
|
|
e188e1 |
/*
|
|
|
e188e1 |
diff --git openjdk.orig/jdk/src/share/classes/java/security/SystemConfigurator.java openjdk/jdk/src/share/classes/java/security/SystemConfigurator.java
|
|
|
e188e1 |
index d1f677597d..7da65b1d2c 100644
|
|
|
e188e1 |
--- openjdk.orig/jdk/src/share/classes/java/security/SystemConfigurator.java
|
|
|
e188e1 |
+++ openjdk/jdk/src/share/classes/java/security/SystemConfigurator.java
|
|
|
e188e1 |
@@ -76,7 +76,7 @@ final class SystemConfigurator {
|
|
|
e188e1 |
* java.security.disableSystemPropertiesFile property is not set and
|
|
|
e188e1 |
* security.useSystemPropertiesFile is true.
|
|
|
e188e1 |
*/
|
|
|
e188e1 |
- static boolean configure(Properties props) {
|
|
|
e188e1 |
+ static boolean configureSysProps(Properties props) {
|
|
|
e188e1 |
boolean loadedProps = false;
|
|
|
e188e1 |
|
|
|
e188e1 |
try (BufferedInputStream bis =
|
|
|
e188e1 |
@@ -96,11 +96,19 @@ final class SystemConfigurator {
|
|
|
e188e1 |
e.printStackTrace();
|
|
|
e188e1 |
}
|
|
|
e188e1 |
}
|
|
|
e188e1 |
+ return loadedProps;
|
|
|
e188e1 |
+ }
|
|
|
e188e1 |
+
|
|
|
e188e1 |
+ /*
|
|
|
e188e1 |
+ * Invoked at the end of java.security.Security initialisation
|
|
|
e188e1 |
+ * if java.security properties have been loaded
|
|
|
e188e1 |
+ */
|
|
|
e188e1 |
+ static boolean configureFIPS(Properties props) {
|
|
|
e188e1 |
+ boolean loadedProps = false;
|
|
|
e188e1 |
|
|
|
e188e1 |
try {
|
|
|
e188e1 |
if (enableFips()) {
|
|
|
e188e1 |
if (sdebug != null) { sdebug.println("FIPS mode detected"); }
|
|
|
e188e1 |
- loadedProps = false;
|
|
|
e188e1 |
// Remove all security providers
|
|
|
e188e1 |
Iterator<Entry<Object, Object>> i = props.entrySet().iterator();
|
|
|
e188e1 |
while (i.hasNext()) {
|