Mercurial > dive4elements > river
comparison flys-client/src/main/java/org/dive4elements/river/client/server/auth/was/Request.java @ 5834:f507086aa94b
Repaired internal references.
author | Sascha L. Teichmann <teichmann@intevation.de> |
---|---|
date | Thu, 25 Apr 2013 12:31:32 +0200 |
parents | flys-client/src/main/java/de/intevation/flys/client/server/auth/was/Request.java@e0c6de3a9803 |
children | 821a02bbfb4e |
comparison
equal
deleted
inserted
replaced
5833:a2bdc0f524e8 | 5834:f507086aa94b |
---|---|
1 package de.intevation.flys.client.server.auth.was; | |
2 | |
3 import java.io.UnsupportedEncodingException; | |
4 import java.net.URI; | |
5 | |
6 import org.apache.commons.codec.binary.Base64; | |
7 import org.apache.http.client.methods.HttpGet; | |
8 import org.apache.log4j.Logger; | |
9 | |
10 public class Request extends HttpGet { | |
11 | |
12 private final static String VERSION = "1.1"; | |
13 private final static String REQUEST_SAML_RESPONSE = "GetSAMLResponse"; | |
14 private final static String METHOD_AUTH_PASSWORD = | |
15 "urn:opengeospatial:authNMethod:OWS:1.0:password"; | |
16 | |
17 private static Logger logger = Logger.getLogger(Request.class); | |
18 | |
19 public Request(String uri) { | |
20 String request = uri + "?VERSION=" + VERSION + "&REQUEST=" + | |
21 REQUEST_SAML_RESPONSE + "&METHOD=" + METHOD_AUTH_PASSWORD + | |
22 "&ANONYMOUS=TRUE&CREDENTIALS="; | |
23 this.setURI(URI.create(request)); | |
24 } | |
25 | |
26 public Request(String uri, String user, String pass, String encoding) { | |
27 try { | |
28 String base64user = this.toBase64(user, encoding); | |
29 String base64pass = this.toBase64(pass, encoding); | |
30 | |
31 String request = uri + "?VERSION=" + VERSION + "&REQUEST=" + | |
32 REQUEST_SAML_RESPONSE + "&METHOD=" + METHOD_AUTH_PASSWORD + | |
33 "&CREDENTIALS=" + base64user + "," + base64pass; | |
34 | |
35 this.setURI(URI.create(request)); | |
36 } | |
37 catch(UnsupportedEncodingException e) { | |
38 logger.error(e); | |
39 } | |
40 } | |
41 | |
42 private String toBase64(String value, String encoding) throws | |
43 UnsupportedEncodingException { | |
44 if (encoding == null) { | |
45 encoding = "utf-8"; | |
46 } | |
47 try { | |
48 return new String(Base64.encodeBase64(value.getBytes(encoding))); | |
49 } | |
50 catch(UnsupportedEncodingException e) { | |
51 logger.warn("Can't encode string with encoding " + encoding + | |
52 ". Falling back to utf-8. " + e); | |
53 return this.toBase64(value, "utf-8"); | |
54 } | |
55 } | |
56 | |
57 } | |
58 // vim: set et si fileencoding=utf-8 ts=4 sw=4 tw=80: | |
59 |