1 /*
2  * Copyright (c) 2013 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.ims.internal;
18 
19 import com.android.ims.ImsReasonInfo;
20 
21 import android.net.Uri;
22 
23 /**
24  * A listener type for receiving notifications about the changes to
25  * the IMS connection(registration).
26  *
27  * {@hide}
28  */
29 interface IImsRegistrationListener {
30     /**
31      * Notifies the application when the device is connected to the IMS network.
32      *
33      * @deprecated see {@link registrationConnectedWithRadioTech}
34      */
registrationConnected()35     void registrationConnected();
36 
37     /**
38      * Notifies the application when the device is trying to connect the IMS network.
39      *
40      * @deprecated see {@link registrationProgressingWithRadioTech}
41      */
registrationProgressing()42     void registrationProgressing();
43 
44     /**
45      * Notifies the application when the device is connected to the IMS network.
46      *
47      * @param imsRadioTech the radio access technology. Valid values are {@code
48      * RIL_RADIO_TECHNOLOGY_*} defined in {@link ServiceState}.
49      */
registrationConnectedWithRadioTech(int imsRadioTech)50     void registrationConnectedWithRadioTech(int imsRadioTech);
51 
52     /**
53      * Notifies the application when the device is trying to connect the IMS network.
54      *
55      * @param imsRadioTech the radio access technology. Valid values are {@code
56      * RIL_RADIO_TECHNOLOGY_*} defined in {@link ServiceState}.
57      */
registrationProgressingWithRadioTech(int imsRadioTech)58     void registrationProgressingWithRadioTech(int imsRadioTech);
59 
60 
61     /**
62      * Notifies the application when the device is disconnected from the IMS network.
63      */
registrationDisconnected(in ImsReasonInfo imsReasonInfo)64     void registrationDisconnected(in ImsReasonInfo imsReasonInfo);
65 
66     /**
67      * Notifies the application when its suspended IMS connection is resumed,
68      * meaning the connection now allows throughput.
69      */
registrationResumed()70     void registrationResumed();
71 
72     /**
73      * Notifies the application when its current IMS connection is suspended,
74      * meaning there is no data throughput.
75      */
registrationSuspended()76     void registrationSuspended();
77 
78     /**
79      * Notifies the application when its current IMS connection is updated
80      * since the service setting is changed or the service is added/removed.
81      *
82      * @param serviceClass a service class specified in {@link ImsServiceClass}
83      * @param event an event type when this callback is called
84      *    If {@code event} is 0, meaning the specified service is removed from the IMS connection.
85      *    Else ({@code event} is 1), meaning the specified service is added to the IMS connection.
86      */
registrationServiceCapabilityChanged(int serviceClass, int event)87     void registrationServiceCapabilityChanged(int serviceClass, int event);
88 
89     /**
90      * Notifies the application when features on a particular service enabled or
91      * disabled successfully based on user preferences.
92      *
93      * @param serviceClass a service class specified in {@link ImsServiceClass}
94      * @param enabledFeatures features enabled as defined in com.android.ims.ImsConfig#FeatureConstants.
95      * @param disabledFeatures features disabled as defined in com.android.ims.ImsConfig#FeatureConstants.
96      */
registrationFeatureCapabilityChanged(int serviceClass, in int[] enabledFeatures, in int[] disabledFeatures)97     void registrationFeatureCapabilityChanged(int serviceClass,
98             in int[] enabledFeatures, in int[] disabledFeatures);
99 
100     /**
101      * Updates the application with the waiting voice message count.
102      * @param count The number of waiting voice messages.
103      */
voiceMessageCountUpdate(int count)104     void voiceMessageCountUpdate(int count);
105 
106     /**
107      * Notifies the application when the list of URIs associated with IMS client is updated.
108      */
registrationAssociatedUriChanged(in Uri[] uris)109     void registrationAssociatedUriChanged(in Uri[] uris);
110 
111     /**
112      * Notifies the application when IMS registration attempt on a target
113      * access tech fails.
114      *
115      * @param targetAccessTech Radio access technology on which the IMS registration was
116      *         attempted.
117      * @param imsReasonInfo Reason for the failure.
118      */
registrationChangeFailed(in int targetAccessTech, in ImsReasonInfo imsReasonInfo)119     void registrationChangeFailed(in int targetAccessTech, in ImsReasonInfo imsReasonInfo);
120 }
121