blob: 1eb3250aa0251e61c5b005c4e9fdd0398214e86b [file] [log] [blame]
/*******************************************************************************
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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 org.apache.ofbiz.base.util;
import java.io.IOException;
import java.net.HttpURLConnection;
import java.net.URL;
import java.net.URLConnection;
import java.security.GeneralSecurityException;
import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import org.apache.ofbiz.base.config.GenericConfigException;
/**
* URLConnector.java
*
*/
public class URLConnector {
public static final String module = URLConnector.class.getName();
private URLConnection connection = null;
private URL url = null;
private String clientCertAlias = null;
private boolean timedOut = false;
private boolean trustAnyCert = false;
private int hostCertLevel = 2;
protected URLConnector() {}
protected URLConnector(URL url, String clientCertAlias, int hostCertLevel, boolean trustAnyCert) {
this.clientCertAlias = clientCertAlias;
this.url = url;
this.trustAnyCert = trustAnyCert;
this.hostCertLevel = hostCertLevel;
}
protected synchronized URLConnection openConnection(int timeout) throws IOException {
Thread t = new Thread(new URLConnectorThread());
t.start();
try {
this.wait(timeout);
} catch (InterruptedException e) {
if (connection == null) {
timedOut = true;
} else {
close(connection);
}
throw new IOException("Connection never established");
}
if (connection != null) {
return connection;
} else {
timedOut = true;
throw new IOException("Connection timed out");
}
}
// trusted certs only
public static URLConnection openConnection(URL url) throws IOException {
return openConnection(url, 30000);
}
public static URLConnection openConnection(URL url, int timeout) throws IOException {
return openConnection(url, timeout, null, SSLUtil.getHostCertNormalCheck());
}
public static URLConnection openConnection(URL url, String clientCertAlias) throws IOException {
return openConnection(url, 30000, clientCertAlias, SSLUtil.getHostCertNormalCheck());
}
public static URLConnection openConnection(URL url, int timeout, String clientCertAlias, int hostCertLevel) throws IOException {
URLConnector uc = new URLConnector(url, clientCertAlias, hostCertLevel, false);
return uc.openConnection(timeout);
}
// allow untrusted certs
public static URLConnection openUntrustedConnection(URL url) throws IOException {
return openConnection(url, 30000);
}
public static URLConnection openUntrustedConnection(URL url, int timeout) throws IOException {
return openConnection(url, timeout, null, SSLUtil.getHostCertNormalCheck());
}
public static URLConnection openUntrustedConnection(URL url, String clientCertAlias) throws IOException {
return openConnection(url, 30000, clientCertAlias, SSLUtil.getHostCertNormalCheck());
}
public static URLConnection openUntrustedConnection(URL url, int timeout, String clientCertAlias, int hostCertLevel) throws IOException {
URLConnector uc = new URLConnector(url, clientCertAlias, hostCertLevel, true);
return uc.openConnection(timeout);
}
// special thread to open the connection
private class URLConnectorThread implements Runnable {
public void run() {
URLConnection con = null;
try {
con = url.openConnection();
if ("HTTPS".equalsIgnoreCase(url.getProtocol())) {
HttpsURLConnection scon = (HttpsURLConnection) con;
try {
scon.setSSLSocketFactory(SSLUtil.getSSLSocketFactory(clientCertAlias, trustAnyCert));
HostnameVerifier hv = SSLUtil.getHostnameVerifier(hostCertLevel);
if (hv != null) {
scon.setHostnameVerifier(hv);
}
} catch (GeneralSecurityException e) {
Debug.logError(e, module);
} catch (GenericConfigException e) {
Debug.logError(e, module);
}
}
} catch (IOException e) {
Debug.logError(e, module);
}
synchronized (URLConnector.this) {
if (timedOut && con != null) {
close(con);
} else {
connection = con;
URLConnector.this.notify();
}
}
}
}
// closes the HttpURLConnection does nothing to others
private static void close(URLConnection con) {
if (con instanceof HttpURLConnection) {
((HttpURLConnection) con).disconnect();
}
}
}