/* * 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 android.telecom; import android.annotation.IntDef; import android.annotation.NonNull; import android.annotation.Nullable; import android.content.pm.ApplicationInfo; import android.graphics.drawable.Icon; import android.os.Parcel; import android.os.Parcelable; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.util.Objects; /** * Encapsulates information about an incoming or outgoing {@link Call} provided by a * {@link CallScreeningService}. *
* Call identified information is consumed by the {@link InCallService dialer} app to provide the * user with more information about a call. This can include information such as the name of the * caller, address, etc. Call identification information is persisted to the * {@link android.provider.CallLog}. */ public final class CallIdentification implements Parcelable { /** * Builder for {@link CallIdentification} instances. *
* A {@link CallScreeningService} uses this class to create new instances of * {@link CallIdentification} for a screened call. */ public static class Builder { private String mName; private String mDescription; private String mDetails; private Icon mPhoto; private int mNuisanceConfidence = CallIdentification.CONFIDENCE_UNKNOWN; private String mPackageName; private String mAppName; /** * Default builder constructor. */ public Builder() { // Default constructor } /** * Create instance of call identification with specified package/app name. * * @param callIdPackageName The package name. * @param callIdAppName The app name. * @hide */ public Builder(String callIdPackageName, String callIdAppName) { mPackageName = callIdPackageName; mAppName = callIdAppName; } /** * Sets the name associated with the {@link CallIdentification} being built. *
* Could be a business name, for example. * * @param name The name associated with the call, or {@code null} if none is provided. * @return Builder instance. */ public Builder setName(@Nullable String name) { mName = name; return this; } /** * Sets the description associated with the {@link CallIdentification} being built. *
* A description of the call as identified by a {@link CallScreeningService}. The * description is typically presented by Dialer apps after the * {@link CallIdentification#getName() name} to provide a short piece of relevant * information about the call. This could include a location, address, or a message * regarding the potential nature of the call (e.g. potential telemarketer). * * @param description The call description, or {@code null} if none is provided. * @return Builder instance. */ public Builder setDescription(@Nullable String description) { mDescription = description; return this; } /** * Sets the details associated with the {@link CallIdentification} being built. *
* The details is typically presented by Dialer apps after the * {@link CallIdentification#getName() name} and * {@link CallIdentification#getDescription() description} to provide further clarifying * information about the call. This could include, for example, the opening hours of a * business, or a stats about the number of times a call has been reported as spam. * * @param details The call details, or {@code null} if none is provided. * @return Builder instance. */ public Builder setDetails(@Nullable String details) { mDetails = details; return this; } /** * Sets the photo associated with the {@link CallIdentification} being built. *
* This could be, for example, a business logo, or a photo of the caller. * * @param photo The photo associated with the call, or {@code null} if none was provided. * @return Builder instance. */ public Builder setPhoto(@Nullable Icon photo) { mPhoto = photo; return this; } /** * Sets the nuisance confidence with the {@link CallIdentification} being built. *
* This can be used to specify how confident the {@link CallScreeningService} is that a call * is or is not a nuisance call. * * @param nuisanceConfidence The nuisance confidence. * @return The builder. */ public Builder setNuisanceConfidence(@NuisanceConfidence int nuisanceConfidence) { mNuisanceConfidence = nuisanceConfidence; return this; } /** * Creates a new instance of {@link CallIdentification} based on the parameters set in this * builder. * * @return {@link CallIdentification} instance. */ public CallIdentification build() { return new CallIdentification(mName, mDescription, mDetails, mPhoto, mNuisanceConfidence, mPackageName, mAppName); } } /** @hide */ @Retention(RetentionPolicy.SOURCE) @IntDef( prefix = { "CONFIDENCE_" }, value = {CONFIDENCE_NUISANCE, CONFIDENCE_LIKELY_NUISANCE, CONFIDENCE_UNKNOWN, CONFIDENCE_LIKELY_NOT_NUISANCE, CONFIDENCE_NOT_NUISANCE}) public @interface NuisanceConfidence {} /** * Call has been identified as a nuisance call. *
* Returned from {@link #getNuisanceConfidence()} to indicate that a * {@link CallScreeningService} to indicate how confident it is that a call is or is not a * nuisance call. */ public static final int CONFIDENCE_NUISANCE = 2; /** * Call has been identified as a likely nuisance call. *
* Returned from {@link #getNuisanceConfidence()} to indicate that a * {@link CallScreeningService} to indicate how confident it is that a call is or is not a * nuisance call. */ public static final int CONFIDENCE_LIKELY_NUISANCE = 1; /** * Call could not be classified as nuisance or non-nuisance. *
* Returned from {@link #getNuisanceConfidence()} to indicate that a * {@link CallScreeningService} to indicate how confident it is that a call is or is not a * nuisance call. */ public static final int CONFIDENCE_UNKNOWN = 0; /** * Call has been identified as not likely to be a nuisance call. *
* Returned from {@link #getNuisanceConfidence()} to indicate that a * {@link CallScreeningService} to indicate how confident it is that a call is or is not a * nuisance call. */ public static final int CONFIDENCE_LIKELY_NOT_NUISANCE = -1; /** * Call has been identified as not a nuisance call. *
* Returned from {@link #getNuisanceConfidence()} to indicate that a
* {@link CallScreeningService} to indicate how confident it is that a call is or is not a
* nuisance call.
*/
public static final int CONFIDENCE_NOT_NUISANCE = -2;
/**
* Default constructor for {@link CallIdentification}.
*
* @param name The name.
* @param description The description.
* @param details The details.
* @param photo The photo.
* @param nuisanceConfidence Confidence that this is a nuisance call.
* @hide
*/
private CallIdentification(@Nullable String name, @Nullable String description,
@Nullable String details, @Nullable Icon photo,
@NuisanceConfidence int nuisanceConfidence) {
this(name, description, details, photo, nuisanceConfidence, null, null);
}
/**
* Default constructor for {@link CallIdentification}.
*
* @param name The name.
* @param description The description.
* @param details The details.
* @param photo The photo.
* @param nuisanceConfidence Confidence that this is a nuisance call.
* @param callScreeningPackageName Package name of the {@link CallScreeningService} which
* provided the call identification.
* @param callScreeningAppName App name of the {@link CallScreeningService} which provided the
* call identification.
* @hide
*/
private CallIdentification(@Nullable String name, @Nullable String description,
@Nullable String details, @Nullable Icon photo,
@NuisanceConfidence int nuisanceConfidence, @NonNull String callScreeningPackageName,
@NonNull String callScreeningAppName) {
mName = name;
mDescription = description;
mDetails = details;
mPhoto = photo;
mNuisanceConfidence = nuisanceConfidence;
mCallScreeningAppName = callScreeningPackageName;
mCallScreeningPackageName = callScreeningAppName;
}
private String mName;
private String mDescription;
private String mDetails;
private Icon mPhoto;
private int mNuisanceConfidence;
private String mCallScreeningPackageName;
private String mCallScreeningAppName;
@Override
public int describeContents() {
return 0;
}
@Override
public void writeToParcel(Parcel parcel, int i) {
parcel.writeString(mName);
parcel.writeString(mDescription);
parcel.writeString(mDetails);
parcel.writeParcelable(mPhoto, 0);
parcel.writeInt(mNuisanceConfidence);
parcel.writeString(mCallScreeningPackageName);
parcel.writeString(mCallScreeningAppName);
}
/**
* Responsible for creating CallIdentification objects for deserialized Parcels.
*/
public static final Parcelable.Creator
* The name of the call as identified by a {@link CallScreeningService}. Could be a business
* name, for example.
*
* @return The name associated with the number, or {@code null} if none was provided.
*/
public final @Nullable String getName() {
return mName;
}
/**
* Description of the call.
*
* A description of the call as identified by a {@link CallScreeningService}. The description
* is typically presented by Dialer apps after the {@link #getName() name} to provide a short
* piece of relevant information about the call. This could include a location, address, or a
* message regarding the potential nature of the call (e.g. potential telemarketer).
*
* @return The call description, or {@code null} if none was provided.
*/
public final @Nullable String getDescription() {
return mDescription;
}
/**
* Details of the call.
*
* Details of the call as identified by a {@link CallScreeningService}. The details
* are typically presented by Dialer apps after the {@link #getName() name} and
* {@link #getDescription() description} to provide further clarifying information about the
* call. This could include, for example, the opening hours of a business, or stats about
* the number of times a call has been reported as spam.
*
* @return The call details, or {@code null} if none was provided.
*/
public final @Nullable String getDetails() {
return mDetails;
}
/**
* Photo associated with the call.
*
* A photo associated with the call as identified by a {@link CallScreeningService}. This
* could be, for example, a business logo, or a photo of the caller.
*
* @return The photo associated with the call, or {@code null} if none was provided.
*/
public final @Nullable Icon getPhoto() {
return mPhoto;
}
/**
* Indicates the likelihood that this call is a nuisance call.
*
* How likely the call is a nuisance call, as identified by a {@link CallScreeningService}.
*
* @return The nuisance confidence.
*/
public final @NuisanceConfidence
int getNuisanceConfidence() {
return mNuisanceConfidence;
}
/**
* The package name of the {@link CallScreeningService} which provided the
* {@link CallIdentification}.
*
* A {@link CallScreeningService} may not set this property; it is set by the system.
* @return the package name
*/
public final @NonNull String getCallScreeningPackageName() {
return mCallScreeningPackageName;
}
/**
* The {@link android.content.pm.PackageManager#getApplicationLabel(ApplicationInfo) name} of
* the {@link CallScreeningService} which provided the {@link CallIdentification}.
*
* A {@link CallScreeningService} may not set this property; it is set by the system.
*
* @return The name of the app.
*/
public final @NonNull String getCallScreeningAppName() {
return mCallScreeningAppName;
}
/**
* Set the package name of the {@link CallScreeningService} which provided this information.
*
* @param callScreeningPackageName The package name.
* @hide
*/
public void setCallScreeningPackageName(@NonNull String callScreeningPackageName) {
mCallScreeningPackageName = callScreeningPackageName;
}
/**
* Set the app name of the {@link CallScreeningService} which provided this information.
*
* @param callScreeningAppName The app name.
* @hide
*/
public void setCallScreeningAppName(@NonNull String callScreeningAppName) {
mCallScreeningAppName = callScreeningAppName;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
CallIdentification that = (CallIdentification) o;
// Note: mPhoto purposely omit as no good comparison exists.
return mNuisanceConfidence == that.mNuisanceConfidence
&& Objects.equals(mName, that.mName)
&& Objects.equals(mDescription, that.mDescription)
&& Objects.equals(mDetails, that.mDetails)
&& Objects.equals(mCallScreeningAppName, that.mCallScreeningAppName)
&& Objects.equals(mCallScreeningPackageName, that.mCallScreeningPackageName);
}
@Override
public int hashCode() {
return Objects.hash(mName, mDescription, mDetails, mPhoto, mNuisanceConfidence,
mCallScreeningAppName, mCallScreeningPackageName);
}
}