blob: 88845efb24f6ddb66a067a8d050088c014135733 [file] [log] [blame]
// 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);
}
}