package play.utils; import java.io.IOException; import java.net.InetAddress; import java.net.Socket; import java.security.cert.X509Certificate; import javax.net.SocketFactory; import javax.net.ssl.SSLContext; import javax.net.ssl.SSLSocketFactory; import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; /** * SSL Sockets created by this factory won't check * if certificates are signed with a root certificate (or chained from root) */ public class YesSSLSocketFactory extends SSLSocketFactory { public static class YesTrustManager implements X509TrustManager { public void checkClientTrusted(X509Certificate[] cert, String authType) { } public void checkServerTrusted(X509Certificate[] cert, String authType) { } public X509Certificate[] getAcceptedIssuers() { return new X509Certificate[0]; } } private SSLSocketFactory factory; public YesSSLSocketFactory() { try { SSLContext sslcontext = SSLContext.getInstance("TLS"); sslcontext.init(null, new TrustManager[]{new YesTrustManager()}, null); factory = sslcontext.getSocketFactory(); } catch (Exception ex) { } } public static SocketFactory getDefault() { return new YesSSLSocketFactory(); } public Socket createSocket(Socket socket, String s, int i, boolean flag) throws IOException { return factory.createSocket(socket, s, i, flag); } public Socket createSocket() throws IOException { return factory.createSocket(); } public Socket createSocket(InetAddress inaddr, int i, InetAddress inaddr1, int j) throws IOException { return factory.createSocket(inaddr, i, inaddr1, j); } public Socket createSocket(InetAddress inaddr, int i) throws IOException { return factory.createSocket(inaddr, i); } public Socket createSocket(String s, int i, InetAddress inaddr, int j) throws IOException { return factory.createSocket(s, i, inaddr, j); } public Socket createSocket(String s, int i) throws IOException { return factory.createSocket(s, i); } public String[] getDefaultCipherSuites() { return factory.getDefaultCipherSuites(); } public String[] getSupportedCipherSuites() { return factory.getSupportedCipherSuites(); } }