summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSantos Cordon <santoscordon@google.com>2014-02-19 01:59:32 -0800
committerSantos Cordon <santoscordon@google.com>2014-02-24 16:02:59 -0800
commitb340c331bca330e9cb60ce6e398b3c014e1a14c7 (patch)
treecabd07dac8762d6da8a26ecf878c75912ed71886
parentfefe41a79916c2a4701828fcba6d7b8fb95d6a02 (diff)
downloadframeworks_base-b340c331bca330e9cb60ce6e398b3c014e1a14c7.zip
frameworks_base-b340c331bca330e9cb60ce6e398b3c014e1a14c7.tar.gz
frameworks_base-b340c331bca330e9cb60ce6e398b3c014e1a14c7.tar.bz2
Adding API support for incoming calls.
Change-Id: I7b1530d13e5adac530c4f451aa2cd97f275f9cae
-rw-r--r--api/current.txt11
-rw-r--r--telecomm/java/android/telecomm/CallService.java63
-rw-r--r--telecomm/java/android/telecomm/CallServiceDescriptor.java3
-rw-r--r--telecomm/java/android/telecomm/ICallService.aidl32
-rw-r--r--telecomm/java/android/telecomm/ICallServiceAdapter.aidl12
5 files changed, 84 insertions, 37 deletions
diff --git a/api/current.txt b/api/current.txt
index 6228848..3fa628f 100644
--- a/api/current.txt
+++ b/api/current.txt
@@ -24216,13 +24216,15 @@ package android.telecomm {
public abstract class CallService extends android.app.Service {
ctor public CallService();
+ method public abstract void answer(java.lang.String);
method public abstract void call(android.telecomm.CallInfo);
- method public abstract void confirmIncomingCall(java.lang.String, java.lang.String);
method public abstract void disconnect(java.lang.String);
method public final android.os.IBinder getBinder();
method public abstract void isCompatibleWith(android.telecomm.CallInfo);
method public final android.os.IBinder onBind(android.content.Intent);
+ method public abstract void reject(java.lang.String);
method public abstract void setCallServiceAdapter(android.telecomm.ICallServiceAdapter);
+ method public abstract void setIncomingCallId(java.lang.String);
}
public final class CallServiceDescriptor implements android.os.Parcelable {
@@ -24232,6 +24234,7 @@ package android.telecomm {
method public android.content.ComponentName getServiceComponent();
method public static android.telecomm.CallServiceDescriptor.Builder newBuilder(android.content.Context);
method public void writeToParcel(android.os.Parcel, int);
+ field public static final android.os.Parcelable.Creator CREATOR;
field public static final int FLAG_MOBILE = 4; // 0x4
field public static final int FLAG_PSTN = 2; // 0x2
field public static final int FLAG_WIFI = 1; // 0x1
@@ -24274,11 +24277,13 @@ package android.telecomm {
}
public abstract interface ICallService implements android.os.IInterface {
+ method public abstract void answer(java.lang.String) throws android.os.RemoteException;
method public abstract void call(android.telecomm.CallInfo) throws android.os.RemoteException;
- method public abstract void confirmIncomingCall(java.lang.String, java.lang.String) throws android.os.RemoteException;
method public abstract void disconnect(java.lang.String) throws android.os.RemoteException;
method public abstract void isCompatibleWith(android.telecomm.CallInfo) throws android.os.RemoteException;
+ method public abstract void reject(java.lang.String) throws android.os.RemoteException;
method public abstract void setCallServiceAdapter(android.telecomm.ICallServiceAdapter) throws android.os.RemoteException;
+ method public abstract void setIncomingCallId(java.lang.String) throws android.os.RemoteException;
}
public static abstract class ICallService.Stub extends android.os.Binder implements android.telecomm.ICallService {
@@ -24289,8 +24294,8 @@ package android.telecomm {
}
public abstract interface ICallServiceAdapter implements android.os.IInterface {
- method public abstract void handleConfirmedIncomingCall(android.telecomm.CallInfo) throws android.os.RemoteException;
method public abstract void handleFailedOutgoingCall(java.lang.String, java.lang.String) throws android.os.RemoteException;
+ method public abstract void handleIncomingCall(android.telecomm.CallInfo) throws android.os.RemoteException;
method public abstract void handleSuccessfulOutgoingCall(java.lang.String) throws android.os.RemoteException;
method public abstract void setActive(java.lang.String) throws android.os.RemoteException;
method public abstract void setCompatibleWith(java.lang.String, boolean) throws android.os.RemoteException;
diff --git a/telecomm/java/android/telecomm/CallService.java b/telecomm/java/android/telecomm/CallService.java
index 9bad3ad..0eb96cc 100644
--- a/telecomm/java/android/telecomm/CallService.java
+++ b/telecomm/java/android/telecomm/CallService.java
@@ -62,11 +62,14 @@ public abstract class CallService extends Service {
case MSG_DISCONNECT:
disconnect((String) msg.obj);
break;
- case MSG_CONFIRM_INCOMING_CALL:
- SomeArgs args = (SomeArgs) msg.obj;
- String callId = (String) args.arg1;
- String callToken = (String) args.arg2;
- confirmIncomingCall(callId, callToken);
+ case MSG_SET_INCOMING_CALL_ID:
+ setIncomingCallId((String) msg.obj);
+ break;
+ case MSG_ANSWER:
+ answer((String) msg.obj);
+ break;
+ case MSG_REJECT:
+ reject((String) msg.obj);
break;
default:
break;
@@ -100,11 +103,18 @@ public abstract class CallService extends Service {
}
@Override
- public void confirmIncomingCall(String callId, String callToken) {
- SomeArgs args = SomeArgs.obtain();
- args.arg1 = callId;
- args.arg2 = callToken;
- mMessageHandler.obtainMessage(MSG_CONFIRM_INCOMING_CALL, args).sendToTarget();
+ public void setIncomingCallId(String callId) {
+ mMessageHandler.obtainMessage(MSG_SET_INCOMING_CALL_ID, callId).sendToTarget();
+ }
+
+ @Override
+ public void answer(String callId) {
+ mMessageHandler.obtainMessage(MSG_ANSWER, callId).sendToTarget();
+ }
+
+ @Override
+ public void reject(String callId) {
+ mMessageHandler.obtainMessage(MSG_REJECT, callId).sendToTarget();
}
}
@@ -118,7 +128,9 @@ public abstract class CallService extends Service {
MSG_IS_COMPATIBLE_WITH = 2,
MSG_CALL = 3,
MSG_DISCONNECT = 4,
- MSG_CONFIRM_INCOMING_CALL = 5;
+ MSG_SET_INCOMING_CALL_ID = 5,
+ MSG_ANSWER = 6,
+ MSG_REJECT = 7;
/**
* Message handler for consolidating binder callbacks onto a single thread.
@@ -183,14 +195,29 @@ public abstract class CallService extends Service {
public abstract void disconnect(String callId);
/**
- * Confirms that the specified incoming call is connecting through this call service. Telecomm
- * receives all incoming calls initially as intents that include information about a call
- * and a token identifying the call. Before displaying any UI to the user, Telecomm confirms
- * the existence of the incoming call by binding to the specified call service and calling
- * this method. Confirmation responses are received through {@link ICallServiceAdapter}.
+ * Receives a new call ID to use with an incoming call. Invoked by Telecomm after it is notified
+ * that this call service has a pending incoming call, see
+ * {@link TelecommConstants#ACTION_INCOMING_CALL}. The call service must first give Telecomm
+ * additional information about the call through {@link ICallServiceAdapter#handleIncomingCall}.
+ * Following that, the call service can update the call at will using the specified call ID.
+ *
+ * @param callId The ID of the call.
+ */
+ public abstract void setIncomingCallId(String callId);
+
+ /**
+ * Answers a ringing call identified by callId. Telecomm invokes this method as a result of the
+ * user hitting the "answer" button in the incoming call screen.
+ *
+ * @param callId The ID of the call.
+ */
+ public abstract void answer(String callId);
+
+ /**
+ * Rejects a ringing call identified by callId. Telecomm invokes this method as a result of the
+ * user hitting the "reject" button in the incoming call screen.
*
* @param callId The ID of the call.
- * @param callToken The call token received through the incoming call intent.
*/
- public abstract void confirmIncomingCall(String callId, String callToken);
+ public abstract void reject(String callId);
}
diff --git a/telecomm/java/android/telecomm/CallServiceDescriptor.java b/telecomm/java/android/telecomm/CallServiceDescriptor.java
index 256b558..40f6ab9 100644
--- a/telecomm/java/android/telecomm/CallServiceDescriptor.java
+++ b/telecomm/java/android/telecomm/CallServiceDescriptor.java
@@ -189,7 +189,8 @@ public final class CallServiceDescriptor implements Parcelable {
dest.writeInt(mNetworkType);
}
- static final Creator<CallServiceDescriptor> CREATOR = new Creator<CallServiceDescriptor>() {
+ public static final Creator<CallServiceDescriptor> CREATOR =
+ new Creator<CallServiceDescriptor>() {
@Override
public CallServiceDescriptor createFromParcel(Parcel source) {
String id = source.readString();
diff --git a/telecomm/java/android/telecomm/ICallService.aidl b/telecomm/java/android/telecomm/ICallService.aidl
index 393a1be..6f3c4d46 100644
--- a/telecomm/java/android/telecomm/ICallService.aidl
+++ b/telecomm/java/android/telecomm/ICallService.aidl
@@ -61,8 +61,7 @@ oneway interface ICallService {
* handle-calling systems. See {@link #isCompatibleWith}. It is expected that the
* call service respond via {@link ICallServiceAdapter#handleSuccessfulOutgoingCall} if it can
* successfully make the call.
- * TODO(santoscordon): Figure out how a calls service can short-circuit a failure to
- * the adapter.
+ * TODO(santoscordon): Figure out how a call service can short-circuit a failure to the adapter.
*
* @param callInfo The details of the relevant call.
*/
@@ -76,14 +75,29 @@ oneway interface ICallService {
void disconnect(String callId);
/**
- * Confirms that the specified incoming call is connecting through this call service. Telecomm
- * receives all incoming calls initially as intents that include information about a call
- * and a token identifying the call. Before displaying any UI to the user, Telecomm confirms
- * the existence of the incoming call by binding to the specified call service and calling
- * this method. Confirmation responses are received through {@link ICallServiceAdapter}.
+ * Receives a new call ID to use with an incoming call. Invoked by Telecomm after it is notified
+ * that this call service has a pending incoming call, see
+ * {@link TelecommConstants#ACTION_INCOMING_CALL}. The call service must first give Telecomm
+ * additional information of the call through {@link ICallServiceAdapter#handleIncomingCall}.
+ * Following that, the call service can update the call at will using the specified call ID.
*
* @param callId The ID of the call.
- * @param callToken The call token received through the incoming call intent.
*/
- void confirmIncomingCall(String callId, String callToken);
+ void setIncomingCallId(String callId);
+
+ /**
+ * Answers a ringing call identified by callId. Telecomm invokes this method as a result of the
+ * user hitting the "answer" button in the incoming call screen.
+ *
+ * @param callId The ID of the call.
+ */
+ void answer(String callId);
+
+ /**
+ * Rejects a ringing call identified by callId. Telecomm invokes this method as a result of the
+ * user hitting the "reject" button in the incoming call screen.
+ *
+ * @param callId The ID of the call.
+ */
+ void reject(String callId);
}
diff --git a/telecomm/java/android/telecomm/ICallServiceAdapter.aidl b/telecomm/java/android/telecomm/ICallServiceAdapter.aidl
index c1ffa68..2e03d39 100644
--- a/telecomm/java/android/telecomm/ICallServiceAdapter.aidl
+++ b/telecomm/java/android/telecomm/ICallServiceAdapter.aidl
@@ -37,15 +37,15 @@ oneway interface ICallServiceAdapter {
void setCompatibleWith(String callId, boolean isCompatible);
/**
- * Receives confirmation of the existence of an incoming call connected through the call
- * service. Invoked by the call service after it receives a confirmation request from Telecomm
- * through {@link ICallService#confirmIncomingCall}. The call info object must contain all the
- * updated status of the call and use the same call ID as was passed into
- * {@link ICallService#confirmIncomingCall}.
+ * Provides Telecomm with the details of an incoming call. An invocation of this method must
+ * follow {@link CallService#setIncomingCallId} and use the call ID specified therein. Upon
+ * the invocation of this method, Telecomm will bring up the incoming-call interface where the
+ * user can elect to answer or reject a call.
+ * TODO(santoscordon): Consider renaming from handle* to notify*.
*
* @param callInfo The details of the relevant call.
*/
- void handleConfirmedIncomingCall(in CallInfo callInfo);
+ void handleIncomingCall(in CallInfo callInfo);
/**
* Tells Telecomm that an attempt to place the specified outgoing call succeeded.