diff options
Diffstat (limited to 'sonar-core')
4 files changed, 128 insertions, 0 deletions
diff --git a/sonar-core/build.gradle b/sonar-core/build.gradle index 053c84335d0..3360cc80f3c 100644 --- a/sonar-core/build.gradle +++ b/sonar-core/build.gradle @@ -26,6 +26,7 @@ dependencies { testImplementation 'junit:junit' testImplementation 'org.assertj:assertj-core' testImplementation 'org.junit.jupiter:junit-jupiter-api' + testImplementation 'org.junit.jupiter:junit-jupiter-params' testImplementation 'org.hamcrest:hamcrest-core' testImplementation 'org.mockito:mockito-core' testImplementation 'org.simpleframework:simple' diff --git a/sonar-core/src/main/java/org/sonar/core/fips/FipsDetector.java b/sonar-core/src/main/java/org/sonar/core/fips/FipsDetector.java new file mode 100644 index 00000000000..d619fffa55d --- /dev/null +++ b/sonar-core/src/main/java/org/sonar/core/fips/FipsDetector.java @@ -0,0 +1,43 @@ +/* + * SonarQube + * Copyright (C) 2009-2024 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.core.fips; + +import java.security.Provider; +import java.security.Security; +import java.util.Locale; + +public class FipsDetector { + + private FipsDetector() { + // Helper class + } + + public static boolean isFipsEnabled() { + Provider[] providers = Security.getProviders(); + for (Provider provider : providers) { + String nameLowerCase = provider.getName().toUpperCase(Locale.ENGLISH); + if (nameLowerCase.contains("FIPS")) { + return true; + } + } + return false; + } + +} diff --git a/sonar-core/src/main/java/org/sonar/core/fips/package-info.java b/sonar-core/src/main/java/org/sonar/core/fips/package-info.java new file mode 100644 index 00000000000..1d1de452d39 --- /dev/null +++ b/sonar-core/src/main/java/org/sonar/core/fips/package-info.java @@ -0,0 +1,23 @@ +/* + * SonarQube + * Copyright (C) 2009-2024 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +@ParametersAreNonnullByDefault +package org.sonar.core.fips; + +import javax.annotation.ParametersAreNonnullByDefault; diff --git a/sonar-core/src/test/java/org/sonar/core/fips/FipsDetectorTest.java b/sonar-core/src/test/java/org/sonar/core/fips/FipsDetectorTest.java new file mode 100644 index 00000000000..e8f8a75d983 --- /dev/null +++ b/sonar-core/src/test/java/org/sonar/core/fips/FipsDetectorTest.java @@ -0,0 +1,61 @@ +/* + * SonarQube + * Copyright (C) 2009-2024 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.core.fips; + +import java.security.Provider; +import java.security.Security; +import java.util.ArrayList; +import org.junit.jupiter.params.ParameterizedTest; +import org.junit.jupiter.params.provider.MethodSource; +import org.mockito.MockedStatic; + +import static org.assertj.core.api.Assertions.assertThat; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.mockStatic; +import static org.mockito.Mockito.when; + +class FipsDetectorTest { + + @ParameterizedTest + @MethodSource("inputs") + void testGetters(String[] providerNames, boolean expected) { + ArrayList<Provider> providers = new ArrayList<>(); + for (String providerName : providerNames) { + Provider provider = mock(Provider.class); + when(provider.getName()).thenReturn(providerName); + providers.add(provider); + } + + try (MockedStatic<Security> mockedSecurity = mockStatic(Security.class)) { + mockedSecurity.when(Security::getProviders).thenReturn(providers.toArray(new Provider[0])); + + boolean result = FipsDetector.isFipsEnabled(); + assertThat(result).isEqualTo(expected); + } + } + + private static Object[][] inputs() { + return new Object[][] { + { new String[]{"FIPS Provider", "SunJSSE", "SunJCE"}, true }, + { new String[]{"Some Provider", "SunJSSE", "SunJCE"}, false } + }; + } + +} |