From 3ed0c281a143789ea8187dba60dba6c6b5db9009 Mon Sep 17 00:00:00 2001 From: Eric Erfanian Date: Tue, 23 May 2017 08:59:53 -0700 Subject: Update Dialer to v10 RC39 This release was created following the instructions at: go/dialer-aosp-release Subsequent dialer releases will follow as O bugs are fixed, until we reach our final RC. Version: 10 Candidate: RC39 Branch: dialer-android_release_branch/153304843.1 dialer-android_20170416.00/dialer-android_20170416.00_RC39 This release contains the following bug fixes since RC32: Bug: 38137349 38249439 38299262 38329114 Test: make Change-Id: I65f695db8aa20902fa60835d58b41cfdfe42704b --- .../voicemail/impl/VvmPackageInstallHandler.java | 89 +--------------------- 1 file changed, 1 insertion(+), 88 deletions(-) (limited to 'java/com/android/voicemail/impl/VvmPackageInstallHandler.java') diff --git a/java/com/android/voicemail/impl/VvmPackageInstallHandler.java b/java/com/android/voicemail/impl/VvmPackageInstallHandler.java index 8d1fb2289..07900c26f 100644 --- a/java/com/android/voicemail/impl/VvmPackageInstallHandler.java +++ b/java/com/android/voicemail/impl/VvmPackageInstallHandler.java @@ -19,17 +19,10 @@ package com.android.voicemail.impl; import android.annotation.SuppressLint; import android.annotation.TargetApi; import android.content.Context; -import android.content.SharedPreferences; -import android.content.pm.ChangedPackages; import android.os.Build.VERSION_CODES; -import android.preference.PreferenceManager; -import android.provider.Settings.Global; import android.telecom.PhoneAccountHandle; import android.telecom.TelecomManager; -import android.util.ArraySet; -import com.android.dialer.common.PackageUtils; import com.android.voicemail.impl.settings.VisualVoicemailSettingsUtil; -import java.util.Set; /** * When a new package is installed, check if it matches any of the vvm carrier apps of the currently @@ -45,91 +38,11 @@ import java.util.Set; @TargetApi(VERSION_CODES.O) public final class VvmPackageInstallHandler { - private static final String LAST_BOOT_COUNT = - "com.android.voicemail.impl.VvmPackageInstallHandler.LAST_BOOT_COUNT"; - - private static final String CHANGED_PACKAGES_SEQUENCE_NUMBER = - "com.android.voicemail.impl.VvmPackageInstallHandler.CHANGED_PACKAGES_SEQUENCE_NUMBER"; - - private static final String INSTALLED_CARRIER_PACKAGES = - "com.android.voicemail.impl.VvmPackageInstallHandler.INSTALLED_CARRIER_PACKAGES"; - - /** - * Perform a scan of all changed apps since the last invocation to see if the carrier VVM app is - * installed. - */ - public static void scanNewPackages(Context context) { - SharedPreferences sharedPreferences = PreferenceManager.getDefaultSharedPreferences(context); - int sequenceNumber = sharedPreferences.getInt(CHANGED_PACKAGES_SEQUENCE_NUMBER, 0); - int lastBootCount = sharedPreferences.getInt(LAST_BOOT_COUNT, 0); - int bootCount = Global.getInt(context.getContentResolver(), Global.BOOT_COUNT, 0); - if (lastBootCount != bootCount) { - VvmLog.i( - "VvmPackageInstallHandler.scanNewPackages", "reboot detected, resetting sequence number"); - sequenceNumber = 0; - sharedPreferences.edit().putInt(LAST_BOOT_COUNT, bootCount).apply(); - } - - ChangedPackages changedPackages = - context.getPackageManager().getChangedPackages(sequenceNumber); - if (changedPackages == null) { - VvmLog.i("VvmPackageInstallHandler.scanNewPackages", "no package has changed"); - return; - } - sharedPreferences - .edit() - .putInt(CHANGED_PACKAGES_SEQUENCE_NUMBER, changedPackages.getSequenceNumber()) - .apply(); - - Set installedPackages = - sharedPreferences.getStringSet(INSTALLED_CARRIER_PACKAGES, new ArraySet<>()); - - Set monitoredPackage = getMonitoredPackages(context); - installedPackages.removeIf((packageName) -> !monitoredPackage.contains(packageName)); - - for (String packageName : changedPackages.getPackageNames()) { - if (!monitoredPackage.contains(packageName)) { - continue; - } - if (PackageUtils.isPackageEnabled(packageName, context)) { - if (!installedPackages.contains(packageName)) { - VvmLog.i("VvmPackageInstallHandler.scanNewPackages", "new package found: " + packageName); - installedPackages.add(packageName); - handlePackageInstalled(context, packageName); - } - } else { - installedPackages.remove(packageName); - } - } - sharedPreferences.edit().putStringSet(INSTALLED_CARRIER_PACKAGES, installedPackages).apply(); - } - - private static Set getMonitoredPackages(Context context) { - Set result = new ArraySet<>(); - context - .getSystemService(TelecomManager.class) - .getCallCapablePhoneAccounts() - .forEach( - (phoneAccountHandle -> { - OmtpVvmCarrierConfigHelper carrierConfigHelper = - new OmtpVvmCarrierConfigHelper(context, phoneAccountHandle); - if (!carrierConfigHelper.isValid()) { - return; - } - if (carrierConfigHelper.getCarrierVvmPackageNames() == null) { - return; - } - result.addAll(carrierConfigHelper.getCarrierVvmPackageNames()); - })); - - return result; - }; - /** * Iterates through all phone account and disable VVM on a account if {@code packageName} is * listed as a carrier VVM package. */ - private static void handlePackageInstalled(Context context, String packageName) { + public static void handlePackageInstalled(Context context, String packageName) { // This get called every time an app is installed and will be noisy. Don't log until the app // is identified as a carrier VVM app. for (PhoneAccountHandle phoneAccount : -- cgit v1.2.3