Home | History | Annotate | Download | only in telephony
      1 /*
      2  * Copyright (C) 2007 The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  *      http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 package com.android.internal.telephony;
     18 
     19 import android.content.Context;
     20 import android.net.LinkCapabilities;
     21 import android.net.LinkProperties;
     22 import android.os.Handler;
     23 import android.os.Message;
     24 import android.telephony.CellInfo;
     25 import android.telephony.CellLocation;
     26 import android.telephony.PhoneStateListener;
     27 import android.telephony.ServiceState;
     28 import android.telephony.SignalStrength;
     29 
     30 import com.android.internal.telephony.test.SimulatedRadioControl;
     31 import com.android.internal.telephony.uicc.IsimRecords;
     32 import com.android.internal.telephony.uicc.UsimServiceTable;
     33 
     34 import com.android.internal.telephony.PhoneConstants.*; // ????
     35 
     36 import java.util.List;
     37 
     38 /**
     39  * Internal interface used to control the phone; SDK developers cannot
     40  * obtain this interface.
     41  *
     42  * {@hide}
     43  *
     44  */
     45 public interface Phone {
     46 
     47     /** used to enable additional debug messages */
     48     static final boolean DEBUG_PHONE = true;
     49 
     50     public enum DataActivityState {
     51         /**
     52          * The state of a data activity.
     53          * <ul>
     54          * <li>NONE = No traffic</li>
     55          * <li>DATAIN = Receiving IP ppp traffic</li>
     56          * <li>DATAOUT = Sending IP ppp traffic</li>
     57          * <li>DATAINANDOUT = Both receiving and sending IP ppp traffic</li>
     58          * <li>DORMANT = The data connection is still active,
     59                                      but physical link is down</li>
     60          * </ul>
     61          */
     62         NONE, DATAIN, DATAOUT, DATAINANDOUT, DORMANT;
     63     }
     64 
     65     enum SuppService {
     66       UNKNOWN, SWITCH, SEPARATE, TRANSFER, CONFERENCE, REJECT, HANGUP;
     67     }
     68 
     69     // "Features" accessible through the connectivity manager
     70     static final String FEATURE_ENABLE_MMS = "enableMMS";
     71     static final String FEATURE_ENABLE_SUPL = "enableSUPL";
     72     static final String FEATURE_ENABLE_DUN = "enableDUN";
     73     static final String FEATURE_ENABLE_HIPRI = "enableHIPRI";
     74     static final String FEATURE_ENABLE_DUN_ALWAYS = "enableDUNAlways";
     75     static final String FEATURE_ENABLE_FOTA = "enableFOTA";
     76     static final String FEATURE_ENABLE_IMS = "enableIMS";
     77     static final String FEATURE_ENABLE_CBS = "enableCBS";
     78 
     79     /**
     80      * Optional reasons for disconnect and connect
     81      */
     82     static final String REASON_ROAMING_ON = "roamingOn";
     83     static final String REASON_ROAMING_OFF = "roamingOff";
     84     static final String REASON_DATA_DISABLED = "dataDisabled";
     85     static final String REASON_DATA_ENABLED = "dataEnabled";
     86     static final String REASON_DATA_ATTACHED = "dataAttached";
     87     static final String REASON_DATA_DETACHED = "dataDetached";
     88     static final String REASON_CDMA_DATA_ATTACHED = "cdmaDataAttached";
     89     static final String REASON_CDMA_DATA_DETACHED = "cdmaDataDetached";
     90     static final String REASON_APN_CHANGED = "apnChanged";
     91     static final String REASON_APN_SWITCHED = "apnSwitched";
     92     static final String REASON_APN_FAILED = "apnFailed";
     93     static final String REASON_RESTORE_DEFAULT_APN = "restoreDefaultApn";
     94     static final String REASON_RADIO_TURNED_OFF = "radioTurnedOff";
     95     static final String REASON_PDP_RESET = "pdpReset";
     96     static final String REASON_VOICE_CALL_ENDED = "2GVoiceCallEnded";
     97     static final String REASON_VOICE_CALL_STARTED = "2GVoiceCallStarted";
     98     static final String REASON_PS_RESTRICT_ENABLED = "psRestrictEnabled";
     99     static final String REASON_PS_RESTRICT_DISABLED = "psRestrictDisabled";
    100     static final String REASON_SIM_LOADED = "simLoaded";
    101     static final String REASON_NW_TYPE_CHANGED = "nwTypeChanged";
    102     static final String REASON_DATA_DEPENDENCY_MET = "dependencyMet";
    103     static final String REASON_DATA_DEPENDENCY_UNMET = "dependencyUnmet";
    104     static final String REASON_LOST_DATA_CONNECTION = "lostDataConnection";
    105     static final String REASON_CONNECTED = "connected";
    106 
    107     // Used for band mode selection methods
    108     static final int BM_UNSPECIFIED = 0; // selected by baseband automatically
    109     static final int BM_EURO_BAND   = 1; // GSM-900 / DCS-1800 / WCDMA-IMT-2000
    110     static final int BM_US_BAND     = 2; // GSM-850 / PCS-1900 / WCDMA-850 / WCDMA-PCS-1900
    111     static final int BM_JPN_BAND    = 3; // WCDMA-800 / WCDMA-IMT-2000
    112     static final int BM_AUS_BAND    = 4; // GSM-900 / DCS-1800 / WCDMA-850 / WCDMA-IMT-2000
    113     static final int BM_AUS2_BAND   = 5; // GSM-900 / DCS-1800 / WCDMA-850
    114     static final int BM_BOUNDARY    = 6; // upper band boundary
    115 
    116     // Used for preferred network type
    117     // Note NT_* substitute RILConstants.NETWORK_MODE_* above the Phone
    118     int NT_MODE_WCDMA_PREF   = RILConstants.NETWORK_MODE_WCDMA_PREF;
    119     int NT_MODE_GSM_ONLY     = RILConstants.NETWORK_MODE_GSM_ONLY;
    120     int NT_MODE_WCDMA_ONLY   = RILConstants.NETWORK_MODE_WCDMA_ONLY;
    121     int NT_MODE_GSM_UMTS     = RILConstants.NETWORK_MODE_GSM_UMTS;
    122 
    123     int NT_MODE_CDMA         = RILConstants.NETWORK_MODE_CDMA;
    124 
    125     int NT_MODE_CDMA_NO_EVDO = RILConstants.NETWORK_MODE_CDMA_NO_EVDO;
    126     int NT_MODE_EVDO_NO_CDMA = RILConstants.NETWORK_MODE_EVDO_NO_CDMA;
    127     int NT_MODE_GLOBAL       = RILConstants.NETWORK_MODE_GLOBAL;
    128 
    129     int NT_MODE_LTE_CDMA_AND_EVDO        = RILConstants.NETWORK_MODE_LTE_CDMA_EVDO;
    130     int NT_MODE_LTE_GSM_WCDMA            = RILConstants.NETWORK_MODE_LTE_GSM_WCDMA;
    131     int NT_MODE_LTE_CMDA_EVDO_GSM_WCDMA  = RILConstants.NETWORK_MODE_LTE_CMDA_EVDO_GSM_WCDMA;
    132     int NT_MODE_LTE_ONLY                 = RILConstants.NETWORK_MODE_LTE_ONLY;
    133     int NT_MODE_LTE_WCDMA                = RILConstants.NETWORK_MODE_LTE_WCDMA;
    134     int PREFERRED_NT_MODE                = RILConstants.PREFERRED_NETWORK_MODE;
    135 
    136     // Used for CDMA roaming mode
    137     static final int CDMA_RM_HOME        = 0;  // Home Networks only, as defined in PRL
    138     static final int CDMA_RM_AFFILIATED  = 1;  // Roaming an Affiliated networks, as defined in PRL
    139     static final int CDMA_RM_ANY         = 2;  // Roaming on Any Network, as defined in PRL
    140 
    141     // Used for CDMA subscription mode
    142     static final int CDMA_SUBSCRIPTION_UNKNOWN  =-1; // Unknown
    143     static final int CDMA_SUBSCRIPTION_RUIM_SIM = 0; // RUIM/SIM (default)
    144     static final int CDMA_SUBSCRIPTION_NV       = 1; // NV -> non-volatile memory
    145 
    146     static final int PREFERRED_CDMA_SUBSCRIPTION = CDMA_SUBSCRIPTION_NV;
    147 
    148     static final int TTY_MODE_OFF = 0;
    149     static final int TTY_MODE_FULL = 1;
    150     static final int TTY_MODE_HCO = 2;
    151     static final int TTY_MODE_VCO = 3;
    152 
    153      /**
    154      * CDMA OTA PROVISION STATUS, the same as RIL_CDMA_OTA_Status in ril.h
    155      */
    156 
    157     public static final int CDMA_OTA_PROVISION_STATUS_SPL_UNLOCKED = 0;
    158     public static final int CDMA_OTA_PROVISION_STATUS_SPC_RETRIES_EXCEEDED = 1;
    159     public static final int CDMA_OTA_PROVISION_STATUS_A_KEY_EXCHANGED = 2;
    160     public static final int CDMA_OTA_PROVISION_STATUS_SSD_UPDATED = 3;
    161     public static final int CDMA_OTA_PROVISION_STATUS_NAM_DOWNLOADED = 4;
    162     public static final int CDMA_OTA_PROVISION_STATUS_MDN_DOWNLOADED = 5;
    163     public static final int CDMA_OTA_PROVISION_STATUS_IMSI_DOWNLOADED = 6;
    164     public static final int CDMA_OTA_PROVISION_STATUS_PRL_DOWNLOADED = 7;
    165     public static final int CDMA_OTA_PROVISION_STATUS_COMMITTED = 8;
    166     public static final int CDMA_OTA_PROVISION_STATUS_OTAPA_STARTED = 9;
    167     public static final int CDMA_OTA_PROVISION_STATUS_OTAPA_STOPPED = 10;
    168     public static final int CDMA_OTA_PROVISION_STATUS_OTAPA_ABORTED = 11;
    169 
    170 
    171     /**
    172      * Get the current ServiceState. Use
    173      * <code>registerForServiceStateChanged</code> to be informed of
    174      * updates.
    175      */
    176     ServiceState getServiceState();
    177 
    178     /**
    179      * Get the current CellLocation.
    180      */
    181     CellLocation getCellLocation();
    182 
    183     /**
    184      * @return all available cell information or null if none.
    185      */
    186     public List<CellInfo> getAllCellInfo();
    187 
    188     /**
    189      * Sets the minimum time in milli-seconds between {@link PhoneStateListener#onCellInfoChanged
    190      * PhoneStateListener.onCellInfoChanged} will be invoked.
    191      *
    192      * The default, 0, means invoke onCellInfoChanged when any of the reported
    193      * information changes. Setting the value to INT_MAX(0x7fffffff) means never issue
    194      * A onCellInfoChanged.
    195      *
    196      * @param rateInMillis the rate
    197      */
    198     public void setCellInfoListRate(int rateInMillis);
    199 
    200     /**
    201      * Get the current for the default apn DataState. No change notification
    202      * exists at this interface -- use
    203      * {@link android.telephony.PhoneStateListener} instead.
    204      */
    205     DataState getDataConnectionState();
    206 
    207     /**
    208      * Get the current DataState. No change notification exists at this
    209      * interface -- use
    210      * {@link android.telephony.PhoneStateListener} instead.
    211      * @param apnType specify for which apn to get connection state info.
    212      */
    213     DataState getDataConnectionState(String apnType);
    214 
    215     /**
    216      * Get the current DataActivityState. No change notification exists at this
    217      * interface -- use
    218      * {@link android.telephony.TelephonyManager} instead.
    219      */
    220     DataActivityState getDataActivityState();
    221 
    222     /**
    223      * Gets the context for the phone, as set at initialization time.
    224      */
    225     Context getContext();
    226 
    227     /**
    228      * Disables the DNS check (i.e., allows "0.0.0.0").
    229      * Useful for lab testing environment.
    230      * @param b true disables the check, false enables.
    231      */
    232     void disableDnsCheck(boolean b);
    233 
    234     /**
    235      * Returns true if the DNS check is currently disabled.
    236      */
    237     boolean isDnsCheckDisabled();
    238 
    239     /**
    240      * Get current coarse-grained voice call state.
    241      * Use {@link #registerForPreciseCallStateChanged(Handler, int, Object)
    242      * registerForPreciseCallStateChanged()} for change notification. <p>
    243      * If the phone has an active call and call waiting occurs,
    244      * then the phone state is RINGING not OFFHOOK
    245      * <strong>Note:</strong>
    246      * This registration point provides notification of finer-grained
    247      * changes.<p>
    248      *
    249      */
    250     State getState();
    251 
    252     /**
    253      * Returns a string identifier for this phone interface for parties
    254      *  outside the phone app process.
    255      *  @return The string name.
    256      */
    257     String getPhoneName();
    258 
    259     /**
    260      * Return a numerical identifier for the phone radio interface.
    261      * @return PHONE_TYPE_XXX as defined above.
    262      */
    263     int getPhoneType();
    264 
    265     /**
    266      * Returns an array of string identifiers for the APN types serviced by the
    267      * currently active.
    268      *  @return The string array will always return at least one entry, Phone.APN_TYPE_DEFAULT.
    269      * TODO: Revisit if we always should return at least one entry.
    270      */
    271     String[] getActiveApnTypes();
    272 
    273     /**
    274      * Returns string for the active APN host.
    275      *  @return type as a string or null if none.
    276      */
    277     String getActiveApnHost(String apnType);
    278 
    279     /**
    280      * Return the LinkProperties for the named apn or null if not available
    281      */
    282     LinkProperties getLinkProperties(String apnType);
    283 
    284     /**
    285      * Return the LinkCapabilities
    286      */
    287     LinkCapabilities getLinkCapabilities(String apnType);
    288 
    289     /**
    290      * Get current signal strength. No change notification available on this
    291      * interface. Use <code>PhoneStateNotifier</code> or an equivalent.
    292      * An ASU is 0-31 or -1 if unknown (for GSM, dBm = -113 - 2 * asu).
    293      * The following special values are defined:</p>
    294      * <ul><li>0 means "-113 dBm or less".</li>
    295      * <li>31 means "-51 dBm or greater".</li></ul>
    296      *
    297      * @return Current signal strength as SignalStrength
    298      */
    299     SignalStrength getSignalStrength();
    300 
    301     /**
    302      * Notifies when a previously untracked non-ringing/waiting connection has appeared.
    303      * This is likely due to some other entity (eg, SIM card application) initiating a call.
    304      */
    305     void registerForUnknownConnection(Handler h, int what, Object obj);
    306 
    307     /**
    308      * Unregisters for unknown connection notifications.
    309      */
    310     void unregisterForUnknownConnection(Handler h);
    311 
    312     /**
    313      * Register for getting notifications for change in the Call State {@link Call.State}
    314      * This is called PreciseCallState because the call state is more precise than the
    315      * {@link PhoneConstants.State} which can be obtained using the {@link PhoneStateListener}
    316      *
    317      * Resulting events will have an AsyncResult in <code>Message.obj</code>.
    318      * AsyncResult.userData will be set to the obj argument here.
    319      * The <em>h</em> parameter is held only by a weak reference.
    320      */
    321     void registerForPreciseCallStateChanged(Handler h, int what, Object obj);
    322 
    323     /**
    324      * Unregisters for voice call state change notifications.
    325      * Extraneous calls are tolerated silently.
    326      */
    327     void unregisterForPreciseCallStateChanged(Handler h);
    328 
    329 
    330     /**
    331      * Notifies when a new ringing or waiting connection has appeared.<p>
    332      *
    333      *  Messages received from this:
    334      *  Message.obj will be an AsyncResult
    335      *  AsyncResult.userObj = obj
    336      *  AsyncResult.result = a Connection. <p>
    337      *  Please check Connection.isRinging() to make sure the Connection
    338      *  has not dropped since this message was posted.
    339      *  If Connection.isRinging() is true, then
    340      *   Connection.getCall() == Phone.getRingingCall()
    341      */
    342     void registerForNewRingingConnection(Handler h, int what, Object obj);
    343 
    344     /**
    345      * Unregisters for new ringing connection notification.
    346      * Extraneous calls are tolerated silently
    347      */
    348 
    349     void unregisterForNewRingingConnection(Handler h);
    350 
    351     /**
    352      * Notifies when an incoming call rings.<p>
    353      *
    354      *  Messages received from this:
    355      *  Message.obj will be an AsyncResult
    356      *  AsyncResult.userObj = obj
    357      *  AsyncResult.result = a Connection. <p>
    358      */
    359     void registerForIncomingRing(Handler h, int what, Object obj);
    360 
    361     /**
    362      * Unregisters for ring notification.
    363      * Extraneous calls are tolerated silently
    364      */
    365 
    366     void unregisterForIncomingRing(Handler h);
    367 
    368     /**
    369      * Notifies when out-band ringback tone is needed.<p>
    370      *
    371      *  Messages received from this:
    372      *  Message.obj will be an AsyncResult
    373      *  AsyncResult.userObj = obj
    374      *  AsyncResult.result = boolean, true to start play ringback tone
    375      *                       and false to stop. <p>
    376      */
    377     void registerForRingbackTone(Handler h, int what, Object obj);
    378 
    379     /**
    380      * Unregisters for ringback tone notification.
    381      */
    382 
    383     void unregisterForRingbackTone(Handler h);
    384 
    385     /**
    386      * Registers the handler to reset the uplink mute state to get
    387      * uplink audio.
    388      */
    389     void registerForResendIncallMute(Handler h, int what, Object obj);
    390 
    391     /**
    392      * Unregisters for resend incall mute notifications.
    393      */
    394     void unregisterForResendIncallMute(Handler h);
    395 
    396     /**
    397      * Notifies when a voice connection has disconnected, either due to local
    398      * or remote hangup or error.
    399      *
    400      *  Messages received from this will have the following members:<p>
    401      *  <ul><li>Message.obj will be an AsyncResult</li>
    402      *  <li>AsyncResult.userObj = obj</li>
    403      *  <li>AsyncResult.result = a Connection object that is
    404      *  no longer connected.</li></ul>
    405      */
    406     void registerForDisconnect(Handler h, int what, Object obj);
    407 
    408     /**
    409      * Unregisters for voice disconnection notification.
    410      * Extraneous calls are tolerated silently
    411      */
    412     void unregisterForDisconnect(Handler h);
    413 
    414 
    415     /**
    416      * Register for notifications of initiation of a new MMI code request.
    417      * MMI codes for GSM are discussed in 3GPP TS 22.030.<p>
    418      *
    419      * Example: If Phone.dial is called with "*#31#", then the app will
    420      * be notified here.<p>
    421      *
    422      * The returned <code>Message.obj</code> will contain an AsyncResult.
    423      *
    424      * <code>obj.result</code> will be an "MmiCode" object.
    425      */
    426     void registerForMmiInitiate(Handler h, int what, Object obj);
    427 
    428     /**
    429      * Unregisters for new MMI initiate notification.
    430      * Extraneous calls are tolerated silently
    431      */
    432     void unregisterForMmiInitiate(Handler h);
    433 
    434     /**
    435      * Register for notifications that an MMI request has completed
    436      * its network activity and is in its final state. This may mean a state
    437      * of COMPLETE, FAILED, or CANCELLED.
    438      *
    439      * <code>Message.obj</code> will contain an AsyncResult.
    440      * <code>obj.result</code> will be an "MmiCode" object
    441      */
    442     void registerForMmiComplete(Handler h, int what, Object obj);
    443 
    444     /**
    445      * Unregisters for MMI complete notification.
    446      * Extraneous calls are tolerated silently
    447      */
    448     void unregisterForMmiComplete(Handler h);
    449 
    450     /**
    451      * Registration point for Ecm timer reset
    452      * @param h handler to notify
    453      * @param what user-defined message code
    454      * @param obj placed in Message.obj
    455      */
    456     public void registerForEcmTimerReset(Handler h, int what, Object obj);
    457 
    458     /**
    459      * Unregister for notification for Ecm timer reset
    460      * @param h Handler to be removed from the registrant list.
    461      */
    462     public void unregisterForEcmTimerReset(Handler h);
    463 
    464     /**
    465      * Returns a list of MMI codes that are pending. (They have initiated
    466      * but have not yet completed).
    467      * Presently there is only ever one.
    468      * Use <code>registerForMmiInitiate</code>
    469      * and <code>registerForMmiComplete</code> for change notification.
    470      */
    471     public List<? extends MmiCode> getPendingMmiCodes();
    472 
    473     /**
    474      * Sends user response to a USSD REQUEST message.  An MmiCode instance
    475      * representing this response is sent to handlers registered with
    476      * registerForMmiInitiate.
    477      *
    478      * @param ussdMessge    Message to send in the response.
    479      */
    480     public void sendUssdResponse(String ussdMessge);
    481 
    482     /**
    483      * Register for ServiceState changed.
    484      * Message.obj will contain an AsyncResult.
    485      * AsyncResult.result will be a ServiceState instance
    486      */
    487     void registerForServiceStateChanged(Handler h, int what, Object obj);
    488 
    489     /**
    490      * Unregisters for ServiceStateChange notification.
    491      * Extraneous calls are tolerated silently
    492      */
    493     void unregisterForServiceStateChanged(Handler h);
    494 
    495     /**
    496      * Register for Supplementary Service notifications from the network.
    497      * Message.obj will contain an AsyncResult.
    498      * AsyncResult.result will be a SuppServiceNotification instance.
    499      *
    500      * @param h Handler that receives the notification message.
    501      * @param what User-defined message code.
    502      * @param obj User object.
    503      */
    504     void registerForSuppServiceNotification(Handler h, int what, Object obj);
    505 
    506     /**
    507      * Unregisters for Supplementary Service notifications.
    508      * Extraneous calls are tolerated silently
    509      *
    510      * @param h Handler to be removed from the registrant list.
    511      */
    512     void unregisterForSuppServiceNotification(Handler h);
    513 
    514     /**
    515      * Register for notifications when a supplementary service attempt fails.
    516      * Message.obj will contain an AsyncResult.
    517      *
    518      * @param h Handler that receives the notification message.
    519      * @param what User-defined message code.
    520      * @param obj User object.
    521      */
    522     void registerForSuppServiceFailed(Handler h, int what, Object obj);
    523 
    524     /**
    525      * Unregister for notifications when a supplementary service attempt fails.
    526      * Extraneous calls are tolerated silently
    527      *
    528      * @param h Handler to be removed from the registrant list.
    529      */
    530     void unregisterForSuppServiceFailed(Handler h);
    531 
    532     /**
    533      * Register for notifications when a sInCall VoicePrivacy is enabled
    534      *
    535      * @param h Handler that receives the notification message.
    536      * @param what User-defined message code.
    537      * @param obj User object.
    538      */
    539     void registerForInCallVoicePrivacyOn(Handler h, int what, Object obj);
    540 
    541     /**
    542      * Unegister for notifications when a sInCall VoicePrivacy is enabled
    543      *
    544      * @param h Handler to be removed from the registrant list.
    545      */
    546     void unregisterForInCallVoicePrivacyOn(Handler h);
    547 
    548     /**
    549      * Register for notifications when a sInCall VoicePrivacy is disabled
    550      *
    551      * @param h Handler that receives the notification message.
    552      * @param what User-defined message code.
    553      * @param obj User object.
    554      */
    555     void registerForInCallVoicePrivacyOff(Handler h, int what, Object obj);
    556 
    557     /**
    558      * Unregister for notifications when a sInCall VoicePrivacy is disabled
    559      *
    560      * @param h Handler to be removed from the registrant list.
    561      */
    562     void unregisterForInCallVoicePrivacyOff(Handler h);
    563 
    564     /**
    565      * Register for notifications when CDMA OTA Provision status change
    566      *
    567      * @param h Handler that receives the notification message.
    568      * @param what User-defined message code.
    569      * @param obj User object.
    570      */
    571     void registerForCdmaOtaStatusChange(Handler h, int what, Object obj);
    572 
    573     /**
    574      * Unregister for notifications when CDMA OTA Provision status change
    575      * @param h Handler to be removed from the registrant list.
    576      */
    577     void unregisterForCdmaOtaStatusChange(Handler h);
    578 
    579     /**
    580      * Registration point for subscription info ready
    581      * @param h handler to notify
    582      * @param what what code of message when delivered
    583      * @param obj placed in Message.obj
    584      */
    585     public void registerForSubscriptionInfoReady(Handler h, int what, Object obj);
    586 
    587     /**
    588      * Unregister for notifications for subscription info
    589      * @param h Handler to be removed from the registrant list.
    590      */
    591     public void unregisterForSubscriptionInfoReady(Handler h);
    592 
    593     /**
    594      * Returns SIM record load state. Use
    595      * <code>getSimCard().registerForReady()</code> for change notification.
    596      *
    597      * @return true if records from the SIM have been loaded and are
    598      * available (if applicable). If not applicable to the underlying
    599      * technology, returns true as well.
    600      */
    601     boolean getIccRecordsLoaded();
    602 
    603     /**
    604      * Returns the ICC card interface for this phone, or null
    605      * if not applicable to underlying technology.
    606      */
    607     IccCard getIccCard();
    608 
    609     /**
    610      * Answers a ringing or waiting call. Active calls, if any, go on hold.
    611      * Answering occurs asynchronously, and final notification occurs via
    612      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    613      * java.lang.Object) registerForPreciseCallStateChanged()}.
    614      *
    615      * @exception CallStateException when no call is ringing or waiting
    616      */
    617     void acceptCall() throws CallStateException;
    618 
    619     /**
    620      * Reject (ignore) a ringing call. In GSM, this means UDUB
    621      * (User Determined User Busy). Reject occurs asynchronously,
    622      * and final notification occurs via
    623      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    624      * java.lang.Object) registerForPreciseCallStateChanged()}.
    625      *
    626      * @exception CallStateException when no call is ringing or waiting
    627      */
    628     void rejectCall() throws CallStateException;
    629 
    630     /**
    631      * Places any active calls on hold, and makes any held calls
    632      *  active. Switch occurs asynchronously and may fail.
    633      * Final notification occurs via
    634      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    635      * java.lang.Object) registerForPreciseCallStateChanged()}.
    636      *
    637      * @exception CallStateException if a call is ringing, waiting, or
    638      * dialing/alerting. In these cases, this operation may not be performed.
    639      */
    640     void switchHoldingAndActive() throws CallStateException;
    641 
    642     /**
    643      * Whether or not the phone can conference in the current phone
    644      * state--that is, one call holding and one call active.
    645      * @return true if the phone can conference; false otherwise.
    646      */
    647     boolean canConference();
    648 
    649     /**
    650      * Conferences holding and active. Conference occurs asynchronously
    651      * and may fail. Final notification occurs via
    652      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    653      * java.lang.Object) registerForPreciseCallStateChanged()}.
    654      *
    655      * @exception CallStateException if canConference() would return false.
    656      * In these cases, this operation may not be performed.
    657      */
    658     void conference() throws CallStateException;
    659 
    660     /**
    661      * Enable or disable enhanced Voice Privacy (VP). If enhanced VP is
    662      * disabled, normal VP is enabled.
    663      *
    664      * @param enable whether true or false to enable or disable.
    665      * @param onComplete a callback message when the action is completed.
    666      */
    667     void enableEnhancedVoicePrivacy(boolean enable, Message onComplete);
    668 
    669     /**
    670      * Get the currently set Voice Privacy (VP) mode.
    671      *
    672      * @param onComplete a callback message when the action is completed.
    673      */
    674     void getEnhancedVoicePrivacy(Message onComplete);
    675 
    676     /**
    677      * Whether or not the phone can do explicit call transfer in the current
    678      * phone state--that is, one call holding and one call active.
    679      * @return true if the phone can do explicit call transfer; false otherwise.
    680      */
    681     boolean canTransfer();
    682 
    683     /**
    684      * Connects the two calls and disconnects the subscriber from both calls
    685      * Explicit Call Transfer occurs asynchronously
    686      * and may fail. Final notification occurs via
    687      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    688      * java.lang.Object) registerForPreciseCallStateChanged()}.
    689      *
    690      * @exception CallStateException if canTransfer() would return false.
    691      * In these cases, this operation may not be performed.
    692      */
    693     void explicitCallTransfer() throws CallStateException;
    694 
    695     /**
    696      * Clears all DISCONNECTED connections from Call connection lists.
    697      * Calls that were in the DISCONNECTED state become idle. This occurs
    698      * synchronously.
    699      */
    700     void clearDisconnected();
    701 
    702 
    703     /**
    704      * Gets the foreground call object, which represents all connections that
    705      * are dialing or active (all connections
    706      * that have their audio path connected).<p>
    707      *
    708      * The foreground call is a singleton object. It is constant for the life
    709      * of this phone. It is never null.<p>
    710      *
    711      * The foreground call will only ever be in one of these states:
    712      * IDLE, ACTIVE, DIALING, ALERTING, or DISCONNECTED.
    713      *
    714      * State change notification is available via
    715      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    716      * java.lang.Object) registerForPreciseCallStateChanged()}.
    717      */
    718     Call getForegroundCall();
    719 
    720     /**
    721      * Gets the background call object, which represents all connections that
    722      * are holding (all connections that have been accepted or connected, but
    723      * do not have their audio path connected). <p>
    724      *
    725      * The background call is a singleton object. It is constant for the life
    726      * of this phone object . It is never null.<p>
    727      *
    728      * The background call will only ever be in one of these states:
    729      * IDLE, HOLDING or DISCONNECTED.
    730      *
    731      * State change notification is available via
    732      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    733      * java.lang.Object) registerForPreciseCallStateChanged()}.
    734      */
    735     Call getBackgroundCall();
    736 
    737     /**
    738      * Gets the ringing call object, which represents an incoming
    739      * connection (if present) that is pending answer/accept. (This connection
    740      * may be RINGING or WAITING, and there may be only one.)<p>
    741 
    742      * The ringing call is a singleton object. It is constant for the life
    743      * of this phone. It is never null.<p>
    744      *
    745      * The ringing call will only ever be in one of these states:
    746      * IDLE, INCOMING, WAITING or DISCONNECTED.
    747      *
    748      * State change notification is available via
    749      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
    750      * java.lang.Object) registerForPreciseCallStateChanged()}.
    751      */
    752     Call getRingingCall();
    753 
    754     /**
    755      * Initiate a new voice connection. This happens asynchronously, so you
    756      * cannot assume the audio path is connected (or a call index has been
    757      * assigned) until PhoneStateChanged notification has occurred.
    758      *
    759      * @exception CallStateException if a new outgoing call is not currently
    760      * possible because no more call slots exist or a call exists that is
    761      * dialing, alerting, ringing, or waiting.  Other errors are
    762      * handled asynchronously.
    763      */
    764     Connection dial(String dialString) throws CallStateException;
    765 
    766     /**
    767      * Initiate a new voice connection with supplementary User to User
    768      * Information. This happens asynchronously, so you cannot assume the audio
    769      * path is connected (or a call index has been assigned) until
    770      * PhoneStateChanged notification has occurred.
    771      *
    772      * @exception CallStateException if a new outgoing call is not currently
    773      *                possible because no more call slots exist or a call exists
    774      *                that is dialing, alerting, ringing, or waiting. Other
    775      *                errors are handled asynchronously.
    776      */
    777     Connection dial(String dialString, UUSInfo uusInfo) throws CallStateException;
    778 
    779     /**
    780      * Handles PIN MMI commands (PIN/PIN2/PUK/PUK2), which are initiated
    781      * without SEND (so <code>dial</code> is not appropriate).
    782      *
    783      * @param dialString the MMI command to be executed.
    784      * @return true if MMI command is executed.
    785      */
    786     boolean handlePinMmi(String dialString);
    787 
    788     /**
    789      * Handles in-call MMI commands. While in a call, or while receiving a
    790      * call, use this to execute MMI commands.
    791      * see 3GPP 20.030, section 6.5.5.1 for specs on the allowed MMI commands.
    792      *
    793      * @param command the MMI command to be executed.
    794      * @return true if the MMI command is executed.
    795      * @throws CallStateException
    796      */
    797     boolean handleInCallMmiCommands(String command) throws CallStateException;
    798 
    799     /**
    800      * Play a DTMF tone on the active call. Ignored if there is no active call.
    801      * @param c should be one of 0-9, '*' or '#'. Other values will be
    802      * silently ignored.
    803      */
    804     void sendDtmf(char c);
    805 
    806     /**
    807      * Start to paly a DTMF tone on the active call. Ignored if there is no active call
    808      * or there is a playing DTMF tone.
    809      * @param c should be one of 0-9, '*' or '#'. Other values will be
    810      * silently ignored.
    811      */
    812     void startDtmf(char c);
    813 
    814     /**
    815      * Stop the playing DTMF tone. Ignored if there is no playing DTMF
    816      * tone or no active call.
    817      */
    818     void stopDtmf();
    819 
    820     /**
    821      * send burst DTMF tone, it can send the string as single character or multiple character
    822      * ignore if there is no active call or not valid digits string.
    823      * Valid digit means only includes characters ISO-LATIN characters 0-9, *, #
    824      * The difference between sendDtmf and sendBurstDtmf is sendDtmf only sends one character,
    825      * this api can send single character and multiple character, also, this api has response
    826      * back to caller.
    827      *
    828      * @param dtmfString is string representing the dialing digit(s) in the active call
    829      * @param on the DTMF ON length in milliseconds, or 0 for default
    830      * @param off the DTMF OFF length in milliseconds, or 0 for default
    831      * @param onComplete is the callback message when the action is processed by BP
    832      *
    833      */
    834     void sendBurstDtmf(String dtmfString, int on, int off, Message onComplete);
    835 
    836     /**
    837      * Sets the radio power on/off state (off is sometimes
    838      * called "airplane mode"). Current state can be gotten via
    839      * {@link #getServiceState()}.{@link
    840      * android.telephony.ServiceState#getState() getState()}.
    841      * <strong>Note: </strong>This request is asynchronous.
    842      * getServiceState().getState() will not change immediately after this call.
    843      * registerForServiceStateChanged() to find out when the
    844      * request is complete.
    845      *
    846      * @param power true means "on", false means "off".
    847      */
    848     void setRadioPower(boolean power);
    849 
    850     /**
    851      * Get voice message waiting indicator status. No change notification
    852      * available on this interface. Use PhoneStateNotifier or similar instead.
    853      *
    854      * @return true if there is a voice message waiting
    855      */
    856     boolean getMessageWaitingIndicator();
    857 
    858     /**
    859      * Get voice call forwarding indicator status. No change notification
    860      * available on this interface. Use PhoneStateNotifier or similar instead.
    861      *
    862      * @return true if there is a voice call forwarding
    863      */
    864     boolean getCallForwardingIndicator();
    865 
    866     /**
    867      * Get the line 1 phone number (MSISDN). For CDMA phones, the MDN is returned
    868      * and {@link #getMsisdn()} will return the MSISDN on CDMA/LTE phones.<p>
    869      *
    870      * @return phone number. May return null if not
    871      * available or the SIM is not ready
    872      */
    873     String getLine1Number();
    874 
    875     /**
    876      * Returns the alpha tag associated with the msisdn number.
    877      * If there is no alpha tag associated or the record is not yet available,
    878      * returns a default localized string. <p>
    879      */
    880     String getLine1AlphaTag();
    881 
    882     /**
    883      * Sets the MSISDN phone number in the SIM card.
    884      *
    885      * @param alphaTag the alpha tag associated with the MSISDN phone number
    886      *        (see getMsisdnAlphaTag)
    887      * @param number the new MSISDN phone number to be set on the SIM.
    888      * @param onComplete a callback message when the action is completed.
    889      */
    890     void setLine1Number(String alphaTag, String number, Message onComplete);
    891 
    892     /**
    893      * Get the voice mail access phone number. Typically dialed when the
    894      * user holds the "1" key in the phone app. May return null if not
    895      * available or the SIM is not ready.<p>
    896      */
    897     String getVoiceMailNumber();
    898 
    899     /**
    900      * Returns unread voicemail count. This count is shown when the  voicemail
    901      * notification is expanded.<p>
    902      */
    903     int getVoiceMessageCount();
    904 
    905     /**
    906      * Returns the alpha tag associated with the voice mail number.
    907      * If there is no alpha tag associated or the record is not yet available,
    908      * returns a default localized string. <p>
    909      *
    910      * Please use this value instead of some other localized string when
    911      * showing a name for this number in the UI. For example, call log
    912      * entries should show this alpha tag. <p>
    913      *
    914      * Usage of this alpha tag in the UI is a common carrier requirement.
    915      */
    916     String getVoiceMailAlphaTag();
    917 
    918     /**
    919      * setVoiceMailNumber
    920      * sets the voicemail number in the SIM card.
    921      *
    922      * @param alphaTag the alpha tag associated with the voice mail number
    923      *        (see getVoiceMailAlphaTag)
    924      * @param voiceMailNumber the new voicemail number to be set on the SIM.
    925      * @param onComplete a callback message when the action is completed.
    926      */
    927     void setVoiceMailNumber(String alphaTag,
    928                             String voiceMailNumber,
    929                             Message onComplete);
    930 
    931     /**
    932      * getCallForwardingOptions
    933      * gets a call forwarding option. The return value of
    934      * ((AsyncResult)onComplete.obj) is an array of CallForwardInfo.
    935      *
    936      * @param commandInterfaceCFReason is one of the valid call forwarding
    937      *        CF_REASONS, as defined in
    938      *        <code>com.android.internal.telephony.CommandsInterface.</code>
    939      * @param onComplete a callback message when the action is completed.
    940      *        @see com.android.internal.telephony.CallForwardInfo for details.
    941      */
    942     void getCallForwardingOption(int commandInterfaceCFReason,
    943                                   Message onComplete);
    944 
    945     /**
    946      * setCallForwardingOptions
    947      * sets a call forwarding option.
    948      *
    949      * @param commandInterfaceCFReason is one of the valid call forwarding
    950      *        CF_REASONS, as defined in
    951      *        <code>com.android.internal.telephony.CommandsInterface.</code>
    952      * @param commandInterfaceCFAction is one of the valid call forwarding
    953      *        CF_ACTIONS, as defined in
    954      *        <code>com.android.internal.telephony.CommandsInterface.</code>
    955      * @param dialingNumber is the target phone number to forward calls to
    956      * @param timerSeconds is used by CFNRy to indicate the timeout before
    957      *        forwarding is attempted.
    958      * @param onComplete a callback message when the action is completed.
    959      */
    960     void setCallForwardingOption(int commandInterfaceCFReason,
    961                                  int commandInterfaceCFAction,
    962                                  String dialingNumber,
    963                                  int timerSeconds,
    964                                  Message onComplete);
    965 
    966     /**
    967      * getOutgoingCallerIdDisplay
    968      * gets outgoing caller id display. The return value of
    969      * ((AsyncResult)onComplete.obj) is an array of int, with a length of 2.
    970      *
    971      * @param onComplete a callback message when the action is completed.
    972      *        @see com.android.internal.telephony.CommandsInterface#getCLIR for details.
    973      */
    974     void getOutgoingCallerIdDisplay(Message onComplete);
    975 
    976     /**
    977      * setOutgoingCallerIdDisplay
    978      * sets a call forwarding option.
    979      *
    980      * @param commandInterfaceCLIRMode is one of the valid call CLIR
    981      *        modes, as defined in
    982      *        <code>com.android.internal.telephony.CommandsInterface./code>
    983      * @param onComplete a callback message when the action is completed.
    984      */
    985     void setOutgoingCallerIdDisplay(int commandInterfaceCLIRMode,
    986                                     Message onComplete);
    987 
    988     /**
    989      * getCallWaiting
    990      * gets call waiting activation state. The return value of
    991      * ((AsyncResult)onComplete.obj) is an array of int, with a length of 1.
    992      *
    993      * @param onComplete a callback message when the action is completed.
    994      *        @see com.android.internal.telephony.CommandsInterface#queryCallWaiting for details.
    995      */
    996     void getCallWaiting(Message onComplete);
    997 
    998     /**
    999      * setCallWaiting
   1000      * sets a call forwarding option.
   1001      *
   1002      * @param enable is a boolean representing the state that you are
   1003      *        requesting, true for enabled, false for disabled.
   1004      * @param onComplete a callback message when the action is completed.
   1005      */
   1006     void setCallWaiting(boolean enable, Message onComplete);
   1007 
   1008     /**
   1009      * Scan available networks. This method is asynchronous; .
   1010      * On completion, <code>response.obj</code> is set to an AsyncResult with
   1011      * one of the following members:.<p>
   1012      *<ul>
   1013      * <li><code>response.obj.result</code> will be a <code>List</code> of
   1014      * <code>OperatorInfo</code> objects, or</li>
   1015      * <li><code>response.obj.exception</code> will be set with an exception
   1016      * on failure.</li>
   1017      * </ul>
   1018      */
   1019     void getAvailableNetworks(Message response);
   1020 
   1021     /**
   1022      * Switches network selection mode to "automatic", re-scanning and
   1023      * re-selecting a network if appropriate.
   1024      *
   1025      * @param response The message to dispatch when the network selection
   1026      * is complete.
   1027      *
   1028      * @see #selectNetworkManually(OperatorInfo, android.os.Message )
   1029      */
   1030     void setNetworkSelectionModeAutomatic(Message response);
   1031 
   1032     /**
   1033      * Manually selects a network. <code>response</code> is
   1034      * dispatched when this is complete.  <code>response.obj</code> will be
   1035      * an AsyncResult, and <code>response.obj.exception</code> will be non-null
   1036      * on failure.
   1037      *
   1038      * @see #setNetworkSelectionModeAutomatic(Message)
   1039      */
   1040     void selectNetworkManually(OperatorInfo network,
   1041                             Message response);
   1042 
   1043     /**
   1044      *  Requests to set the preferred network type for searching and registering
   1045      * (CS/PS domain, RAT, and operation mode)
   1046      * @param networkType one of  NT_*_TYPE
   1047      * @param response is callback message
   1048      */
   1049     void setPreferredNetworkType(int networkType, Message response);
   1050 
   1051     /**
   1052      *  Query the preferred network type setting
   1053      *
   1054      * @param response is callback message to report one of  NT_*_TYPE
   1055      */
   1056     void getPreferredNetworkType(Message response);
   1057 
   1058     /**
   1059      * Gets the default SMSC address.
   1060      *
   1061      * @param result Callback message contains the SMSC address.
   1062      */
   1063     void getSmscAddress(Message result);
   1064 
   1065     /**
   1066      * Sets the default SMSC address.
   1067      *
   1068      * @param address new SMSC address
   1069      * @param result Callback message is empty on completion
   1070      */
   1071     void setSmscAddress(String address, Message result);
   1072 
   1073     /**
   1074      * Query neighboring cell IDs.  <code>response</code> is dispatched when
   1075      * this is complete.  <code>response.obj</code> will be an AsyncResult,
   1076      * and <code>response.obj.exception</code> will be non-null on failure.
   1077      * On success, <code>AsyncResult.result</code> will be a <code>String[]</code>
   1078      * containing the neighboring cell IDs.  Index 0 will contain the count
   1079      * of available cell IDs.  Cell IDs are in hexadecimal format.
   1080      *
   1081      * @param response callback message that is dispatched when the query
   1082      * completes.
   1083      */
   1084     void getNeighboringCids(Message response);
   1085 
   1086     /**
   1087      * Sets an event to be fired when the telephony system processes
   1088      * a post-dial character on an outgoing call.<p>
   1089      *
   1090      * Messages of type <code>what</code> will be sent to <code>h</code>.
   1091      * The <code>obj</code> field of these Message's will be instances of
   1092      * <code>AsyncResult</code>. <code>Message.obj.result</code> will be
   1093      * a Connection object.<p>
   1094      *
   1095      * Message.arg1 will be the post dial character being processed,
   1096      * or 0 ('\0') if end of string.<p>
   1097      *
   1098      * If Connection.getPostDialState() == WAIT,
   1099      * the application must call
   1100      * {@link com.android.internal.telephony.Connection#proceedAfterWaitChar()
   1101      * Connection.proceedAfterWaitChar()} or
   1102      * {@link com.android.internal.telephony.Connection#cancelPostDial()
   1103      * Connection.cancelPostDial()}
   1104      * for the telephony system to continue playing the post-dial
   1105      * DTMF sequence.<p>
   1106      *
   1107      * If Connection.getPostDialState() == WILD,
   1108      * the application must call
   1109      * {@link com.android.internal.telephony.Connection#proceedAfterWildChar
   1110      * Connection.proceedAfterWildChar()}
   1111      * or
   1112      * {@link com.android.internal.telephony.Connection#cancelPostDial()
   1113      * Connection.cancelPostDial()}
   1114      * for the telephony system to continue playing the
   1115      * post-dial DTMF sequence.<p>
   1116      *
   1117      * Only one post dial character handler may be set. <p>
   1118      * Calling this method with "h" equal to null unsets this handler.<p>
   1119      */
   1120     void setOnPostDialCharacter(Handler h, int what, Object obj);
   1121 
   1122 
   1123     /**
   1124      * Mutes or unmutes the microphone for the active call. The microphone
   1125      * is automatically unmuted if a call is answered, dialed, or resumed
   1126      * from a holding state.
   1127      *
   1128      * @param muted true to mute the microphone,
   1129      * false to activate the microphone.
   1130      */
   1131 
   1132     void setMute(boolean muted);
   1133 
   1134     /**
   1135      * Gets current mute status. Use
   1136      * {@link #registerForPreciseCallStateChanged(android.os.Handler, int,
   1137      * java.lang.Object) registerForPreciseCallStateChanged()}
   1138      * as a change notifcation, although presently phone state changed is not
   1139      * fired when setMute() is called.
   1140      *
   1141      * @return true is muting, false is unmuting
   1142      */
   1143     boolean getMute();
   1144 
   1145     /**
   1146      * Enables or disables echo suppression.
   1147      */
   1148     void setEchoSuppressionEnabled(boolean enabled);
   1149 
   1150     /**
   1151      * Invokes RIL_REQUEST_OEM_HOOK_RAW on RIL implementation.
   1152      *
   1153      * @param data The data for the request.
   1154      * @param response <strong>On success</strong>,
   1155      * (byte[])(((AsyncResult)response.obj).result)
   1156      * <strong>On failure</strong>,
   1157      * (((AsyncResult)response.obj).result) == null and
   1158      * (((AsyncResult)response.obj).exception) being an instance of
   1159      * com.android.internal.telephony.gsm.CommandException
   1160      *
   1161      * @see #invokeOemRilRequestRaw(byte[], android.os.Message)
   1162      */
   1163     void invokeOemRilRequestRaw(byte[] data, Message response);
   1164 
   1165     /**
   1166      * Invokes RIL_REQUEST_OEM_HOOK_Strings on RIL implementation.
   1167      *
   1168      * @param strings The strings to make available as the request data.
   1169      * @param response <strong>On success</strong>, "response" bytes is
   1170      * made available as:
   1171      * (String[])(((AsyncResult)response.obj).result).
   1172      * <strong>On failure</strong>,
   1173      * (((AsyncResult)response.obj).result) == null and
   1174      * (((AsyncResult)response.obj).exception) being an instance of
   1175      * com.android.internal.telephony.gsm.CommandException
   1176      *
   1177      * @see #invokeOemRilRequestStrings(java.lang.String[], android.os.Message)
   1178      */
   1179     void invokeOemRilRequestStrings(String[] strings, Message response);
   1180 
   1181     /**
   1182      * Get the current active Data Call list
   1183      *
   1184      * @param response <strong>On success</strong>, "response" bytes is
   1185      * made available as:
   1186      * (String[])(((AsyncResult)response.obj).result).
   1187      * <strong>On failure</strong>,
   1188      * (((AsyncResult)response.obj).result) == null and
   1189      * (((AsyncResult)response.obj).exception) being an instance of
   1190      * com.android.internal.telephony.gsm.CommandException
   1191      */
   1192     void getDataCallList(Message response);
   1193 
   1194     /**
   1195      * Update the ServiceState CellLocation for current network registration.
   1196      */
   1197     void updateServiceLocation();
   1198 
   1199     /**
   1200      * Enable location update notifications.
   1201      */
   1202     void enableLocationUpdates();
   1203 
   1204     /**
   1205      * Disable location update notifications.
   1206      */
   1207     void disableLocationUpdates();
   1208 
   1209     /**
   1210      * For unit tests; don't send notifications to "Phone"
   1211      * mailbox registrants if true.
   1212      */
   1213     void setUnitTestMode(boolean f);
   1214 
   1215     /**
   1216      * @return true If unit test mode is enabled
   1217      */
   1218     boolean getUnitTestMode();
   1219 
   1220     /**
   1221      * Assign a specified band for RF configuration.
   1222      *
   1223      * @param bandMode one of BM_*_BAND
   1224      * @param response is callback message
   1225      */
   1226     void setBandMode(int bandMode, Message response);
   1227 
   1228     /**
   1229      * Query the list of band mode supported by RF.
   1230      *
   1231      * @param response is callback message
   1232      *        ((AsyncResult)response.obj).result  is an int[] with every
   1233      *        element representing one avialable BM_*_BAND
   1234      */
   1235     void queryAvailableBandMode(Message response);
   1236 
   1237     /**
   1238      * @return true if enable data connection on roaming
   1239      */
   1240     boolean getDataRoamingEnabled();
   1241 
   1242     /**
   1243      * @param enable set true if enable data connection on roaming
   1244      */
   1245     void setDataRoamingEnabled(boolean enable);
   1246 
   1247     /**
   1248      *  Query the CDMA roaming preference setting
   1249      *
   1250      * @param response is callback message to report one of  CDMA_RM_*
   1251      */
   1252     void queryCdmaRoamingPreference(Message response);
   1253 
   1254     /**
   1255      *  Requests to set the CDMA roaming preference
   1256      * @param cdmaRoamingType one of  CDMA_RM_*
   1257      * @param response is callback message
   1258      */
   1259     void setCdmaRoamingPreference(int cdmaRoamingType, Message response);
   1260 
   1261     /**
   1262      *  Requests to set the CDMA subscription mode
   1263      * @param cdmaSubscriptionType one of  CDMA_SUBSCRIPTION_*
   1264      * @param response is callback message
   1265      */
   1266     void setCdmaSubscription(int cdmaSubscriptionType, Message response);
   1267 
   1268     /**
   1269      * If this is a simulated phone interface, returns a SimulatedRadioControl.
   1270      * @return SimulatedRadioControl if this is a simulated interface;
   1271      * otherwise, null.
   1272      */
   1273     SimulatedRadioControl getSimulatedRadioControl();
   1274 
   1275     /**
   1276      * Enables the specified APN type. Only works for "special" APN types,
   1277      * i.e., not the default APN.
   1278      * @param type The desired APN type. Cannot be {@link PhoneConstants#APN_TYPE_DEFAULT}.
   1279      * @return <code>APN_ALREADY_ACTIVE</code> if the current APN
   1280      * services the requested type.<br/>
   1281      * <code>APN_TYPE_NOT_AVAILABLE</code> if the carrier does not
   1282      * support the requested APN.<br/>
   1283      * <code>APN_REQUEST_STARTED</code> if the request has been initiated.<br/>
   1284      * <code>APN_REQUEST_FAILED</code> if the request was invalid.<br/>
   1285      * A <code>ACTION_ANY_DATA_CONNECTION_STATE_CHANGED</code> broadcast will
   1286      * indicate connection state progress.
   1287      */
   1288     int enableApnType(String type);
   1289 
   1290     /**
   1291      * Disables the specified APN type, and switches back to the default APN,
   1292      * if necessary. Switching to the default APN will not happen if default
   1293      * data traffic has been explicitly disabled via a call to ITelephony#disableDataConnectivity.
   1294      * <p/>Only works for "special" APN types,
   1295      * i.e., not the default APN.
   1296      * @param type The desired APN type. Cannot be {@link PhoneConstants#APN_TYPE_DEFAULT}.
   1297      * @return <code>APN_ALREADY_ACTIVE</code> if the default APN
   1298      * is already active.<br/>
   1299      * <code>APN_REQUEST_STARTED</code> if the request to switch to the default
   1300      * APN has been initiated.<br/>
   1301      * <code>APN_REQUEST_FAILED</code> if the request was invalid.<br/>
   1302      * A <code>ACTION_ANY_DATA_CONNECTION_STATE_CHANGED</code> broadcast will
   1303      * indicate connection state progress.
   1304      */
   1305     int disableApnType(String type);
   1306 
   1307     /**
   1308      * Report on whether data connectivity is allowed.
   1309      */
   1310     boolean isDataConnectivityPossible();
   1311 
   1312     /**
   1313      * Report on whether data connectivity is allowed for an APN.
   1314      */
   1315     boolean isDataConnectivityPossible(String apnType);
   1316 
   1317     /**
   1318      * Retrieves the unique device ID, e.g., IMEI for GSM phones and MEID for CDMA phones.
   1319      */
   1320     String getDeviceId();
   1321 
   1322     /**
   1323      * Retrieves the software version number for the device, e.g., IMEI/SV
   1324      * for GSM phones.
   1325      */
   1326     String getDeviceSvn();
   1327 
   1328     /**
   1329      * Retrieves the unique subscriber ID, e.g., IMSI for GSM phones.
   1330      */
   1331     String getSubscriberId();
   1332 
   1333     /**
   1334      * Retrieves the Group Identifier Level1 for GSM phones.
   1335      */
   1336     String getGroupIdLevel1();
   1337 
   1338     /**
   1339      * Retrieves the serial number of the ICC, if applicable.
   1340      */
   1341     String getIccSerialNumber();
   1342 
   1343     /* CDMA support methods */
   1344 
   1345     /**
   1346      * Retrieves the MIN for CDMA phones.
   1347      */
   1348     String getCdmaMin();
   1349 
   1350     /**
   1351      * Check if subscription data has been assigned to mMin
   1352      *
   1353      * return true if MIN info is ready; false otherwise.
   1354      */
   1355     boolean isMinInfoReady();
   1356 
   1357     /**
   1358      *  Retrieves PRL Version for CDMA phones
   1359      */
   1360     String getCdmaPrlVersion();
   1361 
   1362     /**
   1363      * Retrieves the ESN for CDMA phones.
   1364      */
   1365     String getEsn();
   1366 
   1367     /**
   1368      * Retrieves MEID for CDMA phones.
   1369      */
   1370     String getMeid();
   1371 
   1372     /**
   1373      * Retrieves the MSISDN from the UICC. For GSM/UMTS phones, this is equivalent to
   1374      * {@link #getLine1Number()}. For CDMA phones, {@link #getLine1Number()} returns
   1375      * the MDN, so this method is provided to return the MSISDN on CDMA/LTE phones.
   1376      */
   1377     String getMsisdn();
   1378 
   1379     /**
   1380      * Retrieves IMEI for phones. Returns null if IMEI is not set.
   1381      */
   1382     String getImei();
   1383 
   1384     /**
   1385      * Retrieves the PhoneSubInfo of the Phone
   1386      */
   1387     public PhoneSubInfo getPhoneSubInfo();
   1388 
   1389     /**
   1390      * Retrieves the IccPhoneBookInterfaceManager of the Phone
   1391      */
   1392     public IccPhoneBookInterfaceManager getIccPhoneBookInterfaceManager();
   1393 
   1394     /**
   1395      * setTTYMode
   1396      * sets a TTY mode option.
   1397      * @param ttyMode is a one of the following:
   1398      * - {@link com.android.internal.telephony.Phone#TTY_MODE_OFF}
   1399      * - {@link com.android.internal.telephony.Phone#TTY_MODE_FULL}
   1400      * - {@link com.android.internal.telephony.Phone#TTY_MODE_HCO}
   1401      * - {@link com.android.internal.telephony.Phone#TTY_MODE_VCO}
   1402      * @param onComplete a callback message when the action is completed
   1403      */
   1404     void setTTYMode(int ttyMode, Message onComplete);
   1405 
   1406     /**
   1407      * queryTTYMode
   1408      * query the status of the TTY mode
   1409      *
   1410      * @param onComplete a callback message when the action is completed.
   1411      */
   1412     void queryTTYMode(Message onComplete);
   1413 
   1414     /**
   1415      * Activate or deactivate cell broadcast SMS.
   1416      *
   1417      * @param activate
   1418      *            0 = activate, 1 = deactivate
   1419      * @param response
   1420      *            Callback message is empty on completion
   1421      */
   1422     void activateCellBroadcastSms(int activate, Message response);
   1423 
   1424     /**
   1425      * Query the current configuration of cdma cell broadcast SMS.
   1426      *
   1427      * @param response
   1428      *            Callback message is empty on completion
   1429      */
   1430     void getCellBroadcastSmsConfig(Message response);
   1431 
   1432     /**
   1433      * Configure cell broadcast SMS.
   1434      *
   1435      * TODO: Change the configValuesArray to a RIL_BroadcastSMSConfig
   1436      *
   1437      * @param response
   1438      *            Callback message is empty on completion
   1439      */
   1440     public void setCellBroadcastSmsConfig(int[] configValuesArray, Message response);
   1441 
   1442     public void notifyDataActivity();
   1443 
   1444     /**
   1445      * Returns the CDMA ERI icon index to display
   1446      */
   1447     public int getCdmaEriIconIndex();
   1448 
   1449     /**
   1450      * Returns the CDMA ERI icon mode,
   1451      * 0 - ON
   1452      * 1 - FLASHING
   1453      */
   1454     public int getCdmaEriIconMode();
   1455 
   1456     /**
   1457      * Returns the CDMA ERI text,
   1458      */
   1459     public String getCdmaEriText();
   1460 
   1461     /**
   1462      * request to exit emergency call back mode
   1463      * the caller should use setOnECMModeExitResponse
   1464      * to receive the emergency callback mode exit response
   1465      */
   1466     void exitEmergencyCallbackMode();
   1467 
   1468     /**
   1469      * this decides if the dial number is OTA(Over the air provision) number or not
   1470      * @param dialStr is string representing the dialing digit(s)
   1471      * @return  true means the dialStr is OTA number, and false means the dialStr is not OTA number
   1472      */
   1473     boolean isOtaSpNumber(String dialStr);
   1474 
   1475     /**
   1476      * Returns true if OTA Service Provisioning needs to be performed.
   1477      */
   1478     boolean needsOtaServiceProvisioning();
   1479 
   1480     /**
   1481      * Register for notifications when CDMA call waiting comes
   1482      *
   1483      * @param h Handler that receives the notification message.
   1484      * @param what User-defined message code.
   1485      * @param obj User object.
   1486      */
   1487     void registerForCallWaiting(Handler h, int what, Object obj);
   1488 
   1489     /**
   1490      * Unegister for notifications when CDMA Call waiting comes
   1491      * @param h Handler to be removed from the registrant list.
   1492      */
   1493     void unregisterForCallWaiting(Handler h);
   1494 
   1495 
   1496     /**
   1497      * Register for signal information notifications from the network.
   1498      * Message.obj will contain an AsyncResult.
   1499      * AsyncResult.result will be a SuppServiceNotification instance.
   1500      *
   1501      * @param h Handler that receives the notification message.
   1502      * @param what User-defined message code.
   1503      * @param obj User object.
   1504      */
   1505 
   1506     void registerForSignalInfo(Handler h, int what, Object obj) ;
   1507     /**
   1508      * Unregisters for signal information notifications.
   1509      * Extraneous calls are tolerated silently
   1510      *
   1511      * @param h Handler to be removed from the registrant list.
   1512      */
   1513     void unregisterForSignalInfo(Handler h);
   1514 
   1515     /**
   1516      * Register for display information notifications from the network.
   1517      * Message.obj will contain an AsyncResult.
   1518      * AsyncResult.result will be a SuppServiceNotification instance.
   1519      *
   1520      * @param h Handler that receives the notification message.
   1521      * @param what User-defined message code.
   1522      * @param obj User object.
   1523      */
   1524     void registerForDisplayInfo(Handler h, int what, Object obj);
   1525 
   1526     /**
   1527      * Unregisters for display information notifications.
   1528      * Extraneous calls are tolerated silently
   1529      *
   1530      * @param h Handler to be removed from the registrant list.
   1531      */
   1532     void unregisterForDisplayInfo(Handler h) ;
   1533 
   1534     /**
   1535      * Register for CDMA number information record notification from the network.
   1536      * Message.obj will contain an AsyncResult.
   1537      * AsyncResult.result will be a CdmaInformationRecords.CdmaNumberInfoRec
   1538      * instance.
   1539      *
   1540      * @param h Handler that receives the notification message.
   1541      * @param what User-defined message code.
   1542      * @param obj User object.
   1543      */
   1544     void registerForNumberInfo(Handler h, int what, Object obj);
   1545 
   1546     /**
   1547      * Unregisters for number information record notifications.
   1548      * Extraneous calls are tolerated silently
   1549      *
   1550      * @param h Handler to be removed from the registrant list.
   1551      */
   1552     void unregisterForNumberInfo(Handler h);
   1553 
   1554     /**
   1555      * Register for CDMA redirected number information record notification
   1556      * from the network.
   1557      * Message.obj will contain an AsyncResult.
   1558      * AsyncResult.result will be a CdmaInformationRecords.CdmaRedirectingNumberInfoRec
   1559      * instance.
   1560      *
   1561      * @param h Handler that receives the notification message.
   1562      * @param what User-defined message code.
   1563      * @param obj User object.
   1564      */
   1565     void registerForRedirectedNumberInfo(Handler h, int what, Object obj);
   1566 
   1567     /**
   1568      * Unregisters for redirected number information record notification.
   1569      * Extraneous calls are tolerated silently
   1570      *
   1571      * @param h Handler to be removed from the registrant list.
   1572      */
   1573     void unregisterForRedirectedNumberInfo(Handler h);
   1574 
   1575     /**
   1576      * Register for CDMA line control information record notification
   1577      * from the network.
   1578      * Message.obj will contain an AsyncResult.
   1579      * AsyncResult.result will be a CdmaInformationRecords.CdmaLineControlInfoRec
   1580      * instance.
   1581      *
   1582      * @param h Handler that receives the notification message.
   1583      * @param what User-defined message code.
   1584      * @param obj User object.
   1585      */
   1586     void registerForLineControlInfo(Handler h, int what, Object obj);
   1587 
   1588     /**
   1589      * Unregisters for line control information notifications.
   1590      * Extraneous calls are tolerated silently
   1591      *
   1592      * @param h Handler to be removed from the registrant list.
   1593      */
   1594     void unregisterForLineControlInfo(Handler h);
   1595 
   1596     /**
   1597      * Register for CDMA T53 CLIR information record notifications
   1598      * from the network.
   1599      * Message.obj will contain an AsyncResult.
   1600      * AsyncResult.result will be a CdmaInformationRecords.CdmaT53ClirInfoRec
   1601      * instance.
   1602      *
   1603      * @param h Handler that receives the notification message.
   1604      * @param what User-defined message code.
   1605      * @param obj User object.
   1606      */
   1607     void registerFoT53ClirlInfo(Handler h, int what, Object obj);
   1608 
   1609     /**
   1610      * Unregisters for T53 CLIR information record notification
   1611      * Extraneous calls are tolerated silently
   1612      *
   1613      * @param h Handler to be removed from the registrant list.
   1614      */
   1615     void unregisterForT53ClirInfo(Handler h);
   1616 
   1617     /**
   1618      * Register for CDMA T53 audio control information record notifications
   1619      * from the network.
   1620      * Message.obj will contain an AsyncResult.
   1621      * AsyncResult.result will be a CdmaInformationRecords.CdmaT53AudioControlInfoRec
   1622      * instance.
   1623      *
   1624      * @param h Handler that receives the notification message.
   1625      * @param what User-defined message code.
   1626      * @param obj User object.
   1627      */
   1628     void registerForT53AudioControlInfo(Handler h, int what, Object obj);
   1629 
   1630     /**
   1631      * Unregisters for T53 audio control information record notifications.
   1632      * Extraneous calls are tolerated silently
   1633      *
   1634      * @param h Handler to be removed from the registrant list.
   1635      */
   1636     void unregisterForT53AudioControlInfo(Handler h);
   1637 
   1638     /**
   1639      * registers for exit emergency call back mode request response
   1640      *
   1641      * @param h Handler that receives the notification message.
   1642      * @param what User-defined message code.
   1643      * @param obj User object.
   1644      */
   1645 
   1646     void setOnEcbModeExitResponse(Handler h, int what, Object obj);
   1647 
   1648     /**
   1649      * Unregisters for exit emergency call back mode request response
   1650      *
   1651      * @param h Handler to be removed from the registrant list.
   1652      */
   1653     void unsetOnEcbModeExitResponse(Handler h);
   1654 
   1655     /**
   1656      * Return if the current radio is LTE on CDMA. This
   1657      * is a tri-state return value as for a period of time
   1658      * the mode may be unknown.
   1659      *
   1660      * @return {@link PhoneConstants#LTE_ON_CDMA_UNKNOWN}, {@link PhoneConstants#LTE_ON_CDMA_FALSE}
   1661      * or {@link PhoneConstants#LTE_ON_CDMA_TRUE}
   1662      */
   1663     public int getLteOnCdmaMode();
   1664 
   1665     /**
   1666      * TODO: Adding a function for each property is not good.
   1667      * A fucntion of type getPhoneProp(propType) where propType is an
   1668      * enum of GSM+CDMA+LTE props would be a better approach.
   1669      *
   1670      * Get "Restriction of menu options for manual PLMN selection" bit
   1671      * status from EF_CSP data, this belongs to "Value Added Services Group".
   1672      * @return true if this bit is set or EF_CSP data is unavailable,
   1673      * false otherwise
   1674      */
   1675     boolean isCspPlmnEnabled();
   1676 
   1677     /**
   1678      * Return an interface to retrieve the ISIM records for IMS, if available.
   1679      * @return the interface to retrieve the ISIM records, or null if not supported
   1680      */
   1681     IsimRecords getIsimRecords();
   1682 
   1683     /**
   1684      * Request the ISIM application on the UICC to perform the AKA
   1685      * challenge/response algorithm for IMS authentication. The nonce string
   1686      * and challenge response are Base64 encoded Strings.
   1687      *
   1688      * @param nonce the nonce string to pass with the ISIM authentication request
   1689      * @param response a callback message with the String response in the obj field
   1690      */
   1691     void requestIsimAuthentication(String nonce, Message response);
   1692 
   1693     /**
   1694      * Sets the SIM voice message waiting indicator records.
   1695      * @param line GSM Subscriber Profile Number, one-based. Only '1' is supported
   1696      * @param countWaiting The number of messages waiting, if known. Use
   1697      *                     -1 to indicate that an unknown number of
   1698      *                      messages are waiting
   1699      */
   1700     void setVoiceMessageWaiting(int line, int countWaiting);
   1701 
   1702     /**
   1703      * Gets the USIM service table from the UICC, if present and available.
   1704      * @return an interface to the UsimServiceTable record, or null if not available
   1705      */
   1706     UsimServiceTable getUsimServiceTable();
   1707 
   1708     /**
   1709      * Unregister from all events it registered for and dispose objects
   1710      * created by this object.
   1711      */
   1712     void dispose();
   1713 
   1714     /**
   1715      * Remove references to external object stored in this object.
   1716      */
   1717     void removeReferences();
   1718 
   1719     /**
   1720      * Update the phone object if the voice radio technology has changed
   1721      *
   1722      * @param voiceRadioTech The new voice radio technology
   1723      */
   1724     void updatePhoneObject(int voiceRadioTech);
   1725 }
   1726