From 81a3c9f8f9ab85b7c6c6237d113617522b9209cd Mon Sep 17 00:00:00 2001 From: Koushik Dutta Date: Sun, 15 Feb 2015 10:53:40 -0800 Subject: basic auth middleware sample --- .../sample/middleware/BasicAuthMiddleware.java | 36 ++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 AndroidAsyncSample/src/com/koushikdutta/async/sample/middleware/BasicAuthMiddleware.java (limited to 'AndroidAsyncSample/src/com/koushikdutta/async') 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 auths = new Hashtable(); + 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); + } +} -- cgit v1.2.3