diff --git a/app/src/main/java/foundation/e/drive/operations/GetAliasOperation.java b/app/src/main/java/foundation/e/drive/operations/GetAliasOperation.java index 253127e8fe7a8717b3fbd18211453f1cef45a651..0602b6e27ccf9f521aa1b0ab75c29b297fb018a8 100644 --- a/app/src/main/java/foundation/e/drive/operations/GetAliasOperation.java +++ b/app/src/main/java/foundation/e/drive/operations/GetAliasOperation.java @@ -28,7 +28,7 @@ import timber.log.Timber; * /!\ Doesn't require NextcloudClient yet */ -public class GetAliasOperation extends RemoteOperation { +public class GetAliasOperation extends RemoteOperation> { private static final String ALIAS_PATH = "/ocs/v1.php/cloud/hide-my-email/"; diff --git a/app/src/main/java/foundation/e/drive/work/AccountUserInfoWorker.java b/app/src/main/java/foundation/e/drive/work/AccountUserInfoWorker.java index 6fcc83c52799047f65a5a33e0c97b67d625c2c3f..2326515fa52a1dfea45cab07d6251bb7f75c2233 100644 --- a/app/src/main/java/foundation/e/drive/work/AccountUserInfoWorker.java +++ b/app/src/main/java/foundation/e/drive/work/AccountUserInfoWorker.java @@ -71,22 +71,32 @@ public class AccountUserInfoWorker extends Worker { @NonNull @Override public Result doWork() { - account = CommonUtils.getAccount(mContext.getString(R.string.eelo_account_type), - accountManager); - final NextcloudClient client = DavClientProvider.getInstance().getNcClientInstance(account, mContext); - if (client != null) { - if (fetchUserInfo(client) && fetchAliases()) { - Glide.with(mContext) - .load(client.getBaseUri() + AccountsActivity.NON_OFFICIAL_AVATAR_PATH - + client.getUserId() + "/" + 300) - .diskCacheStrategy(DiskCacheStrategy.ALL) - .preload(); - updateWidget(mContext); - return Result.success(); - } else { - return Result.retry(); + + try { + account = CommonUtils.getAccount(mContext.getString(R.string.eelo_account_type), accountManager); + + if (account == null) { + return Result.failure(); + } + + final NextcloudClient client = DavClientProvider.getInstance().getNcClientInstance(account, mContext); + if (client != null) { + if (fetchUserInfo(client) && fetchAliases()) { + Glide.with(mContext) + .load(client.getBaseUri() + AccountsActivity.NON_OFFICIAL_AVATAR_PATH + + client.getUserId() + "/" + 300) + .diskCacheStrategy(DiskCacheStrategy.ALL) + .preload(); + updateWidget(mContext); + return Result.success(); + } else { + return Result.retry(); + } } + } catch (Throwable e) { + Timber.e(e, "Exception on retrieving accountUserInfo."); } + return Result.failure(); } @@ -98,23 +108,37 @@ public class AccountUserInfoWorker extends Worker { if (accountManager.getUserData(account, ACCOUNT_USER_ID_KEY) == null) { final String userId = userInfo.getId(); - client.setUserId(userId); - AccountManager.get(mContext).setUserData(account, ACCOUNT_USER_ID_KEY, userId); - Timber.v("UserId %s saved for account", userId); + + if (userId != null) { + client.setUserId(userId); + AccountManager.get(mContext).setUserData(account, ACCOUNT_USER_ID_KEY, userId); + Timber.v("UserId %s saved for account", userId); + } } final Quota userQuota = userInfo.getQuota(); - final double relativeQuota = userQuota.getRelative(); - long totalQuota = userQuota.getTotal(); - if (totalQuota <= 0) { - totalQuota = 0; + + long totalQuota = 0L; + long usedQuota = 0L; + double relativeQuota = 0.0D; + + if (userQuota != null) { + totalQuota = userQuota.getTotal(); + if (totalQuota <= 0) { + totalQuota = 0; + } + + usedQuota = userQuota.getUsed(); + relativeQuota = userQuota.getRelative(); } - final String groups = String.join(",", userInfo.getGroups()); + + final String groups = (userInfo.getGroups() != null) ? String.join(",", userInfo.getGroups()) : ""; + accountManager.setUserData(account, ACCOUNT_DATA_NAME, userInfo.getDisplayName()); accountManager.setUserData(account, ACCOUNT_DATA_EMAIL, userInfo.getEmail()); accountManager.setUserData(account, ACCOUNT_DATA_GROUPS, groups); accountManager.setUserData(account, ACCOUNT_DATA_TOTAL_QUOTA_KEY, "" + totalQuota); accountManager.setUserData(account, ACCOUNT_DATA_RELATIVE_QUOTA_KEY, "" + relativeQuota); - accountManager.setUserData(account, ACCOUNT_DATA_USED_QUOTA_KEY, "" + userQuota.getUsed()); + accountManager.setUserData(account, ACCOUNT_DATA_USED_QUOTA_KEY, "" + usedQuota); addNotifAboutQuota(relativeQuota); Timber.d("fetchUserInfo(): success"); @@ -185,9 +209,14 @@ public class AccountUserInfoWorker extends Worker { private boolean fetchAliases() { final OwnCloudClient ocClient = DavClientProvider.getInstance().getClientInstance(account, mContext); final String userId = accountManager.getUserData(account, ACCOUNT_USER_ID_KEY); + + if (userId == null || userId.isEmpty()) { + return false; + } + final GetAliasOperation getAliasOperation = new GetAliasOperation(userId); final RemoteOperationResult> ocsResult = getAliasOperation.execute(ocClient); - String aliases = ""; + String aliases = ""; if (ocsResult.isSuccess()) { final ArrayList aliasList = ocsResult.getResultData();