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 
17 package com.android.settingslib.bluetooth;
18 
19 /* Required to handle timeout notification when phone is suspended */
20 import android.app.AlarmManager;
21 import android.app.PendingIntent;
22 import android.bluetooth.BluetoothAdapter;
23 import android.content.BroadcastReceiver;
24 import android.content.Context;
25 import android.content.Intent;
26 import android.util.Log;
27 
28 
29 public class BluetoothDiscoverableTimeoutReceiver extends BroadcastReceiver {
30     private static final String TAG = "BluetoothDiscoverableTimeoutReceiver";
31 
32     private static final String INTENT_DISCOVERABLE_TIMEOUT =
33         "android.bluetooth.intent.DISCOVERABLE_TIMEOUT";
34 
setDiscoverableAlarm(Context context, long alarmTime)35     public static void setDiscoverableAlarm(Context context, long alarmTime) {
36         Log.d(TAG, "setDiscoverableAlarm(): alarmTime = " + alarmTime);
37 
38         Intent intent = new Intent(INTENT_DISCOVERABLE_TIMEOUT);
39         intent.setClass(context, BluetoothDiscoverableTimeoutReceiver.class);
40         PendingIntent pending = PendingIntent.getBroadcast(
41                 context, 0, intent, PendingIntent.FLAG_IMMUTABLE);
42         AlarmManager alarmManager =
43               (AlarmManager) context.getSystemService (Context.ALARM_SERVICE);
44 
45         if (pending != null) {
46             // Cancel any previous alarms that do the same thing.
47             alarmManager.cancel(pending);
48             Log.d(TAG, "setDiscoverableAlarm(): cancel prev alarm");
49         }
50         pending = PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_IMMUTABLE);
51 
52         alarmManager.set(AlarmManager.RTC_WAKEUP, alarmTime, pending);
53     }
54 
cancelDiscoverableAlarm(Context context)55     public static void cancelDiscoverableAlarm(Context context) {
56         Log.d(TAG, "cancelDiscoverableAlarm(): Enter");
57 
58         Intent intent = new Intent(INTENT_DISCOVERABLE_TIMEOUT);
59         intent.setClass(context, BluetoothDiscoverableTimeoutReceiver.class);
60         PendingIntent pending = PendingIntent.getBroadcast(
61                 context, 0, intent, PendingIntent.FLAG_NO_CREATE | PendingIntent.FLAG_IMMUTABLE);
62         if (pending != null) {
63             // Cancel any previous alarms that do the same thing.
64             AlarmManager alarmManager =
65               (AlarmManager) context.getSystemService (Context.ALARM_SERVICE);
66 
67             alarmManager.cancel(pending);
68         }
69     }
70 
71     @Override
onReceive(Context context, Intent intent)72     public void onReceive(Context context, Intent intent) {
73         if (intent.getAction() == null || !intent.getAction().equals(INTENT_DISCOVERABLE_TIMEOUT)) {
74             return;
75         }
76         LocalBluetoothAdapter localBluetoothAdapter = LocalBluetoothAdapter.getInstance();
77         if(localBluetoothAdapter != null  &&
78             localBluetoothAdapter.getState() == BluetoothAdapter.STATE_ON) {
79             Log.d(TAG, "Disable discoverable...");
80             localBluetoothAdapter.setScanMode(BluetoothAdapter.SCAN_MODE_CONNECTABLE);
81         } else {
82             Log.e(TAG, "localBluetoothAdapter is NULL!!");
83         }
84     }
85 }
86