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

Commit 0e691c84 authored by Treehugger Robot's avatar Treehugger Robot Committed by Gerrit Code Review
Browse files

Merge changes Ifed43649,Ib59bf558

* changes:
  Search no longer crashes if you don't have the contacts permission.
  -Add cleaning blocked numbers stored in a separate database when people try to clean calllog database.
parents af52cd8e aa8a26e9
Loading
Loading
Loading
Loading
+69 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2018 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License
 */

package com.android.dialer.databasepopulator;

import android.annotation.TargetApi;
import android.content.ContentProviderOperation;
import android.content.ContentValues;
import android.content.Context;
import android.content.OperationApplicationException;
import android.os.Build.VERSION_CODES;
import android.os.RemoteException;
import android.provider.BlockedNumberContract;
import android.provider.BlockedNumberContract.BlockedNumbers;
import android.support.annotation.NonNull;
import com.android.dialer.common.Assert;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/** Populates the device database with blocked number entries. */
public class BlockedBumberPopulator {

  private static final List<ContentValues> values =
      Arrays.asList(
          createContentValuesWithNumber("123456789"), createContentValuesWithNumber("987654321"));

  @TargetApi(VERSION_CODES.N)
  public static void populateBlockedNumber(@NonNull Context context) {
    ArrayList<ContentProviderOperation> operations = new ArrayList<>();
    for (ContentValues value : values) {
      operations.add(
          ContentProviderOperation.newInsert(BlockedNumbers.CONTENT_URI)
              .withValues(value)
              .withYieldAllowed(true)
              .build());
    }
    try {
      context.getContentResolver().applyBatch(BlockedNumberContract.AUTHORITY, operations);
    } catch (RemoteException | OperationApplicationException e) {
      Assert.fail("error adding block number entries: " + e);
    }
  }

  @TargetApi(VERSION_CODES.N)
  public static void deleteBlockedNumbers(@NonNull Context context) {
    // clean BlockedNumbers db
    context.getContentResolver().delete(BlockedNumbers.CONTENT_URI, null, null);
  }

  private static ContentValues createContentValuesWithNumber(String number) {
    ContentValues contentValues = new ContentValues();
    contentValues.put(BlockedNumbers.COLUMN_ORIGINAL_NUMBER, number);
    return contentValues;
  }
}
+8 −6
Original line number Diff line number Diff line
@@ -75,13 +75,13 @@ public final class CallLogPopulator {
  };

  @WorkerThread
  public static void populateCallLog(@NonNull Context context) {
    populateCallLog(context, false);
  public static void populateCallLog(@NonNull Context context, boolean isWithoutMissedCalls) {
    populateCallLog(context, isWithoutMissedCalls, false);
  }

  @WorkerThread
  public static void populateCallLogWithoutMissed(@NonNull Context context) {
    populateCallLog(context, true);
  public static void populateCallLog(@NonNull Context context) {
    populateCallLog(context, false);
  }

  @WorkerThread
@@ -119,8 +119,8 @@ public final class CallLogPopulator {
  }

  @WorkerThread
  public static void populateCallLog(@NonNull Context context, boolean isWithoutMissedCalls) {
    populateCallLog(context, isWithoutMissedCalls, false);
  public static void populateCallLogWithoutMissed(@NonNull Context context) {
    populateCallLog(context, true);
  }

  @WorkerThread
@@ -138,6 +138,8 @@ public final class CallLogPopulator {
    }
  }



  @AutoValue
  abstract static class CallEntry {
    @NonNull
+6 −0
Original line number Diff line number Diff line
@@ -28,9 +28,11 @@ import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.text.TextUtils;
import com.android.contacts.common.preference.ContactsPreferences;
import com.android.dialer.common.LogUtil;
import com.android.dialer.searchfragment.common.Projections;
import com.android.dialer.searchfragment.common.SearchCursor;
import com.android.dialer.smartdial.SmartDialCursorLoader;
import com.android.dialer.util.PermissionsUtil;

/** Cursor Loader for CP2 contacts. */
public final class SearchContactsCursorLoader extends CursorLoader {
@@ -80,6 +82,10 @@ public final class SearchContactsCursorLoader extends CursorLoader {

  @Override
  public Cursor loadInBackground() {
    if (!PermissionsUtil.hasContactsReadPermissions(getContext())) {
      LogUtil.i("SearchContactsCursorLoader.loadInBackground", "Contacts permission denied.");
      return null;
    }
    return isRegularSearch ? regularSearchLoadInBackground() : dialpadSearchLoadInBackground();
  }

+11 −0
Original line number Diff line number Diff line
@@ -25,6 +25,8 @@ import android.os.Build.VERSION;
import android.os.Build.VERSION_CODES;
import android.provider.ContactsContract;
import android.support.annotation.Nullable;
import com.android.dialer.common.LogUtil;
import com.android.dialer.util.PermissionsUtil;
import com.google.auto.value.AutoValue;
import java.util.ArrayList;
import java.util.List;
@@ -47,6 +49,15 @@ public final class DirectoriesCursorLoader extends CursorLoader {
    super(context, getContentUri(), PROJECTION, null, null, ContactsContract.Directory._ID);
  }

  @Override
  public Cursor loadInBackground() {
    if (!PermissionsUtil.hasContactsReadPermissions(getContext())) {
      LogUtil.i("DirectoriesCursorLoader.loadInBackground", "Contacts permission denied.");
      return null;
    }
    return super.loadInBackground();
  }

  /**
   * Creates a complete list of directories from the data set loaded by this loader.
   *
+2 −0
Original line number Diff line number Diff line
@@ -25,6 +25,7 @@ import android.support.v7.app.AppCompatActivity;
import android.view.ActionProvider;
import com.android.dialer.common.concurrent.DialerExecutor.Worker;
import com.android.dialer.common.concurrent.DialerExecutorComponent;
import com.android.dialer.databasepopulator.BlockedBumberPopulator;
import com.android.dialer.databasepopulator.CallLogPopulator;
import com.android.dialer.databasepopulator.ContactsPopulator;
import com.android.dialer.databasepopulator.VoicemailPopulator;
@@ -182,6 +183,7 @@ final class SimulatorMainMenu {
      ContactsPopulator.deleteAllContacts(context);
      CallLogPopulator.deleteAllCallLog(context);
      VoicemailPopulator.deleteAllVoicemail(context);
      BlockedBumberPopulator.deleteBlockedNumbers(context);
      return null;
    }
  }