aboutsummaryrefslogtreecommitdiffstats
path: root/AndroidAsyncSample/src/com/koushikdutta/async
diff options
context:
space:
mode:
authorKoushik Dutta <koushd@gmail.com>2015-02-15 10:53:40 -0800
committerKoushik Dutta <koushd@gmail.com>2015-02-15 10:53:40 -0800
commit81a3c9f8f9ab85b7c6c6237d113617522b9209cd (patch)
tree12302e638dc99451822c5597b1e13ed06f2110fb /AndroidAsyncSample/src/com/koushikdutta/async
parentbd2147e130b5ce1aa3cd0ec5e1eed6154264d3ba (diff)
downloadAndroidAsync-81a3c9f8f9ab85b7c6c6237d113617522b9209cd.tar.gz
AndroidAsync-81a3c9f8f9ab85b7c6c6237d113617522b9209cd.tar.bz2
AndroidAsync-81a3c9f8f9ab85b7c6c6237d113617522b9209cd.zip
basic auth middleware sample
Diffstat (limited to 'AndroidAsyncSample/src/com/koushikdutta/async')
-rw-r--r--AndroidAsyncSample/src/com/koushikdutta/async/sample/middleware/BasicAuthMiddleware.java36
1 files changed, 36 insertions, 0 deletions
diff --git a/AndroidAsyncSample/src/com/koushikdutta/async/sample/middleware/BasicAuthMiddleware.java b/AndroidAsyncSample/src/com/koushikdutta/async/sample/middleware/BasicAuthMiddleware.java
new file mode 100644
index 0000000..f106386
--- /dev/null
+++ b/AndroidAsyncSample/src/com/koushikdutta/async/sample/middleware/BasicAuthMiddleware.java
@@ -0,0 +1,36 @@
+package com.koushikdutta.async.sample.middleware;
+
+import android.text.TextUtils;
+import android.util.Base64;
+
+import com.koushikdutta.async.http.AsyncHttpClient;
+import com.koushikdutta.async.http.SimpleMiddleware;
+
+import java.util.Hashtable;
+
+/**
+ * Created by koush on 2/15/15.
+ */
+public class BasicAuthMiddleware extends SimpleMiddleware {
+ // insert this using
+ public static BasicAuthMiddleware add(AsyncHttpClient client) {
+ BasicAuthMiddleware ret = new BasicAuthMiddleware();
+ client.getMiddleware().add(ret);
+ return ret;
+ }
+
+ @Override
+ public void onRequest(OnRequestData data) {
+ super.onRequest(data);
+ // do more checking here, since uri may not necessarily be http or have a host, etc.
+ String auth = auths.get(data.request.getUri().getHost());
+ if (!TextUtils.isEmpty(auth))
+ data.request.setHeader("Authorization", auth);
+ }
+
+ Hashtable<String, String> auths = new Hashtable<String, String>();
+ public void setAuthorizationForHost(String host, String username, String password) {
+ String auth = "Basic " + Base64.encodeToString(String.format("%s:%s", username, password).getBytes(), Base64.NO_WRAP);
+ auths.put(host, auth);
+ }
+}