aboutsummaryrefslogtreecommitdiffstats
path: root/main/src/cgeo/geocaching/settings/CheckECCredentialsPreference.java
diff options
context:
space:
mode:
Diffstat (limited to 'main/src/cgeo/geocaching/settings/CheckECCredentialsPreference.java')
-rw-r--r--main/src/cgeo/geocaching/settings/CheckECCredentialsPreference.java101
1 files changed, 10 insertions, 91 deletions
diff --git a/main/src/cgeo/geocaching/settings/CheckECCredentialsPreference.java b/main/src/cgeo/geocaching/settings/CheckECCredentialsPreference.java
index 7424fe6..f4f2fc7 100644
--- a/main/src/cgeo/geocaching/settings/CheckECCredentialsPreference.java
+++ b/main/src/cgeo/geocaching/settings/CheckECCredentialsPreference.java
@@ -1,28 +1,14 @@
package cgeo.geocaching.settings;
-import cgeo.geocaching.R;
-import cgeo.geocaching.activity.ActivityMixin;
import cgeo.geocaching.connector.ec.ECLogin;
import cgeo.geocaching.enumerations.StatusCode;
-import cgeo.geocaching.network.Cookies;
-import cgeo.geocaching.utils.Log;
-import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.tuple.ImmutablePair;
-import android.annotation.SuppressLint;
-import android.app.ProgressDialog;
import android.content.Context;
-import android.content.res.Resources;
-import android.graphics.drawable.Drawable;
-import android.os.Handler;
-import android.os.Message;
-import android.preference.Preference;
import android.util.AttributeSet;
-import android.view.View;
-import android.view.ViewGroup;
-public class CheckECCredentialsPreference extends Preference {
+public class CheckECCredentialsPreference extends AbstractCheckCredentialsPreference {
public CheckECCredentialsPreference(Context context) {
super(context);
@@ -37,84 +23,17 @@ public class CheckECCredentialsPreference extends Preference {
}
@Override
- protected View onCreateView(ViewGroup parent) {
- setOnPreferenceClickListener(EC_LOGIN_CHECK);
- return super.onCreateView(parent);
+ protected ImmutablePair<String, String> getCredentials() {
+ return Settings.getECLogin();
}
- private final ECLoginCheck EC_LOGIN_CHECK = new ECLoginCheck();
-
- private class ECLoginCheck implements OnPreferenceClickListener {
- private Resources res;
- private SettingsActivity activity;
-
- private ProgressDialog loginDialog;
- @SuppressLint("HandlerLeak")
- private Handler logInHandler = new Handler() {
- @Override
- public void handleMessage(Message msg) {
- try {
- if (loginDialog != null && loginDialog.isShowing()) {
- loginDialog.dismiss();
- }
-
- if (msg.obj == null || (msg.obj instanceof Drawable)) {
- ActivityMixin.helpDialog(activity,
- res.getString(R.string.init_login_popup),
- res.getString(R.string.init_login_popup_ok),
- (Drawable) msg.obj);
- } else {
- ActivityMixin.helpDialog(activity,
- res.getString(R.string.init_login_popup),
- res.getString(R.string.init_login_popup_failed_reason)
- + " "
- + ((StatusCode) msg.obj).getErrorString(res)
- + ".");
- }
- } catch (Exception e) {
- ActivityMixin.showToast(activity, R.string.err_login_failed);
- Log.e("SettingsActivity.logInHandler", e);
- } finally {
- if (loginDialog != null && loginDialog.isShowing()) {
- loginDialog.dismiss();
- }
- }
- }
- };
-
- @Override
- public boolean onPreferenceClick(Preference preference) {
- this.activity = (SettingsActivity) CheckECCredentialsPreference.this.getContext();
- this.res = activity.getResources();
-
- ImmutablePair<String, String> credentials = Settings.getECLogin();
-
- // check credentials for validity
- if (StringUtils.isBlank(credentials.getLeft())
- || StringUtils.isBlank(credentials.getRight())) {
- ActivityMixin.showToast(activity, R.string.err_missing_auth);
- return false;
- }
-
- loginDialog = ProgressDialog.show(activity,
- res.getString(R.string.init_login_popup),
- res.getString(R.string.init_login_popup_working), true);
- loginDialog.setCancelable(false);
- Cookies.clearCookies();
-
- (new Thread() {
- @Override
- public void run() {
- final StatusCode loginResult = ECLogin.login();
- Object payload = loginResult;
- if (loginResult == StatusCode.NO_ERROR) {
- payload = null;
- }
- logInHandler.obtainMessage(0, payload).sendToTarget();
- }
- }).start();
-
- return false; // no shared preference has to be changed
+ @Override
+ protected Object login() {
+ final StatusCode loginResult = ECLogin.login();
+ Object payload = loginResult;
+ if (loginResult == StatusCode.NO_ERROR) {
+ payload = null;
}
+ return payload;
}
}