mirror of
https://codeberg.org/Bazsalanszky/Infinity-For-Lemmy.git
synced 2025-10-24 14:49:09 +02:00
Check the user token when opening the app
This commit is contained in:
@@ -67,6 +67,9 @@ public class LoginActivity extends BaseActivity {
|
||||
private static final String ENABLE_DOM_STATE = "EDS";
|
||||
private static final String IS_AGREE_TO_USER_AGGREMENT_STATE = "IATUAS";
|
||||
|
||||
public static final String EXTRA_INPUT_USERNAME = "INPUT_USERNAME";
|
||||
public static final String EXTRA_INPUT_INSTANCE = "INPUT_INSTANCE";
|
||||
|
||||
@BindView(R.id.coordinator_layout_login_activity)
|
||||
CoordinatorLayout coordinatorLayout;
|
||||
@BindView(R.id.appbar_layout_login_activity)
|
||||
@@ -149,6 +152,17 @@ public class LoginActivity extends BaseActivity {
|
||||
isAgreeToUserAgreement = savedInstanceState.getBoolean(IS_AGREE_TO_USER_AGGREMENT_STATE);
|
||||
}
|
||||
|
||||
// Get username and instance from intent
|
||||
Intent intent = getIntent();
|
||||
String username_intent = intent.getStringExtra(EXTRA_INPUT_USERNAME);
|
||||
String instance_intent = intent.getStringExtra(EXTRA_INPUT_INSTANCE);
|
||||
if (username_intent != null) {
|
||||
username_input.setText(username_intent);
|
||||
}
|
||||
if (instance_intent != null) {
|
||||
instance_input.setText(instance_intent);
|
||||
}
|
||||
|
||||
LemmyVerseFetchInstances.INSTANCE.fetchInstances(mLemmyVerseRetrofit, new FetchInstancesListener() {
|
||||
|
||||
@Override
|
||||
|
@@ -248,6 +248,8 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
||||
private int fabOption;
|
||||
private int inboxCount;
|
||||
|
||||
private boolean mBearerTokenUsed = true;
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
SplashScreen.installSplashScreen(this);
|
||||
@@ -340,7 +342,7 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
||||
|
||||
mAccessToken = mCurrentAccountSharedPreferences.getString(SharedPreferencesUtils.ACCESS_TOKEN, null);
|
||||
mRetrofit.setAccessToken(mAccessToken);
|
||||
|
||||
mBearerTokenUsed = mCurrentAccountSharedPreferences.getBoolean(SharedPreferencesUtils.BEARER_TOKEN_AUTH, true);
|
||||
|
||||
mAccountName = mCurrentAccountSharedPreferences.getString(SharedPreferencesUtils.ACCOUNT_NAME, null);
|
||||
mAccountQualifiedName = mCurrentAccountSharedPreferences.getString(SharedPreferencesUtils.ACCOUNT_QUALIFIED_NAME, null);
|
||||
@@ -374,6 +376,8 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
||||
mRetrofit.setBaseURL(instancePreference);
|
||||
this.recreate();
|
||||
}
|
||||
} else {
|
||||
checkUserToken();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1081,6 +1085,34 @@ public class MainActivity extends BaseActivity implements SortTypeSelectionCallb
|
||||
}
|
||||
}
|
||||
|
||||
private void checkUserToken() {
|
||||
if (mBearerTokenUsed) {
|
||||
FetchUserData.validateAuthToken(mRetrofit.getRetrofit(), new FetchUserData.ValidateAuthTokenListener() {
|
||||
@Override
|
||||
public void onValidateAuthTokenSuccess() {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onValidateAuthTokenFailed() {
|
||||
// Alert user that the token is invalid and they need to re-login
|
||||
new MaterialAlertDialogBuilder(MainActivity.this, R.style.MaterialAlertDialogTheme)
|
||||
.setTitle(R.string.token_expired)
|
||||
.setMessage(R.string.token_expired_message)
|
||||
.setPositiveButton(R.string.ok, (dialogInterface, i) -> {
|
||||
Intent intent = new Intent(MainActivity.this, LoginActivity.class);
|
||||
// Username without instance
|
||||
String username = mAccountName.substring(0, mAccountQualifiedName.indexOf("@"));
|
||||
intent.putExtra(LoginActivity.EXTRA_INPUT_USERNAME, username);
|
||||
intent.putExtra(LoginActivity.EXTRA_INPUT_INSTANCE, mRetrofit.getBaseURL());
|
||||
startActivity(intent);
|
||||
})
|
||||
.setCancelable(false)
|
||||
.show();
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
private void loadUserData() {
|
||||
if (!mFetchUserInfoSuccess) {
|
||||
FetchUserData.fetchUnreadCount(mRetrofit.getRetrofit(), mAccessToken, new FetchUserData.FetchUserUnreadCountListener() {
|
||||
|
@@ -66,6 +66,9 @@ public interface LemmyAPI {
|
||||
@GET("api/v3/user/unread_count")
|
||||
Call<MessageCount> userUnreadCount(@NonNull @Query("auth") String access_token);
|
||||
|
||||
@GET("api/v3/user/validate_auth")
|
||||
Call<String> userValidateAuth();
|
||||
|
||||
@Headers("Content-Type: application/json")
|
||||
@POST("api/v3/user/mention/mark_as_read")
|
||||
Call<String> userMentionMarkAsRead(@Body ReadMessageDTO params);
|
||||
|
@@ -107,6 +107,33 @@ public class FetchUserData {
|
||||
});
|
||||
}
|
||||
|
||||
public static void validateAuthToken(Retrofit retrofit, ValidateAuthTokenListener validateAuthTokenListener) {
|
||||
LemmyAPI api = retrofit.create(LemmyAPI.class);
|
||||
|
||||
Call<String> validateAuthToken = api.userValidateAuth();
|
||||
validateAuthToken.enqueue(new Callback<>() {
|
||||
@Override
|
||||
public void onResponse(@NonNull Call<String> call, @NonNull retrofit2.Response<String> response) {
|
||||
if (response.isSuccessful()) {
|
||||
validateAuthTokenListener.onValidateAuthTokenSuccess();
|
||||
} else {
|
||||
validateAuthTokenListener.onValidateAuthTokenFailed();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onFailure(@NonNull Call<String> call, @NonNull Throwable t) {
|
||||
validateAuthTokenListener.onValidateAuthTokenFailed();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public interface ValidateAuthTokenListener {
|
||||
void onValidateAuthTokenSuccess();
|
||||
|
||||
void onValidateAuthTokenFailed();
|
||||
}
|
||||
|
||||
public interface FetchUserUnreadCountListener {
|
||||
void onFetchUserUnreadCountSuccess(int unreadCount);
|
||||
|
||||
|
@@ -1322,4 +1322,6 @@
|
||||
<string name="settings_credits_original_app_description">"Infinity was created by u/Hostilenemy "</string>
|
||||
<string name="the_url_of_you_prefered_lemmy_instance_with_or_without_the_https_prefix">The URL of you prefered Lemmy instance with or without the https:// prefix</string>
|
||||
<string name="sort_scaled">Scaled</string>
|
||||
<string name="token_expired">Token Expired</string>
|
||||
<string name="token_expired_message">"Your token has been expired. As Eternity does not store your password, you need to manually log back in! "</string>
|
||||
</resources>
|
Reference in New Issue
Block a user