| Index: ext/content.js |
| =================================================================== |
| new file mode 100644 |
| --- /dev/null |
| +++ b/ext/content.js |
| @@ -0,0 +1,145 @@ |
| +/* |
| + * This file is part of Adblock Plus <http://adblockplus.org/>, |
| + * Copyright (C) 2006-2014 Eyeo GmbH |
| + * |
| + * Adblock Plus is free software: you can redistribute it and/or modify |
| + * it under the terms of the GNU General Public License version 3 as |
| + * published by the Free Software Foundation. |
| + * |
| + * Adblock Plus is distributed in the hope that it will be useful, |
| + * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| + * GNU General Public License for more details. |
| + * |
| + * You should have received a copy of the GNU General Public License |
| + * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
| + */ |
| + |
| +this.ext = function(ext) |
| +{ |
| + function getURLParameters(data) |
|
Thomas Greiner
2014/12/18 10:17:48
This name is not reflecting what the function is d
Wladimir Palant
2014/12/18 19:31:35
I went with updateFromURL() which isn't quite as v
Thomas Greiner
2014/12/19 10:53:38
Thanks, that's great.
|
| + { |
| + if (window.location.search) |
| + { |
| + var params = window.location.search.substr(1).split("&"); |
| + for (var i = 0; i < params.length; i++) |
| + { |
| + var parts = params[i].split("=", 2); |
| + if (parts.length == 2 && parts[0] in data) |
| + data[parts[0]] = decodeURIComponent(parts[1]); |
| + } |
| + } |
| + } |
| + |
| + var subscriptions =[ |
| + "https://easylist-downloads.adblockplus.org/easylistgermany+easylist.txt", |
| + "https://easylist-downloads.adblockplus.org/exceptionrules.txt", |
| + "https://easylist-downloads.adblockplus.org/fanboy-social.txt" |
| + ]; |
| + |
| + var listenerFilter = null; |
| + |
| + ext.backgroundPage = { |
| + sendMessage: function(message, responseCallback) |
| + { |
| + var respond = function(response) |
| + { |
| + setTimeout(responseCallback.bind(responseCallback, response), 0); |
| + }; |
| + |
| + var dispatchListenerNotification = function(action) |
|
Thomas Greiner
2014/12/18 10:17:48
Nit: Since this is only used for subscription noti
Wladimir Palant
2014/12/18 19:31:35
I'm ignoring this nit because that callback is bei
|
| + { |
| + var match = /^subscription\.(.*)/.exec(action); |
|
Thomas Greiner
2014/12/18 10:17:48
In addition to my comment above, by directly passi
Wladimir Palant
2014/12/18 19:31:35
Same here, this is no longer relevant because the
|
| + if (match && listenerFilter && listenerFilter.indexOf(match[1]) >= 0) |
| + { |
| + ext.onMessage._dispatch({ |
| + type: "subscriptions.listen", |
| + action: match[1], |
| + args: Array.prototype.slice.call(arguments, 1) |
| + }); |
| + } |
| + }; |
| + |
| + switch (message.type) |
|
Thomas Greiner
2014/12/18 10:17:48
Introducing new method names should not be the nor
Wladimir Palant
2014/12/18 19:31:35
I've mostly changed it like this. However, I'm not
Thomas Greiner
2014/12/19 10:53:38
Looks good. Not sure about whether an array for "a
Wladimir Palant
2014/12/19 13:32:37
The problem isn't checking what was requested - th
|
| + { |
| + case "app.doclink": |
| + respond("https://adblockplus.org/redirect?link=" + encodeURIComponent(message.args[0])); |
|
Thomas Greiner
2014/12/18 10:17:48
Nit: This line doesn't need to be that long.
Codi
Wladimir Palant
2014/12/18 19:31:35
This code is being rewritten by the next patch, no
|
| + break; |
| + case "app.info": |
| + var response = {platform: "gecko", platformVersion: "34.0", application: "firefox", applicationVersion: "34.0"}; |
|
Thomas Greiner
2014/12/18 10:17:48
Nit: This line doesn't need to be that long.
Wladimir Palant
2014/12/18 19:31:35
This code is being rewritten by the next patch, no
|
| + getURLParameters(response); |
| + respond(response); |
| + break; |
| + case "app.issues": |
| + var response = {seenDataCorruption: false, filterlistsReinitialized: false}; |
|
Thomas Greiner
2014/12/18 10:17:48
Nit: This line doesn't need to be that long.
Wladimir Palant
2014/12/18 19:31:35
This code is being rewritten by the next patch, no
|
| + getURLParameters(response); |
| + respond(response); |
| + break; |
| + case "app.options": |
| + window.open("http://example.com/options.html", "_blank"); |
| + break; |
| + case "subscriptions.get": |
| + respond(subscriptions); |
| + break; |
| + case "filters.blocked": |
| + var params = {blockedURLs: ""}; |
| + getURLParameters(params); |
| + var blocked = params.blockedURLs.split(","); |
| + respond(blocked.indexOf(message.url) >= 0); |
| + break; |
| + case "subscriptions.toggle": |
| + var index = subscriptions.indexOf(message.url); |
| + if (index >= 0) |
| + { |
| + subscriptions.splice(index, 1); |
| + dispatchListenerNotification("subscription.removed", message.url); |
| + } |
| + else |
| + { |
| + subscriptions.push(message.url); |
| + dispatchListenerNotification("subscription.added", message.url); |
| + } |
| + break; |
| + case "subscriptions.listen": |
| + listenerFilter = message.filter; |
| + break; |
| + } |
| + } |
| + }; |
| + |
| + var EventTarget = function(cancelable) |
| + { |
| + this._listeners = []; |
| + this._cancelable = cancelable; |
| + }; |
| + EventTarget.prototype = { |
| + addListener: function(listener) |
| + { |
| + if (this._listeners.indexOf(listener) == -1) |
| + this._listeners.push(listener); |
| + }, |
| + removeListener: function(listener) |
| + { |
| + var idx = this._listeners.indexOf(listener); |
| + if (idx != -1) |
| + this._listeners.splice(idx, 1); |
| + }, |
| + _dispatch: function() |
| + { |
| + var result = null; |
| + |
| + for (var i = 0; i < this._listeners.length; i++) |
| + { |
| + result = this._listeners[i].apply(null, arguments); |
| + |
| + if (this._cancelable && result === false) |
| + break; |
| + } |
| + |
| + return result; |
| + } |
| + }; |
| + ext.onMessage = new EventTarget(); |
| + |
| + return ext; |
| +}(this.ext || {}); |