Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c31d0a84 authored by Reema Bajwa's avatar Reema Bajwa
Browse files

Propagate the right permission information on empty prepare response

This is a bug discovered by our QA team. The bug causes the calling app to
crash and hence, is critical to fix.

Bug: 286519644
Test: Built & deployed locally on device

Change-Id: Ie66e667dd0b8f581402e2e6202dee6c532e6d165
parent 25d7ad11
Loading
Loading
Loading
Loading
+11 −4
Original line number Diff line number Diff line
@@ -21,6 +21,7 @@ import static android.Manifest.permission.CREDENTIAL_MANAGER_SET_ORIGIN;
import static android.content.Context.CREDENTIAL_SERVICE;
import static android.content.pm.PackageManager.PERMISSION_GRANTED;

import android.Manifest;
import android.annotation.NonNull;
import android.annotation.Nullable;
import android.annotation.UserIdInt;
@@ -55,6 +56,7 @@ import android.provider.DeviceConfig;
import android.provider.Settings;
import android.service.credentials.CallingAppInfo;
import android.service.credentials.CredentialProviderInfoFactory;
import android.service.credentials.PermissionUtils;
import android.text.TextUtils;
import android.util.Pair;
import android.util.Slog;
@@ -546,11 +548,16 @@ public final class CredentialManagerService

            if (providerSessions.isEmpty()) {
                try {
                    // TODO: fix
                    prepareGetCredentialCallback.onResponse(
                            new PrepareGetCredentialResponseInternal(
                                    false, null,
                                    false, false, null));
                            new PrepareGetCredentialResponseInternal(PermissionUtils.hasPermission(
                                    mContext,
                                    callingPackage,
                                    Manifest.permission
                                            .CREDENTIAL_MANAGER_QUERY_CANDIDATE_CREDENTIALS),
                                    /*credentialResultTypes=*/null,
                                    /*hasAuthenticationResults=*/false,
                                    /*hasRemoteResults=*/false,
                                    /*pendingIntent=*/null));
                } catch (RemoteException e) {
                    Slog.e(
                            TAG,