148 lines
5.8 KiB
Java
148 lines
5.8 KiB
Java
/* ProviderTest.java
|
|
*
|
|
* Copyright (C) 2006-2025 wolfSSL Inc.
|
|
*
|
|
* This file is part of wolfSSL.
|
|
*
|
|
* wolfSSL is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* wolfSSL 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 General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
|
|
*/
|
|
|
|
import java.security.NoSuchAlgorithmException;
|
|
import java.security.Provider;
|
|
import java.security.Security;
|
|
import java.util.logging.Level;
|
|
import java.util.logging.Logger;
|
|
import javax.net.ssl.SSLContext;
|
|
|
|
import com.wolfssl.provider.jsse.WolfSSLProvider;
|
|
|
|
/**
|
|
* This class tests the wolfSSL provider installation. It lists all providers
|
|
* installed on the system, tries to look up the wolfSSL provider, and if
|
|
* found, prints out the information about the wolfSSL provider.
|
|
* Finally, it tests what provider is registered to provide TLS to Java.
|
|
*
|
|
* This app can be useful for testing if wolfJSSE has been installed
|
|
* correctly at the system level.
|
|
*/
|
|
public class ProviderTest {
|
|
|
|
/* Print out info about registered Security providers. Does not
|
|
* install wolfJSSE. If wolfJSSE has been installed at the system
|
|
* level, or application has installed wolfJSSE at runtime, it will
|
|
* show up. Otherwise will not. main() below calls this once without
|
|
* installing wolfJSSE explicitly, then calls again after installing
|
|
* wolfJSSE at runtime as the highest-level provider. */
|
|
public static void pollProviders()
|
|
{
|
|
/* Get all providers */
|
|
Provider [] providers = Security.getProviders();
|
|
|
|
System.out.println("\nAll Installed Java Security Providers:");
|
|
System.out.println("---------------------------------------");
|
|
for(Provider prov:providers)
|
|
{
|
|
System.out.println("\t" + prov);
|
|
}
|
|
|
|
Provider p = Security.getProvider("wolfJSSE");
|
|
if (p == null) {
|
|
System.out.println("No wolfJSSE provider registered in system");
|
|
} else {
|
|
/* Test if wolfSSL is a Provider */
|
|
System.out.println("\nInfo about wolfSSL Provider (wolfJSSE):");
|
|
System.out.println("----------------------------------------");
|
|
System.out.println("Provider: " + p);
|
|
System.out.println("Info: " + p.getInfo());
|
|
System.out.println("Services:");
|
|
System.out.println(p.getServices());
|
|
}
|
|
|
|
/* Test which Provider provides TLS versions */
|
|
System.out.println("\nWhat Provider is providing TLS?");
|
|
System.out.println("--------------------------------");
|
|
try {
|
|
/* TLS default */
|
|
SSLContext s = SSLContext.getInstance("TLS");
|
|
Provider prov = s.getProvider();
|
|
System.out.println("\tSSLContext TLS Provider = " + prov);
|
|
} catch (NoSuchAlgorithmException ex) {
|
|
Logger.getLogger(ProviderTest.class.getName()).log(Level.SEVERE,
|
|
null, ex);
|
|
}
|
|
|
|
try {
|
|
/* TLS 1.0 - NOTE: compiled out by default in native wolfSSL */
|
|
SSLContext s = SSLContext.getInstance("TLSv1");
|
|
Provider prov = s.getProvider();
|
|
System.out.println("\tSSLContext TLSv1 Provider = " + prov);
|
|
} catch (NoSuchAlgorithmException ex) {
|
|
Logger.getLogger(ProviderTest.class.getName()).log(Level.SEVERE,
|
|
null, ex);
|
|
}
|
|
|
|
try {
|
|
/* TLS 1.1 */
|
|
SSLContext s = SSLContext.getInstance("TLSv1.1");
|
|
Provider prov = s.getProvider();
|
|
System.out.println("\tSSLContext TLSv1.1 Provider = " + prov);
|
|
} catch (NoSuchAlgorithmException ex) {
|
|
Logger.getLogger(ProviderTest.class.getName()).log(Level.SEVERE,
|
|
null, ex);
|
|
}
|
|
|
|
try {
|
|
/* TLS 1.2 */
|
|
SSLContext s = SSLContext.getInstance("TLSv1.2");
|
|
Provider prov = s.getProvider();
|
|
System.out.println("\tSSLContext TLSv1.2 Provider = " + prov);
|
|
} catch (NoSuchAlgorithmException ex) {
|
|
Logger.getLogger(ProviderTest.class.getName()).log(Level.SEVERE,
|
|
null, ex);
|
|
}
|
|
|
|
try {
|
|
/* TLS 1.3 */
|
|
SSLContext s = SSLContext.getInstance("TLSv1.3");
|
|
Provider prov = s.getProvider();
|
|
System.out.println("\tSSLContext TLSv1.3 Provider = " + prov);
|
|
|
|
} catch (NoSuchAlgorithmException ex) {
|
|
Logger.getLogger(ProviderTest.class.getName()).log(Level.SEVERE,
|
|
null, ex);
|
|
}
|
|
}
|
|
|
|
public static void main(String args [])
|
|
{
|
|
/* Print system providers before explicit wolfJSSE install */
|
|
System.out.println("=================================================");
|
|
System.out.println("| Before installing wolfJSSE at runtime |");
|
|
System.out.println("=================================================");
|
|
pollProviders();
|
|
|
|
/* Install wolfJSSE */
|
|
Security.insertProviderAt(new WolfSSLProvider(), 1);
|
|
|
|
/* Print system provider, after installing wolfJSSE */
|
|
System.out.println("");
|
|
System.out.println("=================================================");
|
|
System.out.println("| After installing wolfJSSE at runtime |");
|
|
System.out.println("=================================================");
|
|
pollProviders();
|
|
}
|
|
}
|
|
|