/* * Copyright (C) 2016 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.spam; import android.preference.Preference; import android.preference.Preference.OnPreferenceChangeListener; import android.provider.CallLog.Calls; import android.support.annotation.Nullable; import com.android.dialer.DialerPhoneNumber; import com.android.dialer.logging.ContactLookupResult; import com.android.dialer.logging.ContactSource; import com.android.dialer.logging.ReportingLocation; import com.android.dialer.spam.status.SpamStatus; import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableSet; import com.google.common.util.concurrent.ListenableFuture; /** Allows the container application to mark calls as spam. */ public interface Spam { /** * Checks if each of numbers in the given list is suspected of being a spam. * * @param dialerPhoneNumbers A set of {@link DialerPhoneNumber}. * @return A {@link ListenableFuture} of a map that maps each number to its {@link SpamStatus}. */ ListenableFuture> batchCheckSpamStatus( ImmutableSet dialerPhoneNumbers); /** * Checks if the given number is suspected of being spam. * * @param dialerPhoneNumber the phone number. * @return the {@link SpamStatus} for the given number. */ ListenableFuture checkSpamStatus(DialerPhoneNumber dialerPhoneNumber); /** * Checks if the given number is suspected of being spam. * *

See {@link #checkSpamStatus(DialerPhoneNumber)}. * * @param number the phone number. * @param defaultCountryIso the default country to use if it's not part of the number. * @return the {@link SpamStatus} for the given number. */ ListenableFuture checkSpamStatus(String number, @Nullable String defaultCountryIso); /** * Called as an indication that the Spam implementation should check whether downloading a spam * list needs to occur or not. * * @param isEnabledByUser true if spam is enabled by the user. Generally, this value should be * passed as {@link SpamSettings#isSpamEnabled()}. In the scenario where the user toggles the * spam setting isSpamEnabled returns stale data: the SharedPreferences will not have updated * prior to executing {@link OnPreferenceChangeListener#onPreferenceChange(Preference, * Object)}. For that case, use the new value provided in the onPreferenceChange callback. * @return a future containing no value. It is only an indication of success or failure of the * operation. */ ListenableFuture updateSpamListDownload(boolean isEnabledByUser); /** * Synchronously checks if the given number is suspected of being a spamer. * * @param number The phone number of the call. * @param countryIso The country ISO of the call. * @return True if the number is spam. */ boolean checkSpamStatusSynchronous(String number, String countryIso); /** * Returns a {@link ListenableFuture} indicating whether the spam data have been updated since * {@code timestampMillis}. * *

It is the caller's responsibility to ensure the timestamp is in milliseconds. Failure to do * so will result in undefined behavior. */ ListenableFuture dataUpdatedSince(long timestampMillis); /** * Reports number as spam. * * @param number The number to be reported. * @param countryIso The country ISO of the number. * @param callType Whether the type of call is missed, voicemail, etc. Example of this is {@link * android.provider.CallLog.Calls#VOICEMAIL_TYPE}. * @param from Where in the dialer this was reported from. Must be one of {@link * com.android.dialer.logging.ReportingLocation}. * @param contactLookupResultType The result of the contact lookup for this phone number. Must be * one of {@link com.android.dialer.logging.ContactLookupResult}. */ void reportSpamFromAfterCallNotification( String number, String countryIso, int callType, ReportingLocation.Type from, ContactLookupResult.Type contactLookupResultType); /** * Reports number as spam. * * @param number The number to be reported. * @param countryIso The country ISO of the number. * @param callType Whether the type of call is missed, voicemail, etc. Example of this is {@link * android.provider.CallLog.Calls#VOICEMAIL_TYPE}. * @param from Where in the dialer this was reported from. Must be one of {@link * com.android.dialer.logging.ReportingLocation}. * @param contactSourceType If we have cached contact information for the phone number, this * indicates its source. Must be one of {@link com.android.dialer.logging.ContactSource}. */ void reportSpamFromCallHistory( String number, String countryIso, int callType, ReportingLocation.Type from, ContactSource.Type contactSourceType); /** * Reports number as not spam. * * @param number The number to be reported. * @param countryIso The country ISO of the number. * @param callType Whether the type of call is missed, voicemail, etc. Example of this is {@link * android.provider.CallLog.Calls#VOICEMAIL_TYPE}. * @param from Where in the dialer this was reported from. Must be one of {@link * com.android.dialer.logging.ReportingLocation}. * @param contactLookupResultType The result of the contact lookup for this phone number. Must be * one of {@link com.android.dialer.logging.ContactLookupResult}. */ void reportNotSpamFromAfterCallNotification( String number, String countryIso, int callType, ReportingLocation.Type from, ContactLookupResult.Type contactLookupResultType); /** * Reports number as not spam. * * @param number The number to be reported. * @param countryIso The country ISO of the number. * @param callType Whether the type of call is missed, voicemail, etc. Example of this is {@link * android.provider.CallLog.Calls#VOICEMAIL_TYPE}. * @param from Where in the dialer this was reported from. Must be one of {@link * com.android.dialer.logging.ReportingLocation}. * @param contactSourceType If we have cached contact information for the phone number, this * indicates its source. Must be one of {@link com.android.dialer.logging.ContactSource}. */ void reportNotSpamFromCallHistory( String number, String countryIso, int callType, ReportingLocation.Type from, ContactSource.Type contactSourceType); /** * Given a number's spam status and a call type, determine if the call should be shown as spam. * *

We show a call as spam if * *

    *
  • the number is marked as spam, and *
  • the call is not an outgoing call. *
* *

This is because spammers can hide behind a legit number (e.g., a customer service number). * We don't want to show a spam icon when users call it. * * @param isNumberSpam Whether the number is spam. * @param callType One of the types in {@link android.provider.CallLog.Calls#TYPE}. * @return true if the number is spam *and* the call is not an outgoing call. */ static boolean shouldShowAsSpam(boolean isNumberSpam, int callType) { return isNumberSpam && (callType != Calls.OUTGOING_TYPE); } }