Skip to content

Instantly share code, notes, and snippets.

@imminent
Created July 5, 2013 16:00
Show Gist options
  • Save imminent/5935501 to your computer and use it in GitHub Desktop.
Save imminent/5935501 to your computer and use it in GitHub Desktop.
Example of a persistent cookie store that only keeps one cookie around.
package com.example.android.utilities;
import android.content.SharedPreferences;
import android.os.PatternMatcher;
import android.util.Log;
import java.net.CookieStore;
import java.net.HttpCookie;
import java.net.URI;
import java.util.List;
import javax.annotation.ParametersAreNonnullByDefault;
import javax.inject.Inject;
import javax.inject.Named;
import javax.inject.Singleton;
import static com.google.common.collect.Lists.newArrayList;
/**
* A simple {@linkplain CookieStore cookie jar} that only cares to store the {@link #_COOKIE_AUTH_TOKEN}.
* It persists the cookie through app launches and maintains it securely.
* @author Dandré Allison
*/
@ParametersAreNonnullByDefault
public class AndroidCookieStore implements CookieStore {
/** Name of the authentication token stored in a {@link SharedPreferences} */
public static final String KEY_AUTH_TOKEN = "com.example.android.AndroidCookieStore.key.AUTH_TOKEN";
/* Constructor */
@Inject
public AndroidCookieStore(SharedPreferences settings, CryptographyUtilities crypto,
@Named("COOKIE_AUTH_TOKEN") String cookie_auth_token) {
_settings = settings;
_crypto = crypto;
_COOKIE_AUTH_TOKEN = cookie_auth_token;
_auth_token_pattern = new PatternMatcher(_COOKIE_AUTH_TOKEN, PatternMatcher.PATTERN_LITERAL);
}
/* Cookie Store */
@Override
public void add(URI _, HttpCookie cookie) {
// Stores the cookie in shared preferences
if (_auth_token_pattern.match(cookie.getName())) {
final SharedPreferences.Editor editor = _settings.edit();
try {
editor.putString(KEY_AUTH_TOKEN, _crypto.encrypt(cookie.getValue()));
} catch (Exception error) {
Log.e("Persistent Cookie Store", error.getCause());
}
editor.apply();
}
}
@Override
public List<HttpCookie> getCookies() {
return get(null);
}
@Override
public List<HttpCookie> get(URI _) {
// Loads in cookies from shared preferences
final String auth_token = _settings.getString(KEY_AUTH_TOKEN, null);
if (auth_token != null)
try {
final HttpCookie cookie = new HttpCookie(_COOKIE_AUTH_TOKEN, _crypto.decipher(auth_token));
cookie.setPath("/");
cookie.setVersion(0);
return newArrayList(cookie);
} catch (Exception error) {
Log.e("Persistent Cookie Store", error.getCause());
}
return newArrayList();
}
@Override
public List<URI> getURIs() {
return newArrayList();
}
@Override
public boolean remove(URI _, HttpCookie __) {
final boolean had_auth_token = _settings.getString(KEY_AUTH_TOKEN, null) != null;
final SharedPreferences.Editor editor = _settings.edit();
editor.remove(KEY_AUTH_TOKEN).apply();
return had_auth_token;
}
@Override
public boolean removeAll() {
return remove(null,null);
}
private final String _COOKIE_AUTH_TOKEN;
private final PatternMatcher _auth_token_pattern;
private final SharedPreferences _settings;
private final CryptographyUtilities _crypto;
}
@azaelvaldo
Copy link

Could yo plz tell me how to implement this under my android app? just added class and got a lot of errors.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment