1 /*
2  * Copyright (C) 2022 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.settingslib.mobile.dataservice;
18 
19 import androidx.lifecycle.LiveData;
20 import androidx.room.Dao;
21 import androidx.room.Insert;
22 import androidx.room.OnConflictStrategy;
23 import androidx.room.Query;
24 
25 import java.util.List;
26 
27 @Dao
28 public interface SubscriptionInfoDao {
29 
30     @Insert(onConflict = OnConflictStrategy.REPLACE)
insertSubsInfo(SubscriptionInfoEntity... subscriptionInfo)31     void insertSubsInfo(SubscriptionInfoEntity... subscriptionInfo);
32 
33     @Query("SELECT * FROM " + DataServiceUtils.SubscriptionInfoData.TABLE_NAME + " ORDER BY "
34             + " CASE WHEN " +  DataServiceUtils.SubscriptionInfoData.COLUMN_SIM_SLOT_INDEX
35             + " >= 0 THEN 1 ELSE 2 END , "
36             + DataServiceUtils.SubscriptionInfoData.COLUMN_SIM_SLOT_INDEX)
queryAvailableSubInfos()37     LiveData<List<SubscriptionInfoEntity>> queryAvailableSubInfos();
38 
39     @Query("SELECT * FROM " + DataServiceUtils.SubscriptionInfoData.TABLE_NAME + " WHERE "
40             + DataServiceUtils.SubscriptionInfoData.COLUMN_ID + " = :subId")
querySubInfoById(String subId)41     SubscriptionInfoEntity querySubInfoById(String subId);
42 
43     @Query("SELECT * FROM " + DataServiceUtils.SubscriptionInfoData.TABLE_NAME + " WHERE "
44             + DataServiceUtils.SubscriptionInfoData.COLUMN_IS_ACTIVE_SUBSCRIPTION_ID
45             + " = :isActiveSubscription" + " AND "
46             + DataServiceUtils.SubscriptionInfoData.COLUMN_IS_SUBSCRIPTION_VISIBLE
47             + " = :isSubscriptionVisible" + " ORDER BY "
48             + DataServiceUtils.SubscriptionInfoData.COLUMN_SIM_SLOT_INDEX)
queryActiveSubInfos( boolean isActiveSubscription, boolean isSubscriptionVisible)49     LiveData<List<SubscriptionInfoEntity>> queryActiveSubInfos(
50             boolean isActiveSubscription, boolean isSubscriptionVisible);
51 
52     @Query("SELECT COUNT(*) FROM " + DataServiceUtils.SubscriptionInfoData.TABLE_NAME)
count()53     int count();
54 
55     @Query("DELETE FROM " + DataServiceUtils.SubscriptionInfoData.TABLE_NAME + " WHERE "
56             + DataServiceUtils.SubscriptionInfoData.COLUMN_ID + " = :id")
deleteBySubId(String id)57     void deleteBySubId(String id);
58 
59 }
60