Home | History | Annotate | Download | only in telephony
      1 /*
      2  * Copyright (C) 2012 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 package com.android.internal.telephony;
     17 
     18 /**
     19  * @hide
     20  */
     21 public class PhoneConstants {
     22 
     23     /**
     24      * The phone state. One of the following:<p>
     25      * <ul>
     26      * <li>IDLE = no phone activity</li>
     27      * <li>RINGING = a phone call is ringing or call waiting.
     28      *  In the latter case, another call is active as well</li>
     29      * <li>OFFHOOK = The phone is off hook. At least one call
     30      * exists that is dialing, active or holding and no calls are
     31      * ringing or waiting.</li>
     32      * </ul>
     33      */
     34     public enum State {
     35         IDLE, RINGING, OFFHOOK;
     36     };
     37 
     38    /**
     39      * The state of a data connection.
     40      * <ul>
     41      * <li>CONNECTED = IP traffic should be available</li>
     42      * <li>CONNECTING = Currently setting up data connection</li>
     43      * <li>DISCONNECTED = IP not available</li>
     44      * <li>SUSPENDED = connection is created but IP traffic is
     45      *                 temperately not available. i.e. voice call is in place
     46      *                 in 2G network</li>
     47      * </ul>
     48      */
     49     public enum DataState {
     50         CONNECTED, CONNECTING, DISCONNECTED, SUSPENDED;
     51     };
     52 
     53     public static final String STATE_KEY = "state";
     54 
     55     // Radio Type
     56     public static final int PHONE_TYPE_NONE = RILConstants.NO_PHONE;
     57     public static final int PHONE_TYPE_GSM = RILConstants.GSM_PHONE;
     58     public static final int PHONE_TYPE_CDMA = RILConstants.CDMA_PHONE;
     59     public static final int PHONE_TYPE_SIP = RILConstants.SIP_PHONE;
     60     public static final int PHONE_TYPE_THIRD_PARTY = RILConstants.THIRD_PARTY_PHONE;
     61     public static final int PHONE_TYPE_IMS = RILConstants.IMS_PHONE;
     62 
     63     // Modes for LTE_ON_CDMA
     64     public static final int LTE_ON_CDMA_UNKNOWN = RILConstants.LTE_ON_CDMA_UNKNOWN;
     65     public static final int LTE_ON_CDMA_FALSE = RILConstants.LTE_ON_CDMA_FALSE;
     66     public static final int LTE_ON_CDMA_TRUE = RILConstants.LTE_ON_CDMA_TRUE;
     67 
     68     // Number presentation type for caller id display (From internal/Connection.java)
     69     public static final int PRESENTATION_ALLOWED = 1;    // normal
     70     public static final int PRESENTATION_RESTRICTED = 2; // block by user
     71     public static final int PRESENTATION_UNKNOWN = 3;    // no specified or unknown by network
     72     public static final int PRESENTATION_PAYPHONE = 4;   // show pay phone info
     73 
     74 
     75     public static final String PHONE_NAME_KEY = "phoneName";
     76     public static final String FAILURE_REASON_KEY = "reason";
     77     public static final String STATE_CHANGE_REASON_KEY = "reason";
     78     public static final String DATA_NETWORK_TYPE_KEY = "networkType";
     79     public static final String DATA_FAILURE_CAUSE_KEY = "failCause";
     80     public static final String DATA_APN_TYPE_KEY = "apnType";
     81     public static final String DATA_APN_KEY = "apn";
     82     public static final String DATA_LINK_PROPERTIES_KEY = "linkProperties";
     83     public static final String DATA_NETWORK_CAPABILITIES_KEY = "networkCapabilities";
     84 
     85     public static final String DATA_IFACE_NAME_KEY = "iface";
     86     public static final String NETWORK_UNAVAILABLE_KEY = "networkUnvailable";
     87     public static final String DATA_NETWORK_ROAMING_KEY = "networkRoaming";
     88     public static final String PHONE_IN_ECM_STATE = "phoneinECMState";
     89 
     90     public static final String REASON_LINK_PROPERTIES_CHANGED = "linkPropertiesChanged";
     91 
     92     /**
     93      * Return codes for supplyPinReturnResult and
     94      * supplyPukReturnResult APIs
     95      */
     96     public static final int PIN_RESULT_SUCCESS = 0;
     97     public static final int PIN_PASSWORD_INCORRECT = 1;
     98     public static final int PIN_GENERAL_FAILURE = 2;
     99 
    100     /**
    101      * Return codes for <code>enableApnType()</code>
    102      */
    103     public static final int APN_ALREADY_ACTIVE     = 0;
    104     public static final int APN_REQUEST_STARTED    = 1;
    105     public static final int APN_TYPE_NOT_AVAILABLE = 2;
    106     public static final int APN_REQUEST_FAILED     = 3;
    107     public static final int APN_ALREADY_INACTIVE   = 4;
    108 
    109     /**
    110      * APN types for data connections.  These are usage categories for an APN
    111      * entry.  One APN entry may support multiple APN types, eg, a single APN
    112      * may service regular internet traffic ("default") as well as MMS-specific
    113      * connections.<br/>
    114      * APN_TYPE_ALL is a special type to indicate that this APN entry can
    115      * service all data connections.
    116      */
    117     public static final String APN_TYPE_ALL = "*";
    118     /** APN type for default data traffic */
    119     public static final String APN_TYPE_DEFAULT = "default";
    120     /** APN type for MMS traffic */
    121     public static final String APN_TYPE_MMS = "mms";
    122     /** APN type for SUPL assisted GPS */
    123     public static final String APN_TYPE_SUPL = "supl";
    124     /** APN type for DUN traffic */
    125     public static final String APN_TYPE_DUN = "dun";
    126     /** APN type for HiPri traffic */
    127     public static final String APN_TYPE_HIPRI = "hipri";
    128     /** APN type for FOTA */
    129     public static final String APN_TYPE_FOTA = "fota";
    130     /** APN type for IMS */
    131     public static final String APN_TYPE_IMS = "ims";
    132     /** APN type for CBS */
    133     public static final String APN_TYPE_CBS = "cbs";
    134     /** APN type for IA Initial Attach APN */
    135     public static final String APN_TYPE_IA = "ia";
    136     /** APN type for IA Emergency PDN */
    137     public static final String APN_TYPE_EMERGENCY = "emergency";
    138 
    139     public static final int RIL_CARD_MAX_APPS    = 8;
    140 
    141     public static final int DEFAULT_CARD_INDEX   = 0;
    142 
    143     public static final int MAX_PHONE_COUNT_SINGLE_SIM = 1;
    144 
    145     public static final int MAX_PHONE_COUNT_DUAL_SIM = 2;
    146 
    147     public static final int MAX_PHONE_COUNT_TRI_SIM = 3;
    148 
    149     public static final String PHONE_KEY = "phone";
    150 
    151     public static final String SLOT_KEY  = "slot";
    152 
    153     // FIXME: This is used to pass a subId via intents, we need to look at its usage, which is
    154     // FIXME: extensive, and see if this should be an array of all active subId's or ...?
    155     public static final String SUBSCRIPTION_KEY  = "subscription";
    156 
    157     public static final String SUB_SETTING  = "subSettings";
    158 
    159     public static final int SUB1 = 0;
    160     public static final int SUB2 = 1;
    161     public static final int SUB3 = 2;
    162 
    163     public static final int EVENT_SUBSCRIPTION_ACTIVATED   = 500;
    164     public static final int EVENT_SUBSCRIPTION_DEACTIVATED = 501;
    165 
    166     // TODO: Remove these constants and use an int instead.
    167     public static final int SIM_ID_1 = 0;
    168     public static final int SIM_ID_2 = 1;
    169     public static final int SIM_ID_3 = 2;
    170     public static final int SIM_ID_4 = 3;
    171 
    172     // ICC SIM Application Types
    173     // TODO: Replace the IccCardApplicationStatus.AppType enums with these constants
    174     public static final int APPTYPE_UNKNOWN = 0;
    175     public static final int APPTYPE_SIM = 1;
    176     public static final int APPTYPE_USIM = 2;
    177     public static final int APPTYPE_RUIM = 3;
    178     public static final int APPTYPE_CSIM = 4;
    179     public static final int APPTYPE_ISIM = 5;
    180 
    181     public enum CardUnavailableReason {
    182         REASON_CARD_REMOVED,
    183         REASON_RADIO_UNAVAILABLE,
    184         REASON_SIM_REFRESH_RESET
    185     };
    186 
    187     // Initial MTU value.
    188     public static final int UNSET_MTU = 0;
    189 }
    190