source: josm/trunk/src/oauth/signpost/signature/AuthorizationHeaderSigningStrategy.java@ 12634

Last change on this file since 12634 was 10831, checked in by Don-vip, 10 years ago

see #13232 - cleanup OAuth signpost code:

  • remove classes unused by JOSM
  • add missing @Override annotations
File size: 1.4 KB
RevLine 
[4231]1package oauth.signpost.signature;
2
[6849]3import java.util.Iterator;
4
[4231]5import oauth.signpost.OAuth;
6import oauth.signpost.http.HttpParameters;
7import oauth.signpost.http.HttpRequest;
8
9/**
10 * Writes to the HTTP Authorization header field.
[10831]11 *
[4231]12 * @author Matthias Kaeppler
13 */
14public class AuthorizationHeaderSigningStrategy implements SigningStrategy {
15
16 private static final long serialVersionUID = 1L;
17
[10831]18 @Override
[4231]19 public String writeSignature(String signature, HttpRequest request,
20 HttpParameters requestParameters) {
21 StringBuilder sb = new StringBuilder();
22
23 sb.append("OAuth ");
[6849]24
25 // add the realm parameter, if any
[4231]26 if (requestParameters.containsKey("realm")) {
27 sb.append(requestParameters.getAsHeaderElement("realm"));
28 sb.append(", ");
29 }
[6849]30
31 // add all (x_)oauth parameters
32 HttpParameters oauthParams = requestParameters.getOAuthParameters();
33 oauthParams.put(OAuth.OAUTH_SIGNATURE, signature, true);
34
35 Iterator<String> iter = oauthParams.keySet().iterator();
36 while (iter.hasNext()) {
37 String key = iter.next();
38 sb.append(oauthParams.getAsHeaderElement(key));
39 if (iter.hasNext()) {
40 sb.append(", ");
41 }
[4231]42 }
43
44 String header = sb.toString();
[6849]45 OAuth.debugOut("Auth Header", header);
[4231]46 request.setHeader(OAuth.HTTP_AUTHORIZATION_HEADER, header);
47
48 return header;
49 }
50
51}
Note: See TracBrowser for help on using the repository browser.