Add-option-to-configure-the-ad-blocker-filters-URL.patch 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531
  1. From: csagan5 <32685696+csagan5@users.noreply.github.com>
  2. Date: Thu, 5 Dec 2019 22:41:25 +0100
  3. Subject: Add option to configure the ad blocker filters URL
  4. ---
  5. chrome/android/chrome_java_resources.gni | 2 +
  6. chrome/android/chrome_java_sources.gni | 2 +
  7. .../java/res/layout/adblock_editor.xml | 65 +++++++++++++
  8. chrome/android/java/res/values/values.xml | 2 +
  9. .../java/res/xml/adblock_preferences.xml | 25 +++++
  10. .../android/java/res/xml/main_preferences.xml | 5 +
  11. .../browser/settings/AdBlockEditor.java | 92 +++++++++++++++++++
  12. .../browser/settings/AdBlockPreferences.java | 61 ++++++++++++
  13. chrome/app/generated_resources.grd | 10 ++
  14. chrome/browser/browser_process_impl.cc | 3 +-
  15. .../flags/android/cached_feature_flags.cc | 8 ++
  16. .../browser/flags/CachedFeatureFlags.java | 10 ++
  17. .../net/system_network_context_manager.cc | 4 +
  18. .../strings/android_chrome_strings.grd | 14 +++
  19. chrome/common/pref_names.cc | 3 +
  20. chrome/common/pref_names.h | 1 +
  21. .../adblock_updater_service.cc | 6 +-
  22. .../adblock_updater_service.h | 3 +-
  23. 18 files changed, 311 insertions(+), 5 deletions(-)
  24. create mode 100644 chrome/android/java/res/layout/adblock_editor.xml
  25. create mode 100644 chrome/android/java/res/xml/adblock_preferences.xml
  26. create mode 100644 chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockEditor.java
  27. create mode 100644 chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockPreferences.java
  28. diff --git a/chrome/android/chrome_java_resources.gni b/chrome/android/chrome_java_resources.gni
  29. --- a/chrome/android/chrome_java_resources.gni
  30. +++ b/chrome/android/chrome_java_resources.gni
  31. @@ -885,6 +885,7 @@ chrome_java_resources = [
  32. "java/res/layout/account_picker_new_account_row_legacy.xml",
  33. "java/res/layout/account_picker_row.xml",
  34. "java/res/layout/account_picker_row_legacy.xml",
  35. + "java/res/layout/adblock_editor.xml",
  36. "java/res/layout/add_languages_main.xml",
  37. "java/res/layout/add_to_homescreen_dialog.xml",
  38. "java/res/layout/auto_sign_in_first_run_dialog.xml",
  39. @@ -1175,6 +1176,7 @@ chrome_java_resources = [
  40. "java/res/xml/about_chrome_preferences.xml",
  41. "java/res/xml/accessibility_preferences.xml",
  42. "java/res/xml/account_management_preferences.xml",
  43. + "java/res/xml/adblock_preferences.xml",
  44. "java/res/xml/autofill_server_profile_preferences.xml",
  45. "java/res/xml/bookmark_widget_info.xml",
  46. "java/res/xml/clear_browsing_data_preferences_tab.xml",
  47. diff --git a/chrome/android/chrome_java_sources.gni b/chrome/android/chrome_java_sources.gni
  48. --- a/chrome/android/chrome_java_sources.gni
  49. +++ b/chrome/android/chrome_java_sources.gni
  50. @@ -1321,6 +1321,8 @@ chrome_java_sources = [
  51. "java/src/org/chromium/chrome/browser/photo_picker/DecodeVideoTask.java",
  52. "java/src/org/chromium/chrome/browser/photo_picker/DecoderService.java",
  53. "java/src/org/chromium/chrome/browser/photo_picker/DecoderServiceHost.java",
  54. + "java/src/org/chromium/chrome/browser/settings/AdBlockEditor.java",
  55. + "java/src/org/chromium/chrome/browser/settings/AdBlockPreferences.java",
  56. "java/src/org/chromium/chrome/browser/photo_picker/FileEnumWorkerTask.java",
  57. "java/src/org/chromium/chrome/browser/photo_picker/PhotoPickerDialog.java",
  58. "java/src/org/chromium/chrome/browser/photo_picker/PhotoPickerToolbar.java",
  59. diff --git a/chrome/android/java/res/layout/adblock_editor.xml b/chrome/android/java/res/layout/adblock_editor.xml
  60. new file mode 100644
  61. --- /dev/null
  62. +++ b/chrome/android/java/res/layout/adblock_editor.xml
  63. @@ -0,0 +1,65 @@
  64. +<?xml version="1.0" encoding="utf-8"?>
  65. +<!-- Copyright 2015 The Chromium Authors. All rights reserved.
  66. + Use of this source code is governed by a BSD-style license that can be
  67. + found in the LICENSE file. -->
  68. +
  69. +<FrameLayout
  70. + xmlns:android="http://schemas.android.com/apk/res/android"
  71. + xmlns:app="http://schemas.android.com/apk/res-auto"
  72. + xmlns:tools="http://schemas.android.com/tools"
  73. + android:layout_width="match_parent"
  74. + android:layout_height="match_parent" >
  75. +
  76. + <ScrollView
  77. + android:layout_width="match_parent"
  78. + android:layout_height="match_parent"
  79. + android:id="@+id/scroll_view"
  80. + android:fillViewport="true" >
  81. +
  82. + <LinearLayout
  83. + android:layout_width="match_parent"
  84. + android:layout_height="wrap_content"
  85. + android:orientation="vertical"
  86. + android:focusableInTouchMode="true" >
  87. +
  88. + <com.google.android.material.textfield.TextInputLayout
  89. + android:id="@+id/adblock_url"
  90. + style="@style/PreferenceScreenLayout"
  91. + android:layout_width="match_parent"
  92. + android:layout_height="wrap_content" >
  93. + <!-- TODO(crbug.com/900912): Fix and remove lint ignore -->
  94. + <EditText
  95. + tools:ignore="Autofill"
  96. + android:id="@+id/adblock_url_edit"
  97. + android:layout_width="match_parent"
  98. + android:layout_height="wrap_content"
  99. + android:inputType="textUri"
  100. + android:singleLine="true"
  101. + android:hint="@string/options_adblock_edit_label" />
  102. + </com.google.android.material.textfield.TextInputLayout>
  103. +
  104. + <Space style="@style/ButtonBarTopSpacer" />
  105. + <View style="@style/ButtonBarTopDivider" />
  106. +
  107. + <LinearLayout style="@style/ButtonBar" >
  108. + <org.chromium.ui.widget.ButtonCompat
  109. + android:id="@+id/adblock_reset"
  110. + style="@style/ButtonBarButton"
  111. + android:text="@string/reset" />
  112. +
  113. + <org.chromium.ui.widget.ButtonCompat
  114. + android:id="@+id/adblock_cancel"
  115. + style="@style/ButtonBarButton"
  116. + android:text="@string/cancel" />
  117. +
  118. + <org.chromium.ui.widget.ButtonCompat
  119. + android:id="@+id/adblock_save"
  120. + style="@style/ButtonBarButton"
  121. + android:text="@string/save" />
  122. + </LinearLayout>
  123. + </LinearLayout>
  124. + </ScrollView>
  125. +
  126. + <include layout="@layout/settings_action_bar_shadow"/>
  127. +
  128. +</FrameLayout>
  129. diff --git a/chrome/android/java/res/values/values.xml b/chrome/android/java/res/values/values.xml
  130. --- a/chrome/android/java/res/values/values.xml
  131. +++ b/chrome/android/java/res/values/values.xml
  132. @@ -66,6 +66,8 @@
  133. <!-- Our manage space activity. Default pre-KitKat to be nothing. -->
  134. <string name="manage_space_activity"></string>
  135. + <string name="adblock_help_url">https://www.bromite.org/custom-filters</string>
  136. +
  137. <string name="proxy_title">Proxy configuration</string>
  138. <string name="proxy_url">chrome://proxy</string>
  139. diff --git a/chrome/android/java/res/xml/adblock_preferences.xml b/chrome/android/java/res/xml/adblock_preferences.xml
  140. new file mode 100644
  141. --- /dev/null
  142. +++ b/chrome/android/java/res/xml/adblock_preferences.xml
  143. @@ -0,0 +1,25 @@
  144. +<?xml version="1.0" encoding="utf-8"?>
  145. +<!-- Copyright 2015 The Chromium Authors. All rights reserved.
  146. + Use of this source code is governed by a BSD-style license that can be
  147. + found in the LICENSE file. -->
  148. +
  149. +<PreferenceScreen
  150. + xmlns:android="http://schemas.android.com/apk/res/android"
  151. + xmlns:app="http://schemas.android.com/apk/res-auto">
  152. +
  153. + <org.chromium.components.browser_ui.settings.ChromeSwitchPreference
  154. + android:key="adblock_switch"
  155. + android:summaryOn="@string/text_on"
  156. + android:summaryOff="@string/text_off" />
  157. +
  158. + <org.chromium.chrome.browser.settings.HyperlinkPreference
  159. + android:key="adblock_help"
  160. + android:title="@string/adblock_help"
  161. + app:url="@string/adblock_help_url" />
  162. +
  163. + <Preference
  164. + android:key="adblock_edit"
  165. + android:title="@string/options_adblock_edit_label"
  166. + android:fragment="org.chromium.chrome.browser.settings.AdBlockEditor" />
  167. +
  168. +</PreferenceScreen>
  169. diff --git a/chrome/android/java/res/xml/main_preferences.xml b/chrome/android/java/res/xml/main_preferences.xml
  170. --- a/chrome/android/java/res/xml/main_preferences.xml
  171. +++ b/chrome/android/java/res/xml/main_preferences.xml
  172. @@ -55,6 +55,11 @@
  173. android:key="privacy"
  174. android:order="12"
  175. android:title="@string/prefs_privacy"/>
  176. + <Preference
  177. + android:fragment="org.chromium.chrome.browser.settings.AdBlockPreferences"
  178. + android:key="adblock"
  179. + android:order="13"
  180. + android:title="@string/prefs_adblock"/>
  181. <Preference
  182. android:fragment="org.chromium.chrome.browser.accessibility.settings.AccessibilitySettings"
  183. android:key="accessibility"
  184. diff --git a/chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockEditor.java b/chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockEditor.java
  185. new file mode 100644
  186. --- /dev/null
  187. +++ b/chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockEditor.java
  188. @@ -0,0 +1,92 @@
  189. +// Copyright 2015 The Chromium Authors. All rights reserved.
  190. +// Use of this source code is governed by a BSD-style license that can be
  191. +// found in the LICENSE file.
  192. +
  193. +package org.chromium.chrome.browser.settings;
  194. +
  195. +import android.os.Bundle;
  196. +import androidx.fragment.app.Fragment;
  197. +import android.text.Editable;
  198. +import android.text.TextWatcher;
  199. +import android.view.LayoutInflater;
  200. +import android.view.View;
  201. +import android.view.ViewGroup;
  202. +import android.widget.Button;
  203. +import android.widget.EditText;
  204. +
  205. +import org.chromium.components.browser_ui.settings.SettingsUtils;
  206. +import org.chromium.chrome.browser.flags.CachedFeatureFlags;
  207. +import org.chromium.chrome.R;
  208. +import org.chromium.components.url_formatter.UrlFormatter;
  209. +
  210. +/**
  211. + * Provides the Java-UI for editing AdBlock preferences.
  212. + */
  213. +public class AdBlockEditor extends Fragment implements TextWatcher {
  214. + private EditText mAdBlockFiltersUrlEdit;
  215. + private Button mSaveButton;
  216. + private Button mResetButton;
  217. +
  218. + @Override
  219. + public View onCreateView(LayoutInflater inflater, ViewGroup container,
  220. + Bundle savedInstanceState) {
  221. + super.onCreate(savedInstanceState);
  222. + getActivity().setTitle(R.string.options_adblock_edit_title);
  223. +
  224. + View v = inflater.inflate(R.layout.adblock_editor, container, false);
  225. + View scrollView = v.findViewById(R.id.scroll_view);
  226. + scrollView.getViewTreeObserver().addOnScrollChangedListener(
  227. + SettingsUtils.getShowShadowOnScrollListener(v, v.findViewById(R.id.shadow)));
  228. + mAdBlockFiltersUrlEdit = (EditText) v.findViewById(R.id.adblock_url_edit);
  229. + mAdBlockFiltersUrlEdit.setText(CachedFeatureFlags.getAdBlockFiltersURL());
  230. + mAdBlockFiltersUrlEdit.addTextChangedListener(this);
  231. + mAdBlockFiltersUrlEdit.requestFocus();
  232. +
  233. + initializeSaveCancelResetButtons(v);
  234. + return v;
  235. + }
  236. +
  237. + @Override
  238. + public void beforeTextChanged(CharSequence s, int start, int count, int after) {
  239. + }
  240. +
  241. + @Override
  242. + public void onTextChanged(CharSequence s, int start, int before, int count) {
  243. + mSaveButton.setEnabled(s.length() != 0);
  244. + mResetButton.setEnabled(true);
  245. + }
  246. +
  247. + @Override
  248. + public void afterTextChanged(Editable s) {
  249. + }
  250. +
  251. + private void initializeSaveCancelResetButtons(View v) {
  252. + mResetButton = (Button) v.findViewById(R.id.adblock_reset);
  253. + mResetButton.setOnClickListener(new View.OnClickListener() {
  254. + @Override
  255. + public void onClick(View v) {
  256. + mAdBlockFiltersUrlEdit.setText(CachedFeatureFlags.getAdBlockFiltersURL());
  257. + getActivity().finish();
  258. + }
  259. + });
  260. +
  261. + mSaveButton = (Button) v.findViewById(R.id.adblock_save);
  262. + mSaveButton.setEnabled(false);
  263. + mSaveButton.setOnClickListener(new View.OnClickListener() {
  264. + @Override
  265. + public void onClick(View v) {
  266. + CachedFeatureFlags.setAdBlockFiltersURL(
  267. + UrlFormatter.fixupUrl(mAdBlockFiltersUrlEdit.getText().toString()).getSpec());
  268. + getActivity().finish();
  269. + }
  270. + });
  271. +
  272. + Button button = (Button) v.findViewById(R.id.adblock_cancel);
  273. + button.setOnClickListener(new View.OnClickListener() {
  274. + @Override
  275. + public void onClick(View v) {
  276. + getActivity().finish();
  277. + }
  278. + });
  279. + }
  280. +}
  281. diff --git a/chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockPreferences.java b/chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockPreferences.java
  282. new file mode 100644
  283. --- /dev/null
  284. +++ b/chrome/android/java/src/org/chromium/chrome/browser/settings/AdBlockPreferences.java
  285. @@ -0,0 +1,61 @@
  286. +// Copyright 2015 The Chromium Authors. All rights reserved.
  287. +// Use of this source code is governed by a BSD-style license that can be
  288. +// found in the LICENSE file.
  289. +
  290. +package org.chromium.chrome.browser.settings;
  291. +
  292. +import android.os.Bundle;
  293. +import androidx.preference.Preference;
  294. +import androidx.preference.PreferenceFragmentCompat;
  295. +import org.chromium.components.browser_ui.settings.ChromeSwitchPreference;
  296. +
  297. +import org.chromium.components.embedder_support.browser_context.BrowserContextHandle;
  298. +import org.chromium.components.browser_ui.site_settings.SiteSettingsPreferenceFragment;
  299. +import org.chromium.components.browser_ui.site_settings.WebsitePreferenceBridge;
  300. +import org.chromium.components.content_settings.ContentSettingsType;
  301. +import org.chromium.components.browser_ui.settings.SettingsUtils;
  302. +import org.chromium.chrome.browser.flags.CachedFeatureFlags;
  303. +import androidx.annotation.VisibleForTesting;
  304. +import org.chromium.chrome.R;
  305. +
  306. +/**
  307. + * Fragment that allows the user to configure AdBlock related preferences.
  308. + */
  309. +public class AdBlockPreferences extends SiteSettingsPreferenceFragment {
  310. + @VisibleForTesting
  311. + public static final String PREF_ADBLOCK_SWITCH = "adblock_switch";
  312. + private static final String PREF_ADBLOCK_EDIT = "adblock_edit";
  313. +
  314. + private Preference mAdBlockEdit;
  315. +
  316. + @Override
  317. + public void onCreatePreferences(Bundle savedInstanceState, String rootKey) {
  318. + getActivity().setTitle(R.string.options_adblock_title);
  319. + SettingsUtils.addPreferencesFromResource(this, R.xml.adblock_preferences);
  320. +
  321. + BrowserContextHandle browserContextHandle =
  322. + getSiteSettingsClient().getBrowserContextHandle();
  323. +
  324. + ChromeSwitchPreference mAdBlockSwitch =
  325. + (ChromeSwitchPreference) findPreference(PREF_ADBLOCK_SWITCH);
  326. + boolean isAdBlockEnabled = !WebsitePreferenceBridge.isCategoryEnabled(browserContextHandle, ContentSettingsType.ADS);
  327. + mAdBlockSwitch.setChecked(isAdBlockEnabled);
  328. + mAdBlockSwitch.setOnPreferenceChangeListener((preference, newValue) -> {
  329. + WebsitePreferenceBridge.setCategoryEnabled(browserContextHandle, ContentSettingsType.ADS, !(boolean) newValue);
  330. + return true;
  331. + });
  332. +
  333. + mAdBlockEdit = findPreference(PREF_ADBLOCK_EDIT);
  334. + updateCurrentAdBlockUrl();
  335. + }
  336. +
  337. + private void updateCurrentAdBlockUrl() {
  338. + mAdBlockEdit.setSummary(CachedFeatureFlags.getAdBlockFiltersURL());
  339. + }
  340. +
  341. + @Override
  342. + public void onResume() {
  343. + super.onResume();
  344. + updateCurrentAdBlockUrl();
  345. + }
  346. +}
  347. diff --git a/chrome/app/generated_resources.grd b/chrome/app/generated_resources.grd
  348. --- a/chrome/app/generated_resources.grd
  349. +++ b/chrome/app/generated_resources.grd
  350. @@ -9806,6 +9806,16 @@ Please help our engineers fix this problem. Tell us what happened right before y
  351. Never show this again.
  352. </message>
  353. + <!-- Ad Blocking preferences -->
  354. + <if expr="is_android">
  355. + <message name="IDS_OPTIONS_ADBLOCK_TITLE" desc="The title of the Ad Blocking option on Android" formatter_data="android_java">
  356. + Ad Blocking
  357. + </message>
  358. + <message name="IDS_OPTIONS_ADBLOCK_SUMMARY" desc="The title of the Ad Blocking summary on Android" formatter_data="android_java">
  359. + Configure Ad Blocking and filters URL
  360. + </message>
  361. + </if>
  362. +
  363. <!-- Ad Blocking UI strings. -->
  364. <message name="IDS_ALWAYS_ALLOW_ADS" desc="Explanation associated with a toggle to allow ads after ads have been blocked on the page. To be used on pages where the ad blocking UI is governed by a persistent permissions-based whitelist.">
  365. Always allow ads on this site
  366. diff --git a/chrome/browser/browser_process_impl.cc b/chrome/browser/browser_process_impl.cc
  367. --- a/chrome/browser/browser_process_impl.cc
  368. +++ b/chrome/browser/browser_process_impl.cc
  369. @@ -1066,7 +1066,8 @@ BrowserProcessImpl::adblock_updater() {
  370. adblock_updater_ = std::make_unique<adblock_updater::AdBlockUpdaterService>(
  371. g_browser_process->system_network_context_manager()->GetSharedURLLoaderFactory(),
  372. std::move(scheduler),
  373. - g_browser_process->subresource_filter_ruleset_service());
  374. + g_browser_process->subresource_filter_ruleset_service(),
  375. + local_state()->GetString(prefs::kAdBlockFiltersURL));
  376. return adblock_updater_.get();
  377. }
  378. diff --git a/chrome/browser/flags/android/cached_feature_flags.cc b/chrome/browser/flags/android/cached_feature_flags.cc
  379. --- a/chrome/browser/flags/android/cached_feature_flags.cc
  380. +++ b/chrome/browser/flags/android/cached_feature_flags.cc
  381. @@ -36,6 +36,14 @@ std::string GetReachedCodeProfilerTrialGroup() {
  382. } // namespace android
  383. } // namespace chrome
  384. +static ScopedJavaLocalRef<jstring> JNI_CachedFeatureFlags_GetAdBlockFiltersURL(JNIEnv* env) {
  385. + return base::android::ConvertUTF8ToJavaString(env, g_browser_process->local_state()->GetString(prefs::kAdBlockFiltersURL));
  386. +}
  387. +
  388. +static void JNI_CachedFeatureFlags_SetAdBlockFiltersURL(JNIEnv* env, const JavaParamRef<jstring>& url) {
  389. + g_browser_process->local_state()->SetString(prefs::kAdBlockFiltersURL, base::android::ConvertJavaStringToUTF8(env, url));
  390. +}
  391. +
  392. static jboolean JNI_CachedFeatureFlags_IsNetworkServiceWarmUpEnabled(
  393. JNIEnv* env) {
  394. return content::IsOutOfProcessNetworkService() &&
  395. diff --git a/chrome/browser/flags/android/java/src/org/chromium/chrome/browser/flags/CachedFeatureFlags.java b/chrome/browser/flags/android/java/src/org/chromium/chrome/browser/flags/CachedFeatureFlags.java
  396. --- a/chrome/browser/flags/android/java/src/org/chromium/chrome/browser/flags/CachedFeatureFlags.java
  397. +++ b/chrome/browser/flags/android/java/src/org/chromium/chrome/browser/flags/CachedFeatureFlags.java
  398. @@ -250,6 +250,14 @@ public class CachedFeatureFlags {
  399. ChromeFeatureList.isEnabled(ChromeFeatureList.REACHED_CODE_PROFILER));
  400. }
  401. + public static void setAdBlockFiltersURL(String url) {
  402. + CachedFeatureFlagsJni.get().setAdBlockFiltersURL(url);
  403. + }
  404. +
  405. + public static String getAdBlockFiltersURL() {
  406. + return CachedFeatureFlagsJni.get().getAdBlockFiltersURL();
  407. + }
  408. +
  409. /**
  410. * Caches flags that must take effect on startup but are set via native code.
  411. */
  412. @@ -402,5 +410,7 @@ public class CachedFeatureFlags {
  413. @NativeMethods
  414. interface Natives {
  415. boolean isNetworkServiceWarmUpEnabled();
  416. + void setAdBlockFiltersURL(String url);
  417. + String getAdBlockFiltersURL();
  418. }
  419. }
  420. diff --git a/chrome/browser/net/system_network_context_manager.cc b/chrome/browser/net/system_network_context_manager.cc
  421. --- a/chrome/browser/net/system_network_context_manager.cc
  422. +++ b/chrome/browser/net/system_network_context_manager.cc
  423. @@ -328,6 +328,8 @@ SystemNetworkContextManager::SystemNetworkContextManager(
  424. SSLConfigServiceManager::CreateDefaultManager(local_state_)),
  425. proxy_config_monitor_(local_state_),
  426. stub_resolver_config_reader_(local_state_) {
  427. + local_state_->SetDefaultPrefValue(prefs::kAdBlockFiltersURL,
  428. + base::Value("https://www.bromite.org/filters/filters.dat"));
  429. #if !defined(OS_ANDROID)
  430. // QuicAllowed was not part of Android policy.
  431. const base::Value* value =
  432. @@ -389,6 +391,8 @@ SystemNetworkContextManager::~SystemNetworkContextManager() {
  433. void SystemNetworkContextManager::RegisterPrefs(PrefRegistrySimple* registry) {
  434. StubResolverConfigReader::RegisterPrefs(registry);
  435. + registry->RegisterStringPref(prefs::kAdBlockFiltersURL, std::string());
  436. +
  437. // Static auth params
  438. registry->RegisterStringPref(prefs::kAuthSchemes,
  439. "basic,digest,ntlm,negotiate");
  440. diff --git a/chrome/browser/ui/android/strings/android_chrome_strings.grd b/chrome/browser/ui/android/strings/android_chrome_strings.grd
  441. --- a/chrome/browser/ui/android/strings/android_chrome_strings.grd
  442. +++ b/chrome/browser/ui/android/strings/android_chrome_strings.grd
  443. @@ -1825,6 +1825,20 @@ To change this setting, <ph name="BEGIN_LINK">&lt;resetlink&gt;</ph>reset sync<p
  444. Work profile
  445. </message>
  446. + <!-- AdBlock settings -->
  447. + <message name="IDS_PREFS_ADBLOCK" desc="Title of the AdBlock Settings screen. [CHAR-LIMIT=32]">
  448. + AdBlock settings
  449. + </message>
  450. + <message name="IDS_OPTIONS_ADBLOCK_EDIT_TITLE" desc="The title of the screen that allows users to change the URL that is used to fetch the ad blocker filters.">
  451. + Edit filters URL
  452. + </message>
  453. + <message name="IDS_OPTIONS_ADBLOCK_EDIT_LABEL" desc="The label for the edit text field that allows the user to change the URL that is used to fetch the ad blocker filters.">
  454. + Filters URL
  455. + </message>
  456. + <message name="IDS_ADBLOCK_HELP" desc="The title of the hyperlink that allows users to visit the web page with instructions for custom ad blocker filters.">
  457. + Visit help page
  458. + </message>
  459. +
  460. <!-- Fullscreen -->
  461. <message name="IDS_IMMERSIVE_FULLSCREEN_API_NOTIFICATION" desc="Notification message when a site has entered immersive fullscreen and the directions of how to exit.">
  462. Drag from top and touch the back button to exit full screen.
  463. diff --git a/chrome/common/pref_names.cc b/chrome/common/pref_names.cc
  464. --- a/chrome/common/pref_names.cc
  465. +++ b/chrome/common/pref_names.cc
  466. @@ -2043,6 +2043,9 @@ const char kAudioCaptureAllowed[] = "hardware.audio_capture_enabled";
  467. // capture devices without prompt.
  468. const char kAudioCaptureAllowedUrls[] = "hardware.audio_capture_allowed_urls";
  469. +// Holds the URL to an indexed subresource filters file.
  470. +const char kAdBlockFiltersURL[] = "adblock.filters_url";
  471. +
  472. // A pref holding the value of the policy used to explicitly allow or deny
  473. // access to video capture devices. When enabled or not set, the user is
  474. // prompted for device access. When disabled, access to video capture devices
  475. diff --git a/chrome/common/pref_names.h b/chrome/common/pref_names.h
  476. --- a/chrome/common/pref_names.h
  477. +++ b/chrome/common/pref_names.h
  478. @@ -31,6 +31,7 @@ extern const char kDownloadRestrictions[];
  479. extern const char kForceEphemeralProfiles[];
  480. extern const char kHomePageIsNewTabPage[];
  481. extern const char kHomePage[];
  482. +extern const char kAdBlockFiltersURL[];
  483. extern const char kImportantSitesDialogHistory[];
  484. extern const char kProfileCreationTime[];
  485. #if defined(OS_WIN)
  486. diff --git a/components/component_updater/adblock_updater_service.cc b/components/component_updater/adblock_updater_service.cc
  487. --- a/components/component_updater/adblock_updater_service.cc
  488. +++ b/components/component_updater/adblock_updater_service.cc
  489. @@ -46,12 +46,12 @@ const int initial_check_delay = 5,
  490. next_check_delay = 60*60*24*7, // 1 week
  491. on_demand_check_delay = 60; // minimum 1 minute between each on-demand check
  492. -AdBlockUpdaterService::AdBlockUpdaterService(scoped_refptr<network::SharedURLLoaderFactory> shared_url_network_factory, std::unique_ptr<component_updater::UpdateScheduler> scheduler, subresource_filter::RulesetService* ruleset_service)
  493. +AdBlockUpdaterService::AdBlockUpdaterService(scoped_refptr<network::SharedURLLoaderFactory> shared_url_network_factory, std::unique_ptr<component_updater::UpdateScheduler> scheduler,
  494. + subresource_filter::RulesetService* ruleset_service, std::string filters_url)
  495. : ruleset_service_(ruleset_service), shared_url_network_factory_(shared_url_network_factory), scheduler_(std::move(scheduler)) {
  496. DCHECK(ruleset_service);
  497. - //TODO: retrieve filters URL from config/prefs
  498. - filters_url_ = "https://www.bromite.org/filters/filters.dat";
  499. + filters_url_ = filters_url;
  500. }
  501. AdBlockUpdaterService::~AdBlockUpdaterService() {
  502. diff --git a/components/component_updater/adblock_updater_service.h b/components/component_updater/adblock_updater_service.h
  503. --- a/components/component_updater/adblock_updater_service.h
  504. +++ b/components/component_updater/adblock_updater_service.h
  505. @@ -54,7 +54,8 @@ class Observer {
  506. // All methods are safe to call ONLY from the browser's main thread.
  507. class AdBlockUpdaterService {
  508. public:
  509. - AdBlockUpdaterService(scoped_refptr<network::SharedURLLoaderFactory> shared_url_network_factory, std::unique_ptr<component_updater::UpdateScheduler> scheduler, subresource_filter::RulesetService* ruleset_service);
  510. + AdBlockUpdaterService(scoped_refptr<network::SharedURLLoaderFactory> shared_url_network_factory, std::unique_ptr<component_updater::UpdateScheduler> scheduler,
  511. + subresource_filter::RulesetService* ruleset_service, std::string filters_url);
  512. ~AdBlockUpdaterService();
  513. // Adds an observer for this class. An observer should not be added more
  514. --
  515. 2.17.1