|
|
@ -4,73 +4,61 @@ |
|
|
|
|
|
|
|
'use strict'; |
|
|
|
|
|
|
|
let |
|
|
|
appName = 'ublock', |
|
|
|
contentBaseURI = 'chrome://' + appName + '/content/js/', |
|
|
|
listeners = {}, |
|
|
|
_addMessageListener = function(id, fn) { |
|
|
|
let appName = 'ublock'; |
|
|
|
let contentBaseURI = 'chrome://' + appName + '/content/js/'; |
|
|
|
let listeners = {}; |
|
|
|
|
|
|
|
let _addMessageListener = function(id, fn) { |
|
|
|
_removeMessageListener(id); |
|
|
|
listeners[id] = function(msg) { |
|
|
|
fn(msg.data); |
|
|
|
}; |
|
|
|
addMessageListener(id, listeners[id]); |
|
|
|
}, |
|
|
|
_removeMessageListener = function(id) { |
|
|
|
}; |
|
|
|
|
|
|
|
let _removeMessageListener = function(id) { |
|
|
|
if (listeners[id]) { |
|
|
|
removeMessageListener(id, listeners[id]); |
|
|
|
} |
|
|
|
|
|
|
|
delete listeners[id]; |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
addMessageListener('µBlock:broadcast', function(msg) { |
|
|
|
for (var id in listeners) { |
|
|
|
for (let id in listeners) { |
|
|
|
listeners[id](msg); |
|
|
|
} |
|
|
|
}); |
|
|
|
|
|
|
|
var observer = { |
|
|
|
unload: function(e) { |
|
|
|
Services.obs.removeObserver(observer, 'content-document-global-created'); |
|
|
|
observer = listeners = null; |
|
|
|
}, |
|
|
|
onDOMReady: function(e) { |
|
|
|
var win = e.target.defaultView; |
|
|
|
let initContext = function(win, sandbox) { |
|
|
|
if (sandbox) { |
|
|
|
win = Components.utils.Sandbox([win], { |
|
|
|
sandboxPrototype: win, |
|
|
|
wantComponents: false, |
|
|
|
wantXHRConstructor: false |
|
|
|
}); |
|
|
|
} |
|
|
|
|
|
|
|
if (win.location.protocol === 'chrome:' && win.location.host === appName) { |
|
|
|
win.sendAsyncMessage = sendAsyncMessage; |
|
|
|
win.addMessageListener = _addMessageListener; |
|
|
|
win.removeMessageListener = _removeMessageListener; |
|
|
|
} |
|
|
|
}, |
|
|
|
|
|
|
|
return win; |
|
|
|
}; |
|
|
|
|
|
|
|
let observer = { |
|
|
|
observe: function(win) { |
|
|
|
if (!win || win.top !== content) { |
|
|
|
return; |
|
|
|
} |
|
|
|
|
|
|
|
// baseURI is more reliable
|
|
|
|
var location = Services.io.newURI( |
|
|
|
win.location.protocol === 'data:' ? 'data:text/plain,' : win.document.baseURI, |
|
|
|
null, |
|
|
|
null |
|
|
|
); |
|
|
|
|
|
|
|
if (!(win.document instanceof win.HTMLDocument |
|
|
|
&& (/^https?$/.test(location.scheme)))) { |
|
|
|
&& (/^https?:$/.test(win.location.protocol)))) { |
|
|
|
return; |
|
|
|
} |
|
|
|
|
|
|
|
win = Components.utils.Sandbox([win], { |
|
|
|
sandboxPrototype: win, |
|
|
|
wantComponents: false, |
|
|
|
wantXHRConstructor: false |
|
|
|
}); |
|
|
|
|
|
|
|
win.sendAsyncMessage = sendAsyncMessage; |
|
|
|
win.addMessageListener = _addMessageListener; |
|
|
|
win.removeMessageListener = _removeMessageListener; |
|
|
|
|
|
|
|
var lss = Services.scriptloader.loadSubScript; |
|
|
|
let lss = Services.scriptloader.loadSubScript; |
|
|
|
win = initContext(win, true); |
|
|
|
|
|
|
|
lss(contentBaseURI + 'vapi-client.js', win); |
|
|
|
lss(contentBaseURI + 'contentscript-start.js', win); |
|
|
@ -91,9 +79,20 @@ var observer = { |
|
|
|
|
|
|
|
Services.obs.addObserver(observer, 'content-document-global-created', false); |
|
|
|
|
|
|
|
addEventListener('unload', observer.unload, false); |
|
|
|
let DOMReady = function(e) { |
|
|
|
let win = e.target.defaultView; |
|
|
|
|
|
|
|
// for the Options page
|
|
|
|
addEventListener('DOMContentLoaded', observer.onDOMReady, true); |
|
|
|
// inject the message handlers for the options page
|
|
|
|
if (win.location.protocol === 'chrome:' && win.location.host === appName) { |
|
|
|
initContext(win); |
|
|
|
} |
|
|
|
}; |
|
|
|
|
|
|
|
addEventListener('DOMContentLoaded', DOMReady, true); |
|
|
|
|
|
|
|
addEventListener('unload', function() { |
|
|
|
Services.obs.removeObserver(observer, 'content-document-global-created'); |
|
|
|
observer = listeners = null; |
|
|
|
}, false); |
|
|
|
|
|
|
|
})(); |