mirror of
https://github.com/gorhill/uBlock.git
synced 2024-11-16 23:42:39 +01:00
Merge pull request #1229 from gorhill/chrisaljoudi
Whitelist directives must override strict blocking
This commit is contained in:
commit
b0eed4a555
@ -150,6 +150,9 @@ vAPI.messaging = {
|
||||
},
|
||||
close: function() {
|
||||
delete vAPI.messaging.channels[this.channelName];
|
||||
if ( Object.keys(vAPI.messaging.channels).length === 0 ) {
|
||||
vAPI.messaging.close();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -56,10 +56,36 @@ if ( vAPI.contentscriptEndInjected ) {
|
||||
}
|
||||
vAPI.contentscriptEndInjected = true;
|
||||
|
||||
/******************************************************************************/
|
||||
/******************************************************************************/
|
||||
|
||||
var shutdownJobs = (function() {
|
||||
var jobs = [];
|
||||
|
||||
return {
|
||||
add: function(job) {
|
||||
jobs.push(job);
|
||||
},
|
||||
exec: function() {
|
||||
//console.debug('Shutting down...');
|
||||
var job;
|
||||
while ( job = jobs.pop() ) {
|
||||
job();
|
||||
}
|
||||
}
|
||||
};
|
||||
})();
|
||||
|
||||
/******************************************************************************/
|
||||
/******************************************************************************/
|
||||
|
||||
var messager = vAPI.messaging.channel('contentscript-end.js');
|
||||
|
||||
// https://github.com/gorhill/uMatrix/issues/144
|
||||
shutdownJobs.add(function() {
|
||||
messager.close();
|
||||
});
|
||||
|
||||
/******************************************************************************/
|
||||
|
||||
// https://github.com/chrisaljoudi/uBlock/issues/789
|
||||
@ -119,7 +145,14 @@ var uBlockCollapser = (function() {
|
||||
this.collapse = false;
|
||||
};
|
||||
|
||||
var onProcessed = function(requests) {
|
||||
var onProcessed = function(response) {
|
||||
// https://github.com/gorhill/uMatrix/issues/144
|
||||
if ( response.shutdown ) {
|
||||
shutdownJobs.exec();
|
||||
return;
|
||||
}
|
||||
|
||||
var requests = response.result;
|
||||
if ( requests === null || Array.isArray(requests) === false ) {
|
||||
return;
|
||||
}
|
||||
@ -314,24 +347,32 @@ var uBlockCollapser = (function() {
|
||||
firstRetrieveHandler = null;
|
||||
|
||||
// These are sent only once
|
||||
if ( response ) {
|
||||
if ( response.highGenerics ) {
|
||||
highGenerics = response.highGenerics;
|
||||
var result = response && response.result;
|
||||
if ( result ) {
|
||||
if ( result.highGenerics ) {
|
||||
highGenerics = result.highGenerics;
|
||||
}
|
||||
if ( response.donthide ) {
|
||||
processLowGenerics(response.donthide, nullArray);
|
||||
if ( result.donthide ) {
|
||||
processLowGenerics(result.donthide, nullArray);
|
||||
}
|
||||
}
|
||||
|
||||
nextRetrieveHandler(response);
|
||||
};
|
||||
|
||||
var nextRetrieveHandler = function(selectors) {
|
||||
var nextRetrieveHandler = function(response) {
|
||||
// https://github.com/gorhill/uMatrix/issues/144
|
||||
if ( response && response.shutdown ) {
|
||||
shutdownJobs.exec();
|
||||
return;
|
||||
}
|
||||
|
||||
//var tStart = timer.now();
|
||||
//console.debug('µBlock> contextNodes = %o', contextNodes);
|
||||
var result = response && response.result;
|
||||
var hideSelectors = [];
|
||||
if ( selectors && selectors.hide.length ) {
|
||||
processLowGenerics(selectors.hide, hideSelectors);
|
||||
if ( result && result.hide.length ) {
|
||||
processLowGenerics(result.hide, hideSelectors);
|
||||
}
|
||||
if ( highGenerics ) {
|
||||
if ( highGenerics.hideLowCount ) {
|
||||
@ -688,6 +729,14 @@ var uBlockCollapser = (function() {
|
||||
childList: true,
|
||||
subtree: true
|
||||
});
|
||||
|
||||
// https://github.com/gorhill/uMatrix/issues/144
|
||||
shutdownJobs.add(function() {
|
||||
treeObserver.disconnect();
|
||||
if ( addedNodeListsTimer !== null ) {
|
||||
clearTimeout(addedNodeListsTimer);
|
||||
}
|
||||
});
|
||||
})();
|
||||
|
||||
/******************************************************************************/
|
||||
@ -700,12 +749,19 @@ var uBlockCollapser = (function() {
|
||||
// - Elements dynamically added to the page
|
||||
// - Elements which resource URL changes
|
||||
|
||||
var onResourceFailed = function(ev) {
|
||||
//console.debug('onResourceFailed(%o)', ev);
|
||||
uBlockCollapser.add(ev.target);
|
||||
uBlockCollapser.process();
|
||||
};
|
||||
document.addEventListener('error', onResourceFailed, true);
|
||||
(function() {
|
||||
var onResourceFailed = function(ev) {
|
||||
//console.debug('onResourceFailed(%o)', ev);
|
||||
uBlockCollapser.add(ev.target);
|
||||
uBlockCollapser.process();
|
||||
};
|
||||
document.addEventListener('error', onResourceFailed, true);
|
||||
|
||||
// https://github.com/gorhill/uMatrix/issues/144
|
||||
shutdownJobs.add(function() {
|
||||
document.removeEventListener('error', onResourceFailed, true);
|
||||
});
|
||||
})();
|
||||
|
||||
/******************************************************************************/
|
||||
/******************************************************************************/
|
||||
@ -764,6 +820,11 @@ document.addEventListener('error', onResourceFailed, true);
|
||||
};
|
||||
|
||||
window.addEventListener('contextmenu', onContextMenu, true);
|
||||
|
||||
// https://github.com/gorhill/uMatrix/issues/144
|
||||
shutdownJobs.add(function() {
|
||||
document.removeEventListener('contextmenu', onContextMenu, true);
|
||||
});
|
||||
})();
|
||||
|
||||
/******************************************************************************/
|
||||
|
@ -496,9 +496,12 @@ var onMessage = function(details, sender, callback) {
|
||||
|
||||
switch ( details.what ) {
|
||||
case 'retrieveGenericCosmeticSelectors':
|
||||
if ( pageStore && pageStore.getGenericCosmeticFilteringSwitch()
|
||||
&& (!frameStore || frameStore.getNetFilteringSwitch()) ) {
|
||||
response = µb.cosmeticFilteringEngine.retrieveGenericSelectors(details);
|
||||
response = {
|
||||
shutdown: !pageStore || !pageStore.getNetFilteringSwitch() || (frameStore && !frameStore.getNetFilteringSwitch()),
|
||||
result: null
|
||||
};
|
||||
if(pageStore && pageStore.getGenericCosmeticFilteringSwitch()) {
|
||||
response.result = µb.cosmeticFilteringEngine.retrieveGenericSelectors(details);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -508,7 +511,13 @@ var onMessage = function(details, sender, callback) {
|
||||
|
||||
// Evaluate many requests
|
||||
case 'filterRequests':
|
||||
response = filterRequests(pageStore, details);
|
||||
response = {
|
||||
shutdown: !pageStore || !pageStore.getNetFilteringSwitch(),
|
||||
result: null
|
||||
};
|
||||
if(pageStore) {
|
||||
response.result = filterRequests(pageStore, details);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
|
@ -199,6 +199,11 @@ var onBeforeRootFrameRequest = function(details) {
|
||||
|
||||
var result = '';
|
||||
|
||||
// If the site is whitelisted, disregard strict blocking
|
||||
if ( µb.getNetFilteringSwitch(requestURL) === false ) {
|
||||
result = 'ua:whitelisted';
|
||||
}
|
||||
|
||||
// Permanently unrestricted?
|
||||
if ( result === '' && µb.hnSwitches.evaluateZ('dontBlockDoc', requestHostname) ) {
|
||||
result = 'ua:dontBlockDoc true';
|
||||
@ -217,7 +222,7 @@ var onBeforeRootFrameRequest = function(details) {
|
||||
}
|
||||
|
||||
// Filtering
|
||||
if ( result === '' && µb.getNetFilteringSwitch(requestURL) ) {
|
||||
if ( result === '' ) {
|
||||
result = µb.staticNetFilteringEngine.matchString(context);
|
||||
// https://github.com/chrisaljoudi/uBlock/issues/1128
|
||||
// Do not block if the match begins after the hostname.
|
||||
|
Loading…
Reference in New Issue
Block a user