wolfssljni/examples/provider/ProviderTest.java

148 lines
5.8 KiB
Java

/* ProviderTest.java
*
* Copyright (C) 2006-2022 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-1301, 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();
}
}