Merge "Factor out proxy properties from OpenIdServiceImpl"
This commit is contained in:
		| @@ -0,0 +1,23 @@ | ||||
| // Copyright (C) 2014 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.httpd; | ||||
|  | ||||
| import java.net.URL; | ||||
|  | ||||
| public interface ProxyProperties { | ||||
|   URL getProxyUrl(); | ||||
|   String getUsername(); | ||||
|   String getPassword(); | ||||
| } | ||||
| @@ -0,0 +1,73 @@ | ||||
| // Copyright (C) 2014 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.httpd; | ||||
|  | ||||
| import com.google.common.base.Strings; | ||||
| import com.google.gerrit.server.config.GerritServerConfig; | ||||
| import com.google.inject.Inject; | ||||
| import com.google.inject.Provider; | ||||
| import com.google.inject.Singleton; | ||||
|  | ||||
| import org.eclipse.jgit.lib.Config; | ||||
|  | ||||
| import java.net.MalformedURLException; | ||||
| import java.net.URL; | ||||
|  | ||||
| @Singleton | ||||
| class ProxyPropertiesProvider implements Provider<ProxyProperties> { | ||||
|  | ||||
|   private URL proxyUrl; | ||||
|   private String proxyUser; | ||||
|   private String proxyPassword; | ||||
|  | ||||
|   @Inject | ||||
|   ProxyPropertiesProvider(@GerritServerConfig Config config) | ||||
|       throws MalformedURLException { | ||||
|     String proxyUrlStr = config.getString("http", null, "proxy"); | ||||
|     if (!Strings.isNullOrEmpty(proxyUrlStr)) { | ||||
|       proxyUrl = new URL(proxyUrlStr); | ||||
|       proxyUser = config.getString("http", null, "proxyUsername"); | ||||
|       proxyPassword = config.getString("http", null, "proxyPassword"); | ||||
|       String userInfo = proxyUrl.getUserInfo(); | ||||
|       if (userInfo != null) { | ||||
|         int c = userInfo.indexOf(':'); | ||||
|         if (0 < c) { | ||||
|           proxyUser = userInfo.substring(0, c); | ||||
|           proxyPassword = userInfo.substring(c + 1); | ||||
|         } else { | ||||
|           proxyUser = userInfo; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   @Override | ||||
|   public ProxyProperties get() { | ||||
|     return new ProxyProperties() { | ||||
|       @Override | ||||
|       public URL getProxyUrl() { | ||||
|         return proxyUrl; | ||||
|       } | ||||
|       @Override | ||||
|       public String getUsername() { | ||||
|         return proxyUser; | ||||
|       } | ||||
|       @Override | ||||
|       public String getPassword() { | ||||
|         return proxyPassword; | ||||
|       } | ||||
|     }; | ||||
|   } | ||||
| } | ||||
| @@ -131,6 +131,8 @@ public class WebModule extends LifecycleModule { | ||||
|     bind(SocketAddress.class).annotatedWith(RemotePeer.class).toProvider( | ||||
|         HttpRemotePeerProvider.class).in(RequestScoped.class); | ||||
|  | ||||
|     bind(ProxyProperties.class).toProvider(ProxyPropertiesProvider.class); | ||||
|  | ||||
|     listener().toInstance(registerInParentInjectors()); | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -19,6 +19,7 @@ import com.google.gerrit.common.auth.openid.OpenIdUrls; | ||||
| import com.google.gerrit.extensions.registration.DynamicItem; | ||||
| import com.google.gerrit.extensions.restapi.Url; | ||||
| import com.google.gerrit.httpd.CanonicalWebUrl; | ||||
| import com.google.gerrit.httpd.ProxyProperties; | ||||
| import com.google.gerrit.httpd.WebSession; | ||||
| import com.google.gerrit.reviewdb.client.Account; | ||||
| import com.google.gerrit.server.IdentifiedUser; | ||||
| @@ -55,7 +56,6 @@ import org.openid4java.message.sreg.SRegMessage; | ||||
| import org.openid4java.message.sreg.SRegRequest; | ||||
| import org.openid4java.message.sreg.SRegResponse; | ||||
| import org.openid4java.util.HttpClientFactory; | ||||
| import org.openid4java.util.ProxyProperties; | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
|  | ||||
| @@ -108,29 +108,18 @@ class OpenIdServiceImpl { | ||||
|       final Provider<IdentifiedUser> iu, | ||||
|       CanonicalWebUrl up, | ||||
|       @GerritServerConfig final Config config, final AuthConfig ac, | ||||
|       final AccountManager am) throws ConsumerException, MalformedURLException { | ||||
|       final AccountManager am, | ||||
|       ProxyProperties proxyProperties) | ||||
|           throws ConsumerException, MalformedURLException { | ||||
|  | ||||
|     if (config.getString("http", null, "proxy") != null) { | ||||
|       final URL proxyUrl = new URL(config.getString("http", null, "proxy")); | ||||
|       String username = config.getString("http", null, "proxyUsername"); | ||||
|       String password = config.getString("http", null, "proxyPassword"); | ||||
|  | ||||
|       final String userInfo = proxyUrl.getUserInfo(); | ||||
|       if (userInfo != null) { | ||||
|         int c = userInfo.indexOf(':'); | ||||
|         if (0 < c) { | ||||
|           username = userInfo.substring(0, c); | ||||
|           password = userInfo.substring(c + 1); | ||||
|         } else { | ||||
|           username = userInfo; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       final ProxyProperties proxy = new ProxyProperties(); | ||||
|       proxy.setProxyHostName(proxyUrl.getHost()); | ||||
|       proxy.setProxyPort(proxyUrl.getPort()); | ||||
|       proxy.setUserName(username); | ||||
|       proxy.setPassword(password); | ||||
|     if (proxyProperties.getProxyUrl() != null) { | ||||
|       final org.openid4java.util.ProxyProperties proxy = | ||||
|           new org.openid4java.util.ProxyProperties(); | ||||
|       URL url = proxyProperties.getProxyUrl(); | ||||
|       proxy.setProxyHostName(url.getHost()); | ||||
|       proxy.setProxyPort(url.getPort()); | ||||
|       proxy.setUserName(proxyProperties.getUsername()); | ||||
|       proxy.setPassword(proxyProperties.getPassword()); | ||||
|       HttpClientFactory.setProxyProperties(proxy); | ||||
|     } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Shawn Pearce
					Shawn Pearce