Skip to content

Commit

Permalink
#2209 set nonProxyHosts when update ProxySelector.
Browse files Browse the repository at this point in the history
reset ProxySelector when exit plugin
  • Loading branch information
ivywei0125 committed Feb 1, 2023
1 parent 82ae7bd commit 2c39164
Show file tree
Hide file tree
Showing 4 changed files with 87 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -321,6 +321,7 @@ public void execute() throws MojoExecutionException {
} catch (InterruptedException e) {
// swallow this exception
}
ProxyManager.getInstance().resetProxy();
ApacheSenderFactory.INSTANCE.create().close();
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ public class AzureConfiguration {
private String proxyUsername;
private String proxyPassword;
@Nullable
private String nonProxyHosts;
@Nullable
private SSLContext sslContext;
private int pageSize = 2;
private List<String> documentsLabelFields = new ArrayList<>(DEFAULT_DOCUMENT_LABEL_FIELDS);
Expand All @@ -48,5 +50,6 @@ public void setProxyInfo(ProxyInfo proxy) {
this.setHttpProxyPort(proxy.getPort());
this.setProxyUsername(proxy.getUsername());
this.setProxyPassword(proxy.getPassword());
this.setNonProxyHosts(proxy.getNonProxyHosts());
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@

import lombok.Getter;
import lombok.experimental.SuperBuilder;
import org.jetbrains.annotations.Nullable;

@SuperBuilder
@Getter
Expand All @@ -16,4 +17,6 @@ public class ProxyInfo {
private int port;
private String username;
private String password;
@Nullable
private String nonProxyHosts;
}
Original file line number Diff line number Diff line change
Expand Up @@ -24,12 +24,18 @@
import java.net.URI;
import java.util.Collections;
import java.util.List;
import java.util.Optional;
import java.util.StringJoiner;
import java.util.regex.Pattern;

import static java.util.regex.Pattern.quote;

public class ProxyManager {
private static final String PROPERTY_USE_SYSTEM_PROXY = "java.net.useSystemProxies";
// isSystemProxyUnset shows whether user specify the proxy through -Djava.net.useSystemProxies
// see: https://docs.oracle.com/javase/8/docs/technotes/guides/net/proxies.html
private static final boolean isSystemProxyUnset = StringUtils.isBlank(System.getProperty(PROPERTY_USE_SYSTEM_PROXY));
private final ProxySelector defaultProxySelector = ProxySelector.getDefault();

public boolean isProxyEnabled() {
return StringUtils.isNotBlank(Azure.az().config().getProxySource());
Expand Down Expand Up @@ -67,6 +73,18 @@ public void applyProxy() {
ProxySelector.setDefault(new ProxySelector() {
@Override
public List<Proxy> select(URI uri) {
if (uri == null) {
throw new IllegalArgumentException("URI can't be null.");
}
String protocol = uri.getScheme();
String host = uri.getHost();
if (protocol == null || host == null) {
throw new IllegalArgumentException("protocol = "+protocol+" host = "+host);
}
if (shouldNotUseProxyFor(toPattern(Optional.ofNullable(config.getNonProxyHosts()).orElse(StringUtils.EMPTY)),
host.toLowerCase())) {
return Collections.singletonList(Proxy.NO_PROXY);
}
return Collections.singletonList(proxy);
}

Expand Down Expand Up @@ -95,6 +113,10 @@ public PasswordAuthentication getPasswordAuthentication() {
}
}

public void resetProxy() {
ProxySelector.setDefault(this.defaultProxySelector);
}

private ProxyInfo getSystemProxy() {
// we need to init at the program start before any internet access
if (isSystemProxyUnset) {
Expand All @@ -113,13 +135,16 @@ private static ProxyInfo getProxyFromProgramArgument(String prefix) {
final String proxyPort = System.getProperty(prefix + ".proxyPort");
final String proxyUser = System.getProperty(prefix + ".proxyUser");
final String proxyPassword = System.getProperty(prefix + ".proxyPassword");
final String nonProxyHosts = System.getProperty(prefix + ".nonProxyHosts");

if (StringUtils.isNoneBlank(proxyHost, proxyPort) && NumberUtils.isCreatable(proxyPort)) {
return ProxyInfo.builder().source(String.format("${%s}", prefix + ".proxyHost"))
.host(proxyHost)
.port(Integer.parseInt(proxyPort))
.username(proxyUser)
.password(proxyPassword).build();
.password(proxyPassword)
.nonProxyHosts(nonProxyHosts)
.build();
}
return null;
}
Expand All @@ -144,4 +169,58 @@ private static ProxyInfo getSystemProxyInner() {
return null;
}

/**
* refer to {@link sun.net.spi.DefaultProxySelector}
* @return {@code true} if given this pattern for non-proxy hosts and this
* urlhost the proxy should NOT be used to access this urlhost
*/
private static boolean shouldNotUseProxyFor(Pattern pattern, String urlhost) {
if (pattern == null || urlhost.isEmpty()) {
return false;
}
boolean matches = pattern.matcher(urlhost).matches();
return matches;
}

/**
* refer to {@link sun.net.spi.DefaultProxySelector}
* @param mask non-null mask
* @return {@link java.util.regex.Pattern} corresponding to this mask
* or {@code null} in case mask should not match anything
*/
private static Pattern toPattern(String mask) {
boolean disjunctionEmpty = true;
StringJoiner joiner = new StringJoiner("|");
for (String disjunct : mask.split("\\|")) {
if (disjunct.isEmpty()) {
continue;
}
disjunctionEmpty = false;
String regex = disjunctToRegex(disjunct.toLowerCase());
joiner.add(regex);
}
return disjunctionEmpty ? null : Pattern.compile(joiner.toString());
}

/**
* refer to {@link sun.net.spi.DefaultProxySelector}
* @param disjunct non-null mask disjunct
* @return java regex string corresponding to this mask
*/
private static String disjunctToRegex(String disjunct) {
String regex;
if ("*".equals(disjunct)) {
regex = ".*";
} else if (disjunct.startsWith("*") && disjunct.endsWith("*")) {
regex = ".*" + quote(disjunct.substring(1, disjunct.length() - 1)) + ".*";
} else if (disjunct.startsWith("*")) {
regex = ".*" + quote(disjunct.substring(1));
} else if (disjunct.endsWith("*")) {
regex = quote(disjunct.substring(0, disjunct.length() - 1)) + ".*";
} else {
regex = quote(disjunct);
}
return regex;
}

}

0 comments on commit 2c39164

Please sign in to comment.