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

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

see #13232 - cleanup OAuth signpost code:

  • remove classes unused by JOSM
  • add missing @Override annotations
File size: 1.4 KB
Line 
1package oauth.signpost.signature;
2
3import java.util.Iterator;
4
5import oauth.signpost.OAuth;
6import oauth.signpost.http.HttpParameters;
7import oauth.signpost.http.HttpRequest;
8
9/**
10 * Writes to the HTTP Authorization header field.
11 *
12 * @author Matthias Kaeppler
13 */
14public class AuthorizationHeaderSigningStrategy implements SigningStrategy {
15
16 private static final long serialVersionUID = 1L;
17
18 @Override
19 public String writeSignature(String signature, HttpRequest request,
20 HttpParameters requestParameters) {
21 StringBuilder sb = new StringBuilder();
22
23 sb.append("OAuth ");
24
25 // add the realm parameter, if any
26 if (requestParameters.containsKey("realm")) {
27 sb.append(requestParameters.getAsHeaderElement("realm"));
28 sb.append(", ");
29 }
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 }
42 }
43
44 String header = sb.toString();
45 OAuth.debugOut("Auth Header", header);
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.