| // Copyright (C) 2009 The Android Open Source Project |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| package com.google.gerrit.util.ssl; |
| |
| import java.io.IOException; |
| import java.net.InetAddress; |
| import java.net.Socket; |
| import java.net.UnknownHostException; |
| import java.security.GeneralSecurityException; |
| import java.security.SecureRandom; |
| 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 socket factory that ignores SSL certificate validation. */ |
| public class BlindSSLSocketFactory extends SSLSocketFactory { |
| private static final BlindSSLSocketFactory INSTANCE; |
| |
| static { |
| final X509TrustManager dummyTrustManager = new BlindTrustManager(); |
| |
| try { |
| final SSLContext context = SSLContext.getInstance("SSL"); |
| final TrustManager[] trustManagers = {dummyTrustManager}; |
| final SecureRandom rng = new SecureRandom(); |
| context.init(null, trustManagers, rng); |
| INSTANCE = new BlindSSLSocketFactory(context.getSocketFactory()); |
| } catch (GeneralSecurityException e) { |
| throw new RuntimeException("Cannot create BlindSslSocketFactory", e); |
| } |
| } |
| |
| public static SocketFactory getDefault() { |
| return INSTANCE; |
| } |
| |
| private final SSLSocketFactory sslFactory; |
| |
| private BlindSSLSocketFactory(SSLSocketFactory sslFactory) { |
| this.sslFactory = sslFactory; |
| } |
| |
| @Override |
| public Socket createSocket(Socket s, String host, int port, boolean autoClose) |
| throws IOException { |
| return sslFactory.createSocket(s, host, port, autoClose); |
| } |
| |
| @Override |
| public String[] getDefaultCipherSuites() { |
| return sslFactory.getDefaultCipherSuites(); |
| } |
| |
| @Override |
| public String[] getSupportedCipherSuites() { |
| return sslFactory.getSupportedCipherSuites(); |
| } |
| |
| @Override |
| public Socket createSocket() throws IOException { |
| return sslFactory.createSocket(); |
| } |
| |
| @Override |
| public Socket createSocket(String host, int port) throws IOException, UnknownHostException { |
| return sslFactory.createSocket(host, port); |
| } |
| |
| @Override |
| public Socket createSocket(InetAddress host, int port) throws IOException { |
| return sslFactory.createSocket(host, port); |
| } |
| |
| @Override |
| public Socket createSocket(String host, int port, InetAddress localHost, int localPort) |
| throws IOException, UnknownHostException { |
| return sslFactory.createSocket(host, port, localHost, localPort); |
| } |
| |
| @Override |
| public Socket createSocket(InetAddress address, int port, InetAddress localAddress, int localPort) |
| throws IOException { |
| return sslFactory.createSocket(address, port, localAddress, localPort); |
| } |
| } |