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