 Issue 8680033:
  Made sure to enable acceptable ads and to open the first-run page  (Closed)
    
  
    Issue 8680033:
  Made sure to enable acceptable ads and to open the first-run page  (Closed) 
  | Index: background.js | 
| =================================================================== | 
| --- a/background.js | 
| +++ b/background.js | 
| @@ -8,34 +8,39 @@ with(require("filterClasses")) | 
| with(require("subscriptionClasses")) | 
| { | 
| this.Subscription = Subscription; | 
| this.DownloadableSubscription = DownloadableSubscription; | 
| } | 
| var FilterStorage = require("filterStorage").FilterStorage; | 
| var ElemHide = require("elemHide").ElemHide; | 
| var defaultMatcher = require("matcher").defaultMatcher; | 
| +var Prefs = require("prefs").Prefs; | 
| var Synchronizer = require("synchronizer").Synchronizer; | 
| +var Utils = require("utils").Utils; | 
| // Some types cannot be distinguished | 
| RegExpFilter.typeMap.OBJECT_SUBREQUEST = RegExpFilter.typeMap.OBJECT; | 
| RegExpFilter.typeMap.MEDIA = RegExpFilter.typeMap.FONT = RegExpFilter.typeMap.OTHER; | 
| var isFirstRun = false; | 
| require("filterNotifier").FilterNotifier.addListener(function(action) | 
| { | 
| if (action == "load") | 
| { | 
| importOldData(); | 
| - if (!localStorage["currentVersion"]) | 
| + | 
| + var addonVersion = require("info").addonVersion; | 
| + var prevVersion = localStorage["currentVersion"]; | 
| + if (prevVersion != addonVersion) | 
| { | 
| - isFirstRun = true; | 
| - executeFirstRunActions(); | 
| + isFirstRun = !prevVersion; | 
| + localStorage["currentVersion"] = addonVersion; | 
| + addSubscription(prevVersion); | 
| } | 
| - localStorage["currentVersion"] = require("info").addonVersion; | 
| } | 
| }); | 
| // Special-case domains for which we cannot use style-based hiding rules. | 
| // See http://crbug.com/68705. | 
| var noStyleRulesHosts = ["mail.google.com", "mail.yahoo.com", "www.google.com"]; | 
| // Sets options to defaults, upgrading old options from previous versions as necessary | 
| @@ -269,86 +274,98 @@ function importOldData() | 
| } | 
| catch (e) | 
| { | 
| reportError(e); | 
| } | 
| } | 
| /** | 
| - * This function is called first time the extension runs after installation. | 
| - * It will add the default filter subscription. | 
| + * This function is called on an extension update. It will add the default | 
| + * filter subscription if necessary. | 
| */ | 
| -function executeFirstRunActions() | 
| +function addSubscription(prevVersion) | 
| { | 
| - // Don't do anything if the user has a subscription already | 
| - var hasSubscriptions = FilterStorage.subscriptions.some(function(subscription) {return subscription instanceof DownloadableSubscription}); | 
| - if (hasSubscriptions) | 
| + // Add "acceptable ads" subscription for new users and users updating from old ABP versions. | 
| 
Thomas Greiner
2012/10/26 09:09:48
please remove the point at the end of the sentence
 | 
| + var addAcceptable = (!prevVersion || Services.vc.compare(prevVersion, "2.1") < 0); | 
| + if (addAcceptable) | 
| + { | 
| + addAcceptable = !FilterStorage.subscriptions.some(function(subscription) | 
| + { | 
| + return subscription.url == Prefs.subscriptions_exceptionsurl; | 
| + }); | 
| + } | 
| + | 
| + // Don't add subscription if the user has a subscription already | 
| + var addSubscription = !FilterStorage.subscriptions.some(function(subscription) | 
| + { | 
| + return subscription instanceof DownloadableSubscription && | 
| + subscription.url != Prefs.subscriptions_exceptionsurl; | 
| + }); | 
| + | 
| + // If this isn't the first run, only add subscription if the user has no custom filters | 
| + if (addSubscription && prevVersion) | 
| + { | 
| + addSubscription = !FilterStorage.subscriptions.some(function(subscription) | 
| + { | 
| + return subscription.url != Prefs.subscriptions_exceptionsurl && | 
| + subscription.filters.length; | 
| + }); | 
| + } | 
| + | 
| + // Add "acceptable ads" subscription | 
| + if (addAcceptable) | 
| + { | 
| + var subscription = Subscription.fromURL(Prefs.subscriptions_exceptionsurl); | 
| + if (subscription) | 
| + { | 
| + subscription.title = "Allow non-intrusive advertising"; | 
| + FilterStorage.addSubscription(subscription); | 
| + if (subscription instanceof DownloadableSubscription && !subscription.lastDownload) | 
| + Synchronizer.execute(subscription); | 
| + } | 
| + else | 
| + addAcceptable = false; | 
| + } | 
| + | 
| + if (!addSubscription && !addAcceptable) | 
| return; | 
| - // Load subscriptions data | 
| - var request = new XMLHttpRequest(); | 
| - request.open("GET", "subscriptions.xml"); | 
| - request.onload = function() | 
| + function notifyUser() | 
| { | 
| - var subscriptions = request.responseXML.documentElement.getElementsByTagName("subscription"); | 
| - var selectedItem = null; | 
| - var selectedPrefix = null; | 
| - var matchCount = 0; | 
| - for (var i = 0; i < subscriptions.length; i++) | 
| + chrome.tabs.create({ | 
| + url: chrome.extension.getURL("firstRun.html") | 
| + }); | 
| + } | 
| + | 
| + if (addSubscription) | 
| + { | 
| + // Load subscriptions data | 
| + var request = new XMLHttpRequest(); | 
| + request.open("GET", "subscriptions.xml"); | 
| + request.addEventListener("load", function() | 
| { | 
| - var subscription = subscriptions[i]; | 
| - if (!selectedItem) | 
| - selectedItem = subscription; | 
| + var node = Utils.chooseFilterSubscription(request.responseXML.getElementsByTagName("subscription")); | 
| + var subscription = (node ? Subscription.fromURL(node.getAttribute("url")) : null); | 
| + if (subscription) | 
| + { | 
| + FilterStorage.addSubscription(subscription); | 
| + subscription.disabled = false; | 
| + subscription.title = node.getAttribute("title"); | 
| + subscription.homepage = node.getAttribute("homepage"); | 
| + if (subscription instanceof DownloadableSubscription && !subscription.lastDownload) | 
| + Synchronizer.execute(subscription); | 
| - var prefix = require("utils").Utils.checkLocalePrefixMatch(subscription.getAttribute("prefixes")); | 
| - if (prefix) | 
| - { | 
| - if (!selectedPrefix || selectedPrefix.length < prefix.length) | 
| - { | 
| - selectedItem = subscription; | 
| - selectedPrefix = prefix; | 
| - matchCount = 1; | 
| - } | 
| - else if (selectedPrefix && selectedPrefix.length == prefix.length) | 
| - { | 
| - matchCount++; | 
| - | 
| - // If multiple items have a matching prefix of the same length: | 
| - // Select one of the items randomly, probability should be the same | 
| - // for all items. So we replace the previous match here with | 
| - // probability 1/N (N being the number of matches). | 
| - if (Math.random() * matchCount < 1) | 
| - { | 
| - selectedItem = subscription; | 
| - selectedPrefix = prefix; | 
| - } | 
| - } | 
| + notifyUser(); | 
| } | 
| - } | 
| - | 
| - var subscription = (selectedItem ? Subscription.fromURL(selectedItem.getAttribute("url")) : null); | 
| - if (subscription) | 
| - { | 
| - subscription.disabled = false; | 
| - subscription.title = selectedItem.getAttribute("title"); | 
| - subscription.homepage = selectedItem.getAttribute("homepage"); | 
| - if (subscription instanceof DownloadableSubscription && !subscription.lastDownload) | 
| - Synchronizer.execute(subscription); | 
| - FilterStorage.addSubscription(subscription); | 
| - } | 
| - | 
| - subscription = Subscription.fromURL("https://easylist-downloads.adblockplus.org/chrome_supplement.txt"); | 
| - subscription.disabled = false; | 
| - subscription.title = "Recommended filters for Google Chrome" | 
| - if (subscription instanceof DownloadableSubscription && !subscription.lastDownload) | 
| - Synchronizer.execute(subscription); | 
| - FilterStorage.addSubscription(subscription); | 
| - }; | 
| - request.send(null); | 
| + }, false); | 
| + request.send(null); | 
| + } | 
| + else | 
| + notifyUser(); | 
| } | 
| // Set up context menu for user selection of elements to block | 
| function showContextMenu() | 
| { | 
| chrome.contextMenus.removeAll(function() | 
| { | 
| if(typeof localStorage["shouldShowBlockElementMenu"] == "string" && localStorage["shouldShowBlockElementMenu"] == "true") |