Define our own version of a URL encoding helper
We may not always depend upon the org.mortbay.util package. The code to implement a Map<String,String> that converts into a URL is quite simple given the stock java.net.URLEncoder, so we are better off using that for our contact store client. Signed-off-by: Shawn O. Pearce <sop@google.com>
This commit is contained in:
		@@ -36,7 +36,6 @@ import org.bouncycastle.openpgp.PGPPublicKey;
 | 
			
		||||
import org.bouncycastle.openpgp.PGPPublicKeyRing;
 | 
			
		||||
import org.bouncycastle.openpgp.PGPPublicKeyRingCollection;
 | 
			
		||||
import org.bouncycastle.openpgp.PGPUtil;
 | 
			
		||||
import org.mortbay.util.UrlEncoded;
 | 
			
		||||
import org.spearce.jgit.util.NB;
 | 
			
		||||
 | 
			
		||||
import java.io.ByteArrayOutputStream;
 | 
			
		||||
@@ -161,17 +160,17 @@ public class EncryptedContactStore {
 | 
			
		||||
      final Timestamp filedOn = account.getContactFiledOn();
 | 
			
		||||
      final UrlEncoded u = new UrlEncoded();
 | 
			
		||||
      if (storeAPPSEC != null) {
 | 
			
		||||
        u.add("APPSEC", storeAPPSEC);
 | 
			
		||||
        u.put("APPSEC", storeAPPSEC);
 | 
			
		||||
      }
 | 
			
		||||
      if (account.getPreferredEmail() != null) {
 | 
			
		||||
        u.add("email", account.getPreferredEmail());
 | 
			
		||||
        u.put("email", account.getPreferredEmail());
 | 
			
		||||
      }
 | 
			
		||||
      if (filedOn != null) {
 | 
			
		||||
        u.add("filed", String.valueOf(filedOn.getTime() / 1000L));
 | 
			
		||||
        u.put("filed", String.valueOf(filedOn.getTime() / 1000L));
 | 
			
		||||
      }
 | 
			
		||||
      u.add("account_id", String.valueOf(account.getId().get()));
 | 
			
		||||
      u.add("data", encStr);
 | 
			
		||||
      final byte[] body = u.encode().getBytes("UTF-8");
 | 
			
		||||
      u.put("account_id", String.valueOf(account.getId().get()));
 | 
			
		||||
      u.put("data", encStr);
 | 
			
		||||
      final byte[] body = u.toString().getBytes("UTF-8");
 | 
			
		||||
 | 
			
		||||
      final HttpURLConnection c = (HttpURLConnection) storeUrl.openConnection();
 | 
			
		||||
      c.setRequestMethod("POST");
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										64
									
								
								src/main/java/com/google/gerrit/server/UrlEncoded.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								src/main/java/com/google/gerrit/server/UrlEncoded.java
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,64 @@
 | 
			
		||||
// 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.server;
 | 
			
		||||
 | 
			
		||||
import java.io.UnsupportedEncodingException;
 | 
			
		||||
import java.net.URLEncoder;
 | 
			
		||||
import java.util.LinkedHashMap;
 | 
			
		||||
import java.util.Map;
 | 
			
		||||
 | 
			
		||||
public class UrlEncoded extends LinkedHashMap<String, String> {
 | 
			
		||||
  private String url;
 | 
			
		||||
 | 
			
		||||
  public UrlEncoded() {
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  public UrlEncoded(final String url) {
 | 
			
		||||
    this.url = url;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  @Override
 | 
			
		||||
  public String toString() {
 | 
			
		||||
    final StringBuilder buffer = new StringBuilder();
 | 
			
		||||
    char separator = 0;
 | 
			
		||||
    if (url != null) {
 | 
			
		||||
      separator = '?';
 | 
			
		||||
      buffer.append(url);
 | 
			
		||||
    }
 | 
			
		||||
    for (final Map.Entry<String, String> entry : entrySet()) {
 | 
			
		||||
      final String key = entry.getKey();
 | 
			
		||||
      final String val = entry.getValue();
 | 
			
		||||
      if (separator != 0) {
 | 
			
		||||
        buffer.append(separator);
 | 
			
		||||
      }
 | 
			
		||||
      buffer.append(encode(key));
 | 
			
		||||
      buffer.append('=');
 | 
			
		||||
      if (val != null) {
 | 
			
		||||
        buffer.append(encode(val));
 | 
			
		||||
      }
 | 
			
		||||
      separator = '&';
 | 
			
		||||
    }
 | 
			
		||||
    return buffer.toString();
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private static String encode(final String str) {
 | 
			
		||||
    try {
 | 
			
		||||
      return URLEncoder.encode(str, "UTF-8");
 | 
			
		||||
    } catch (UnsupportedEncodingException e) {
 | 
			
		||||
      throw new RuntimeException(e);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user