1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
package cgeo.geocaching.connector.oc;
import cgeo.geocaching.Intents;
import cgeo.geocaching.R;
import cgeo.geocaching.connector.oc.OkapiError.OkapiErrors;
import cgeo.geocaching.network.OAuthAuthorizationActivity;
import cgeo.geocaching.settings.Settings;
import ch.boye.httpclientandroidlib.HttpResponse;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.tuple.ImmutablePair;
import org.eclipse.jdt.annotation.Nullable;
import android.os.Bundle;
public class OCAuthorizationActivity extends OAuthAuthorizationActivity {
private int titleResId;
private int tokenPublicPrefKey;
private int tokenSecretPrefKey;
private int tempTokenPublicPrefKey;
private int tempTokenSecretPrefKey;
@Override
public void onCreate(Bundle savedInstanceState) {
Bundle extras = getIntent().getExtras();
if (extras != null) {
titleResId = extras.getInt(Intents.EXTRA_OAUTH_TITLE_RES_ID);
tokenPublicPrefKey = extras.getInt(Intents.EXTRA_OAUTH_TOKEN_PUBLIC_KEY);
tokenSecretPrefKey = extras.getInt(Intents.EXTRA_OAUTH_TOKEN_SECRET_KEY);
tempTokenPublicPrefKey = extras.getInt(Intents.EXTRA_OAUTH_TEMP_TOKEN_KEY_PREF);
tempTokenSecretPrefKey = extras.getInt(Intents.EXTRA_OAUTH_TEMP_TOKEN_SECRET_PREF);
}
super.onCreate(savedInstanceState);
}
@Override
protected ImmutablePair<String, String> getTempTokens() {
return Settings.getTokenPair(tempTokenPublicPrefKey, tempTokenSecretPrefKey);
}
@Override
protected void setTempTokens(@Nullable final String tokenPublic, @Nullable final String tokenSecret) {
Settings.setTokens(tempTokenPublicPrefKey, tokenPublic, tempTokenSecretPrefKey, tokenSecret);
}
@Override
protected void setTokens(@Nullable final String tokenPublic, @Nullable final String tokenSecret, final boolean enable) {
Settings.setTokens(tokenPublicPrefKey, tokenPublic, tokenSecretPrefKey, tokenSecret);
if (tokenPublic != null) {
Settings.setTokens(tempTokenPublicPrefKey, null, tempTokenSecretPrefKey, null);
}
}
@Override
protected String getAuthTitle() {
return res.getString(titleResId);
}
@Override
protected String getAuthDialogCompleted() {
return res.getString(R.string.auth_dialog_completed_oc, getAuthTitle());
}
/**
* Return an extended error in case of an invalid time stamp
*/
@Override
protected String getExtendedErrorMsg(HttpResponse response) {
OkapiError error = OkapiClient.decodeErrorResponse(response);
if (error.getResult() == OkapiErrors.INVALID_TIMESTAMP) {
return res.getString(R.string.init_login_popup_invalid_timestamp);
}
return StringUtils.EMPTY;
}
}
|