| /* |
| * Copyright (C) 2014 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.telecomm; |
| |
| import android.os.RemoteException; |
| |
| import com.android.internal.telecomm.ICallServiceAdapter; |
| |
| import java.util.List; |
| |
| /** |
| * Provides methods for ICallService implementations to interact with the system phone app. |
| * TODO(santoscordon): Need final public-facing comments in this file. |
| */ |
| public final class CallServiceAdapter { |
| private final ICallServiceAdapter mAdapter; |
| |
| /** |
| * {@hide} |
| */ |
| public CallServiceAdapter(ICallServiceAdapter adapter) { |
| mAdapter = adapter; |
| } |
| |
| /** |
| * Receives confirmation of a call service's ability to place a call. This method is used in |
| * response to {@link CallService#isCompatibleWith}. |
| * |
| * @param callId The identifier of the call for which compatibility is being received. This ID |
| * should correspond to the ID given as part of the call information in |
| * {@link CallService#isCompatibleWith}. |
| * @param isCompatible True if the call service can place the call. |
| */ |
| public void setIsCompatibleWith(String callId, boolean isCompatible) { |
| try { |
| mAdapter.setIsCompatibleWith(callId, isCompatible); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * 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. |
| * |
| * @param callInfo The details of the relevant call. |
| */ |
| public void notifyIncomingCall(CallInfo callInfo) { |
| try { |
| mAdapter.notifyIncomingCall(callInfo); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Tells Telecomm that an attempt to place the specified outgoing call succeeded. |
| * TODO(santoscordon): Consider adding a CallState parameter in case this outgoing call is |
| * somehow no longer in the DIALING state. |
| * |
| * @param callId The ID of the outgoing call. |
| */ |
| public void handleSuccessfulOutgoingCall(String callId) { |
| try { |
| mAdapter.handleSuccessfulOutgoingCall(callId); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Tells Telecomm that an attempt to place the specified outgoing call failed. |
| * |
| * @param request The originating request for a connection. |
| * @param errorCode The error code associated with the failed call attempt. |
| * @param errorMsg The error message associated with the failed call attempt. |
| */ |
| public void handleFailedOutgoingCall( |
| ConnectionRequest request, |
| int errorCode, |
| String errorMsg) { |
| try { |
| mAdapter.handleFailedOutgoingCall(request, errorCode, errorMsg); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Sets a call's state to active (e.g., an ongoing call where two parties can actively |
| * communicate). |
| * |
| * @param callId The unique ID of the call whose state is changing to active. |
| */ |
| public void setActive(String callId) { |
| try { |
| mAdapter.setActive(callId); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Sets a call's state to ringing (e.g., an inbound ringing call). |
| * |
| * @param callId The unique ID of the call whose state is changing to ringing. |
| */ |
| public void setRinging(String callId) { |
| try { |
| mAdapter.setRinging(callId); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Sets a call's state to dialing (e.g., dialing an outbound call). |
| * |
| * @param callId The unique ID of the call whose state is changing to dialing. |
| */ |
| public void setDialing(String callId) { |
| try { |
| mAdapter.setDialing(callId); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Sets a call's state to disconnected. |
| * |
| * @param callId The unique ID of the call whose state is changing to disconnected. |
| * @param disconnectCause The reason for the disconnection, any of |
| * {@link android.telephony.DisconnectCause}. |
| * @param disconnectMessage Optional call-service-provided message about the disconnect. |
| */ |
| public void setDisconnected(String callId, int disconnectCause, String disconnectMessage) { |
| try { |
| mAdapter.setDisconnected(callId, disconnectCause, disconnectMessage); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Sets a call's state to be on hold. |
| * |
| * @param callId - The unique ID of the call whose state is changing to be on hold. |
| */ |
| public void setOnHold(String callId) { |
| try { |
| mAdapter.setOnHold(callId); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Asks Telecomm to start or stop a ringback tone for a call. |
| * |
| * @param callId The unique ID of the call whose ringback is being changed. |
| * @param ringback Whether Telecomm should start playing a ringback tone. |
| */ |
| public void setRequestingRingback(String callId, boolean ringback) { |
| try { |
| mAdapter.setRequestingRingback(callId, ringback); |
| } catch (RemoteException e) { |
| } |
| } |
| |
| /** |
| * Indicates that the specified call can conference with any of the specified list of calls. |
| * |
| * @param callId The unique ID of the call. |
| * @param conferenceCapableCallIds The unique IDs of the calls which can be conferenced. |
| * @hide |
| */ |
| public void setCanConferenceWith(String callId, List<String> conferenceCapableCallIds) { |
| try { |
| mAdapter.setCanConferenceWith(callId, conferenceCapableCallIds); |
| } catch (RemoteException ignored) { |
| } |
| } |
| |
| /** |
| * Indicates whether or not the specified call is currently conferenced into the specified |
| * conference call. |
| * |
| * @param conferenceCallId The unique ID of the conference call. |
| * @param callId The unique ID of the call being conferenced. |
| * @hide |
| */ |
| public void setIsConferenced(String conferenceCallId, String callId, boolean isConferenced) { |
| try { |
| mAdapter.setIsConferenced(conferenceCallId, callId, isConferenced); |
| } catch (RemoteException ignored) { |
| } |
| } |
| |
| /** |
| * Indicates that the call no longer exists. Can be used with either a call or a conference |
| * call. |
| * |
| * @param callId The unique ID of the call. |
| * @hide |
| */ |
| public void removeCall(String callId) { |
| try { |
| mAdapter.removeCall(callId); |
| } catch (RemoteException ignored) { |
| } |
| } |
| |
| public void onPostDialWait(String callId, String remaining) { |
| try { |
| mAdapter.onPostDialWait(callId, remaining); |
| } catch (RemoteException ignored) { |
| } |
| } |
| } |