blob: e1c0d08e362a2e2e6441d5e285fab0be4c668212 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2008, 2017 compeople AG and others.
*
* This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* compeople AG (Stefan Liebig) - initial API and implementation
* IBM Corporation - handling URI without a scheme by select(URI, List) (bug 246065)
* IBM Corporation - Add proxy providers layer on the top of ProxyManager (bug 255616)
*******************************************************************************/
package org.eclipse.core.internal.net.proxy.win32.winhttp;
import java.net.URI;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import org.eclipse.core.internal.net.ProxyData;
import org.eclipse.core.net.proxy.IProxyData;
/**
* StaticProxyConfig wraps certain information of WinHttpCurrentIEProxyConfig,
* i.e. the Windows specific list of proxies and the proxy bypass list.
*/
public class StaticProxyConfig {
private static final String[] KNOWN_TYPES = {"HTTP", "HTTPS", "FTP", "GOPHER"}; //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$
private List<IProxyData> universalProxies = new ArrayList<>();
private Map<String, List<IProxyData>> protocolSpecificProxies = new HashMap<>();
private ProxyBypass proxyBypass;
/**
* @param proxiesString
* @param proxyBypassString
*/
public StaticProxyConfig(String proxiesString, String proxyBypassString) {
ProxyProviderUtil.fillProxyLists(proxiesString, universalProxies,
protocolSpecificProxies);
proxyBypass = new ProxyBypass(proxyBypassString);
}
/**
* Select the static proxies for the given uri and add it to the given list
* of proxies.<br>
* This respects also the proxy bypass definition.
*
* @param uri
* @param proxies
*/
public void select(URI uri, List<IProxyData> proxies) {
if (proxyBypass.bypassProxyFor(uri))
return;
if (!protocolSpecificProxies.isEmpty()) {
if (uri.getScheme() != null) {
List<IProxyData> protocolProxies = protocolSpecificProxies.get(uri
.getScheme().toUpperCase());
if (protocolProxies == null)
return;
proxies.addAll(protocolProxies);
} else {
Iterator<List<IProxyData>> it = protocolSpecificProxies.values().iterator();
while (it.hasNext()) {
List<IProxyData> protocolProxies = it.next();
if (protocolProxies == null)
return;
proxies.addAll(protocolProxies);
}
}
} else {
IProxyData[] data = getUniversalProxiesData();
if (uri.getScheme() != null) {
for (IProxyData d : data) {
if (uri.getScheme().equalsIgnoreCase(d.getType())) {
proxies.add(d);
}
}
} else {
for (IProxyData d : data) {
proxies.add(d);
}
}
}
}
public IProxyData[] getProxyData() {
IProxyData[] data = getUniversalProxiesData();
if (data.length > 0)
return data;
List<IProxyData> proxies = new ArrayList<>();
Iterator<List<IProxyData>> it = protocolSpecificProxies.values().iterator();
while (it.hasNext()) {
List<IProxyData> protocolProxies = it.next();
if (protocolProxies != null) {
proxies.addAll(protocolProxies);
}
}
return proxies.toArray(new IProxyData[0]);
}
private IProxyData[] getUniversalProxiesData() {
if (universalProxies.isEmpty()) {
return new IProxyData[0];
}
IProxyData[] data = new IProxyData[KNOWN_TYPES.length];
ProxyData universal = (ProxyData) universalProxies.get(0);
for (int i = 0; i < KNOWN_TYPES.length; i++) {
ProxyData newData = new ProxyData(KNOWN_TYPES[i], universal
.getHost(), universal.getPort(), universal
.isRequiresAuthentication(), universal.getSource());
newData.setUserid(universal.getUserId());
newData.setPassword(universal.getPassword());
data[i] = newData;
}
return data;
}
public String[] getNonProxiedHosts() {
return proxyBypass.getNonProxiedHosts();
}
}