blob: b75da0c0552414ca3527fad1ea73785ddf274597 [file] [log] [blame]
Michael Kolb14612442011-06-24 13:06:29 -07001/*
2 * Copyright (C) 2011 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 */
Bijan Amirzada41242f22014-03-21 12:12:18 -070016package com.android.browser;
Michael Kolb14612442011-06-24 13:06:29 -070017
18import android.content.BroadcastReceiver;
19import android.content.Context;
20import android.content.Intent;
Mathew Inwood467813f2011-09-02 15:43:17 +010021import android.net.ConnectivityManager;
22import android.net.NetworkInfo;
Michael Kolb14612442011-06-24 13:06:29 -070023import android.os.Bundle;
Michael Kolb14612442011-06-24 13:06:29 -070024import android.util.Log;
25
Bijan Amirzada3f04dc72014-06-25 11:48:36 -070026import com.android.browser.platformsupport.Browser;
27
Michael Kolb14612442011-06-24 13:06:29 -070028import java.util.HashMap;
29import java.util.Iterator;
30import java.util.Map;
31
32/**
33 * Broadcast receiver for receiving browser preload requests
34 */
35public class PreloadRequestReceiver extends BroadcastReceiver {
36
37 private final static String LOGTAG = "browser.preloader";
Bijan Amirzada41242f22014-03-21 12:12:18 -070038 private final static boolean LOGD_ENABLED = com.android.browser.Browser.LOGD_ENABLED;
Michael Kolb14612442011-06-24 13:06:29 -070039
40 private static final String ACTION_PRELOAD = "android.intent.action.PRELOAD";
41 static final String EXTRA_PRELOAD_ID = "preload_id";
42 static final String EXTRA_PRELOAD_DISCARD = "preload_discard";
Mathew Inwooddffa72f2011-08-10 12:37:43 +010043 static final String EXTRA_SEARCHBOX_CANCEL = "searchbox_cancel";
Mathew Inwood29721c22011-06-29 17:55:24 +010044 static final String EXTRA_SEARCHBOX_SETQUERY = "searchbox_query";
Michael Kolb14612442011-06-24 13:06:29 -070045
Mathew Inwood467813f2011-09-02 15:43:17 +010046 private ConnectivityManager mConnectivityManager;
47
Michael Kolb14612442011-06-24 13:06:29 -070048 @Override
49 public void onReceive(Context context, Intent intent) {
50 if (LOGD_ENABLED) Log.d(LOGTAG, "received intent " + intent);
Mathew Inwood467813f2011-09-02 15:43:17 +010051 if (isPreloadEnabledOnCurrentNetwork(context) &&
52 intent.getAction().equals(ACTION_PRELOAD)) {
Michael Kolb14612442011-06-24 13:06:29 -070053 handlePreload(context, intent);
54 }
55 }
56
Mathew Inwood467813f2011-09-02 15:43:17 +010057 private boolean isPreloadEnabledOnCurrentNetwork(Context context) {
58 String preload = BrowserSettings.getInstance().getPreloadEnabled();
59 if (LOGD_ENABLED) Log.d(LOGTAG, "Preload setting: " + preload);
60 if (BrowserSettings.getPreloadAlwaysPreferenceString(context).equals(preload)) {
61 return true;
62 } else if (BrowserSettings.getPreloadOnWifiOnlyPreferenceString(context).equals(preload)) {
63 boolean onWifi = isOnWifi(context);
64 if (LOGD_ENABLED) Log.d(LOGTAG, "on wifi:" + onWifi);
65 return onWifi;
66 } else {
67 return false;
68 }
69 }
70
71 private boolean isOnWifi(Context context) {
72 if (mConnectivityManager == null) {
73 mConnectivityManager = (ConnectivityManager)
74 context.getSystemService(Context.CONNECTIVITY_SERVICE);
75 }
76 NetworkInfo ni = mConnectivityManager.getActiveNetworkInfo();
77 if (ni == null) {
78 return false;
79 }
80 switch (ni.getType()) {
81 case ConnectivityManager.TYPE_MOBILE:
82 case ConnectivityManager.TYPE_MOBILE_DUN:
83 case ConnectivityManager.TYPE_MOBILE_MMS:
84 case ConnectivityManager.TYPE_MOBILE_SUPL:
85 case ConnectivityManager.TYPE_MOBILE_HIPRI:
86 case ConnectivityManager.TYPE_WIMAX: // separate case for this?
87 return false;
88 case ConnectivityManager.TYPE_WIFI:
89 case ConnectivityManager.TYPE_ETHERNET:
90 case ConnectivityManager.TYPE_BLUETOOTH:
91 return true;
92 default:
93 return false;
94 }
95 }
96
Michael Kolb14612442011-06-24 13:06:29 -070097 private void handlePreload(Context context, Intent i) {
98 String url = UrlUtils.smartUrlFilter(i.getData());
99 String id = i.getStringExtra(EXTRA_PRELOAD_ID);
100 Map<String, String> headers = null;
101 if (id == null) {
102 if (LOGD_ENABLED) Log.d(LOGTAG, "Preload request has no " + EXTRA_PRELOAD_ID);
103 return;
104 }
105 if (i.getBooleanExtra(EXTRA_PRELOAD_DISCARD, false)) {
106 if (LOGD_ENABLED) Log.d(LOGTAG, "Got " + id + " preload discard request");
107 Preloader.getInstance().discardPreload(id);
Mathew Inwooddffa72f2011-08-10 12:37:43 +0100108 } else if (i.getBooleanExtra(EXTRA_SEARCHBOX_CANCEL, false)) {
109 if (LOGD_ENABLED) Log.d(LOGTAG, "Got " + id + " searchbox cancel request");
110 Preloader.getInstance().cancelSearchBoxPreload(id);
Michael Kolb14612442011-06-24 13:06:29 -0700111 } else {
112 if (LOGD_ENABLED) Log.d(LOGTAG, "Got " + id + " preload request for " + url);
113 if (url != null && url.startsWith("http")) {
114 final Bundle pairs = i.getBundleExtra(Browser.EXTRA_HEADERS);
115 if (pairs != null && !pairs.isEmpty()) {
116 Iterator<String> iter = pairs.keySet().iterator();
117 headers = new HashMap<String, String>();
118 while (iter.hasNext()) {
119 String key = iter.next();
120 headers.put(key, pairs.getString(key));
121 }
122 }
123 }
Mathew Inwood29721c22011-06-29 17:55:24 +0100124 String sbQuery = i.getStringExtra(EXTRA_SEARCHBOX_SETQUERY);
Michael Kolb14612442011-06-24 13:06:29 -0700125 if (url != null) {
Mathew Inwood29721c22011-06-29 17:55:24 +0100126 if (LOGD_ENABLED){
127 Log.d(LOGTAG, "Preload request(" + id + ", " + url + ", " +
128 headers + ", " + sbQuery + ")");
129 }
130 Preloader.getInstance().handlePreloadRequest(id, url, headers, sbQuery);
Michael Kolb14612442011-06-24 13:06:29 -0700131 }
132 }
133 }
134
135}