| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-present eyeo GmbH | 3 * Copyright (C) 2006-present eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 12 * GNU General Public License for more details. | 12 * GNU General Public License for more details. |
| 13 * | 13 * |
| 14 * You should have received a copy of the GNU General Public License | 14 * You should have received a copy of the GNU General Public License |
| 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. | 15 * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
| 16 */ | 16 */ |
| 17 | 17 |
| 18 package org.adblockplus.sbrowser.contentblocker; | 18 package org.adblockplus.sbrowser.contentblocker; |
| 19 | 19 |
| 20 import java.io.IOException; | |
| 20 import java.util.Collections; | 21 import java.util.Collections; |
| 21 import java.util.HashMap; | 22 import java.util.Comparator; |
| 22 import java.util.List; | 23 import java.util.List; |
| 23 | 24 |
| 24 import org.adblockplus.sbrowser.contentblocker.engine.DefaultSubscriptionInfo; | |
| 25 import org.adblockplus.sbrowser.contentblocker.engine.Engine; | 25 import org.adblockplus.sbrowser.contentblocker.engine.Engine; |
| 26 import org.adblockplus.sbrowser.contentblocker.engine.EngineService; | 26 import org.adblockplus.sbrowser.contentblocker.engine.EngineService; |
| 27 import org.adblockplus.sbrowser.contentblocker.engine.SubscriptionInfo; | 27 import org.adblockplus.sbrowser.contentblocker.engine.SubscriptionInfo; |
| 28 import org.adblockplus.adblockplussbrowser.R; | 28 import org.adblockplus.adblockplussbrowser.R; |
| 29 import org.adblockplus.sbrowser.contentblocker.preferences.MultilineCheckBoxPref erence; | 29 import org.adblockplus.sbrowser.contentblocker.preferences.MultilineCheckBoxPref erence; |
| 30 | 30 |
| 31 import android.content.Context; | 31 import android.content.Context; |
| 32 import android.preference.Preference; | 32 import android.preference.Preference; |
| 33 import android.preference.PreferenceCategory; | 33 import android.preference.PreferenceCategory; |
| 34 import android.preference.Preference.OnPreferenceChangeListener; | 34 import android.preference.Preference.OnPreferenceChangeListener; |
| 35 import android.text.format.DateUtils; | 35 import android.text.format.DateUtils; |
| 36 import android.util.AttributeSet; | 36 import android.util.AttributeSet; |
| 37 import android.util.Log; | |
| 38 | |
| 39 import static org.adblockplus.sbrowser.contentblocker.engine.Engine.URL_TO_RES_I D_MAP; | |
| 37 | 40 |
| 38 public class MoreBlockingPreferenceCategory extends PreferenceCategory implement s | 41 public class MoreBlockingPreferenceCategory extends PreferenceCategory implement s |
| 39 EngineService.OnEngineCreatedCallback, OnPreferenceChangeListener | 42 EngineService.OnEngineCreatedCallback, OnPreferenceChangeListener, Engine.Su bscriptionAddedCallback |
| 40 { | 43 { |
| 41 private Engine engine = null; | 44 private Engine engine = null; |
| 42 private static final int[] WHITELISTED_LIST_TITLES = | 45 private static final int[] WHITELISTED_LIST_TITLES = |
| 43 { | 46 { |
| 44 R.string.subscription_disable_tracking, | 47 R.string.subscription_disable_tracking, |
| 45 R.string.subscription_disable_malware, | 48 R.string.subscription_disable_malware, |
| 46 R.string.subscription_disable_anti_adblock, | 49 R.string.subscription_disable_anti_adblock, |
| 47 R.string.subscription_disable_social_media | 50 R.string.subscription_disable_social_media |
| 48 }; | 51 }; |
| 49 | 52 |
| 50 private static final String[] WHITELISTED_LIST_URLS = | 53 private static final String[] WHITELISTED_LIST_URLS = |
| 51 { | 54 { |
| 52 "https://easylist-downloads.adblockplus.org/easyprivacy.txt", | 55 "https://easylist-downloads.adblockplus.org/easyprivacy.txt", |
| 53 "https://easylist-downloads.adblockplus.org/malwaredomains_full.txt", | 56 "https://easylist-downloads.adblockplus.org/malwaredomains_full.txt", |
| 54 "https://easylist-downloads.adblockplus.org/antiadblockfilters.txt", | 57 "https://easylist-downloads.adblockplus.org/antiadblockfilters.txt", |
| 55 "https://easylist-downloads.adblockplus.org/fanboy-social.txt" | 58 "https://easylist-downloads.adblockplus.org/fanboy-social.txt" |
| 56 }; | 59 }; |
| 57 | 60 |
| 58 private static final HashMap<String, Integer> URL_TO_RES_ID_MAP = new HashMap< >(); | |
| 59 | |
| 60 static | 61 static |
| 61 { | 62 { |
| 62 for (int i = 0; i < WHITELISTED_LIST_TITLES.length; i++) | 63 for (int i = 0; i < WHITELISTED_LIST_TITLES.length; i++) |
| 63 { | 64 { |
| 64 URL_TO_RES_ID_MAP.put(WHITELISTED_LIST_URLS[i], WHITELISTED_LIST_TITLES[i] ); | 65 URL_TO_RES_ID_MAP.put(WHITELISTED_LIST_URLS[i], WHITELISTED_LIST_TITLES[i] ); |
| 65 } | 66 } |
| 66 } | 67 } |
| 67 | 68 |
| 68 public MoreBlockingPreferenceCategory(final Context context) | 69 public MoreBlockingPreferenceCategory(final Context context) |
| 69 { | 70 { |
| 70 super(context); | 71 super(context); |
| 71 } | 72 } |
| 72 | 73 |
| 73 public MoreBlockingPreferenceCategory(final Context context, final AttributeSe t attrs) | 74 public MoreBlockingPreferenceCategory(final Context context, final AttributeSe t attrs) |
| 74 { | 75 { |
| 75 super(context, attrs); | 76 super(context, attrs); |
| 76 } | 77 } |
| 77 | 78 |
| 78 @Override | 79 @Override |
| 79 protected void onAttachedToActivity() | 80 protected void onAttachedToActivity() |
| 80 { | 81 { |
| 81 EngineService.startService(this.getContext().getApplicationContext(), this); | 82 EngineService.startService(this.getContext().getApplicationContext(), this); |
| 82 super.onAttachedToActivity(); | 83 super.onAttachedToActivity(); |
| 83 } | 84 } |
| 84 | 85 |
| 85 @Override | 86 @Override |
| 86 public void onEngineCreated(final Engine engine, final boolean success) | 87 public void onEngineCreated(final Engine engine, final boolean success) |
| 87 { | 88 { |
| 88 this.engine = engine; | 89 this.engine = engine; |
| 89 final String aaLink = engine.getPrefsDefault(Engine.SUBSCRIPTIONS_EXCEPTIONS URL); | |
| 90 | 90 |
| 91 if (success) | 91 if (success) |
| 92 { | 92 { |
| 93 final List<SubscriptionInfo> subs = engine.getListedSubscriptions(); | 93 initialize(); |
| 94 Collections.sort(subs); | 94 } |
| 95 this.removeAll(); | 95 } |
| 96 | 96 |
| 97 for (final SubscriptionInfo sub : subs) | 97 private void initialize() |
| 98 { | |
| 99 final List<SubscriptionInfo> subs = engine.getMoreBlockingPreferenceSubscrip tions(); | |
| 100 sortSubscriptionsByRelevance(subs); | |
| 101 this.removeAll(); | |
| 102 | |
| 103 for (final SubscriptionInfo sub : subs) | |
| 104 { | |
| 105 Integer resInt = URL_TO_RES_ID_MAP.get(sub.getUrl()); | |
| 106 final MultilineCheckBoxPreference cbp = new MultilineCheckBoxPreference(th is.getContext()); | |
| 107 | |
| 108 if (sub.isEnabled()) | |
| 98 { | 109 { |
| 99 final DefaultSubscriptionInfo info = engine.getDefaultSubscriptionInfoFo rUrl(sub.getUrl()); | 110 final StringBuilder sb = new StringBuilder(); |
| 100 | 111 sb.append(this.getContext().getString(R.string.last_update)); |
| 101 Integer resInt = URL_TO_RES_ID_MAP.get(sub.getUrl()); | 112 sb.append(' '); |
| 102 if (!(aaLink.equals(sub.getUrl()) || sub.getTitle().startsWith("__")) | 113 final long timestamp = sub.getLastUpdateTime(); |
| 103 && resInt != null | 114 if (timestamp > 0) |
| 104 && (info == null || info.getPrefixes().isEmpty() || sub.getType() != SubscriptionInfo.Type.ADS)) | |
| 105 { | 115 { |
| 106 | 116 sb.append(DateUtils.formatDateTime(this.getContext(), timestamp, |
| 107 final MultilineCheckBoxPreference cbp = new MultilineCheckBoxPreferenc e(this.getContext()); | 117 DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_SHOW_TIME)); |
| 108 | 118 } |
| 109 if (sub.isEnabled()) | 119 else |
| 110 { | 120 { |
| 111 final StringBuilder sb = new StringBuilder(); | 121 sb.append(this.getContext().getString(R.string.last_update_never)); |
| 112 sb.append(this.getContext().getString(R.string.last_update)); | 122 } |
| 113 sb.append(' '); | 123 cbp.setSummary(sb.toString()); |
| 114 final long timestamp = sub.getLastUpdateTime(); | 124 } |
| 115 if (timestamp > 0) | 125 else |
| 116 { | 126 { |
| 117 sb.append(DateUtils.formatDateTime(this.getContext(), timestamp, | 127 if (sub.getType() == SubscriptionInfo.Type.CUSTOM) |
| 118 DateUtils.FORMAT_SHOW_DATE | DateUtils.FORMAT_SHOW_TIME)); | 128 { |
| 119 } | 129 engine.removeSubscriptionById(sub.getId()); |
| 120 else | 130 continue; |
| 121 { | |
| 122 sb.append(this.getContext().getString(R.string.last_update_never)) ; | |
| 123 } | |
| 124 cbp.setSummary(sb.toString()); | |
| 125 } | |
| 126 | |
| 127 cbp.setTitle(this.getContext().getString(resInt)); | |
| 128 cbp.setChecked(sub.isEnabled()); | |
| 129 cbp.setPersistent(false); | |
| 130 cbp.setKey(sub.getId()); | |
| 131 cbp.setOnPreferenceChangeListener(this); | |
| 132 this.addPreference(cbp); | |
| 133 } | 131 } |
| 134 } | 132 } |
| 133 | |
| 134 cbp.setTitle(resInt == null ? sub.getTitle() : getContext().getString(resI nt)); | |
| 135 cbp.setChecked(sub.isEnabled()); | |
| 136 cbp.setPersistent(false); | |
| 137 cbp.setKey(sub.getId()); | |
| 138 cbp.setOnPreferenceChangeListener(this); | |
| 139 this.addPreference(cbp); | |
| 135 } | 140 } |
| 141 | |
| 142 final InputValidatorDialogPreference urlPreference = new InputValidatorDialo gPreference( | |
| 143 this.getContext(), InputValidatorDialogPreference.ValidationType.URL); | |
| 144 urlPreference.setTitle(R.string.add_other_list); | |
| 145 urlPreference.setDialogTitle(R.string.add_other_list); | |
| 146 urlPreference.getEditText().setHint(R.string.add_other_list_url_hint); | |
| 147 urlPreference.setOnInputReadyListener(new InputValidatorDialogPreference.OnI nputReadyListener() | |
| 148 { | |
| 149 @Override | |
| 150 public void onInputReady(String url) | |
| 151 { | |
| 152 if (!url.toLowerCase().startsWith("http://") && !url.toLowerCase().start sWith("https://")) | |
| 153 { | |
| 154 url = "http://" + url; | |
| 155 } | |
| 156 | |
| 157 try | |
| 158 { | |
| 159 engine.createAndAddSubscriptionFromUrl(url, MoreBlockingPreferenceCate gory.this); | |
| 160 } | |
| 161 catch (IOException e) | |
| 162 { | |
| 163 Log.e(getClass().getSimpleName(), "Unable to add subscription from url ", e); | |
| 164 } | |
| 165 } | |
| 166 }); | |
| 167 this.addPreference(urlPreference); | |
| 168 } | |
| 169 | |
| 170 private void sortSubscriptionsByRelevance(final List<SubscriptionInfo> moreBlo ckingPreferenceSubscriptions) | |
| 171 { | |
| 172 Collections.sort(moreBlockingPreferenceSubscriptions, new Comparator<Subscri ptionInfo>() | |
| 173 { | |
| 174 @Override | |
| 175 public int compare(SubscriptionInfo o1, SubscriptionInfo o2) | |
| 176 { | |
| 177 if (URL_TO_RES_ID_MAP.containsKey(o1.getUrl()) && URL_TO_RES_ID_MAP.cont ainsKey(o2.getUrl())) | |
| 178 { | |
| 179 return o1.getTitle().compareTo(o2.getTitle()); | |
| 180 } | |
| 181 | |
| 182 if (URL_TO_RES_ID_MAP.containsKey(o1.getUrl()) && !URL_TO_RES_ID_MAP.con tainsKey(o2.getUrl())) | |
| 183 { | |
| 184 return -1; | |
| 185 } | |
| 186 | |
| 187 if (!URL_TO_RES_ID_MAP.containsKey(o1.getUrl()) && URL_TO_RES_ID_MAP.con tainsKey(o2.getUrl())) | |
| 188 { | |
| 189 return 1; | |
| 190 } | |
| 191 | |
| 192 return 0; | |
| 193 } | |
| 194 }); | |
| 136 } | 195 } |
| 137 | 196 |
| 138 @Override | 197 @Override |
| 139 public boolean onPreferenceChange(final Preference preference, final Object ne wValue) | 198 public boolean onPreferenceChange(final Preference preference, final Object ne wValue) |
| 140 { | 199 { |
| 141 final String id = preference.getKey(); | 200 final String id = preference.getKey(); |
| 142 final boolean enabled = (Boolean) newValue; | 201 final boolean enabled = (Boolean) newValue; |
| 143 | 202 |
| 144 this.engine.changeSubscriptionState(id, enabled); | 203 this.engine.changeSubscriptionState(id, enabled); |
| 145 | 204 |
| 146 return true; | 205 return true; |
| 147 } | 206 } |
| 207 | |
| 208 @Override | |
| 209 public void subscriptionAdded() | |
| 210 { | |
| 211 initialize(); | |
|
diegocarloslima
2017/09/22 17:43:42
Maybe we should change the name of this method to
jens
2017/09/26 10:25:01
Acknowledged.
| |
| 212 } | |
| 148 } | 213 } |
| OLD | NEW |