196 lines
6.0 KiB
JavaScript
196 lines
6.0 KiB
JavaScript
/**
|
|
* Interceptor
|
|
* Belongs to LocalCDN (since 2020-02-26)
|
|
* (Origin: Decentraleyes)
|
|
*
|
|
* @author Thomas Rientjes
|
|
* @since 2016-04-06
|
|
*
|
|
* @author nobody
|
|
* @since 2020-02-26
|
|
*
|
|
* @license MPL 2.0
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
* You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
|
/**
|
|
* Interceptor
|
|
*/
|
|
|
|
var interceptor = {};
|
|
|
|
|
|
/**
|
|
* Public Methods
|
|
*/
|
|
|
|
interceptor.handleRequest = function (requestDetails, tabIdentifier, tab) {
|
|
let validCandidate, targetDetails, targetDomain, isGoogleFont, isGoogleMaterialIcons, initiatorDomain, isListed,
|
|
iframe;
|
|
|
|
iframe = '';
|
|
if (tab.url !== requestDetails.originUrl) {
|
|
console.log(`${LogString.PREFIX} ${LogString.IFRAME} ${tab.url} -> ${requestDetails.originUrl}`);
|
|
iframe = requestDetails.originUrl;
|
|
}
|
|
|
|
if (requestDetails['type'] === WebRequestType.MAIN_FRAME &&
|
|
helpers.checkAllowlisted(
|
|
helpers.extractDomainFromUrl(tab.url, true),
|
|
requestAnalyzer.allowlistedDomains
|
|
)) {
|
|
return {
|
|
'cancel': false
|
|
};
|
|
}
|
|
|
|
targetDetails = requestAnalyzer.getLocalTarget(requestDetails, tab.url);
|
|
if (targetDetails['result'] === 'blocked') {
|
|
let source, resource;
|
|
source = helpers.extractDomainFromUrl(tab.url, true);
|
|
resource = tab.url;
|
|
return {
|
|
'redirectUrl': chrome.runtime.getURL(`resources/blocked/index.html?source=${source}&resource=${resource}`)
|
|
};
|
|
}
|
|
|
|
stateManager.requests[requestDetails.requestId] = {
|
|
tabIdentifier, targetDetails
|
|
};
|
|
|
|
// Block POST, HEAD, PUT, DELETE, TRACE, OPTIONS
|
|
if (BlockedRequestMethods[requestDetails.method]) {
|
|
console.warn(`${LogString.PREFIX} ${LogString.NON_GET_REQUEST_BLOCKED}`);
|
|
log.append(tab.url, requestDetails.url, LogString.NON_GET_REQUEST_BLOCKED, true, iframe);
|
|
return {
|
|
'cancel': true
|
|
};
|
|
}
|
|
|
|
validCandidate = requestAnalyzer.isValidCandidate(requestDetails, tab);
|
|
if (!validCandidate) {
|
|
return {
|
|
'cancel': false
|
|
};
|
|
}
|
|
|
|
if (interceptor._isBadResource(requestDetails.url)) {
|
|
console.log(`${LogString.PREFIX} ${LogString.EVIL_RESOURCE_BLOCKED} ${requestDetails.url}`);
|
|
log.append(tab.url, requestDetails.url, '-', true, iframe);
|
|
return {
|
|
'cancel': true
|
|
};
|
|
}
|
|
|
|
targetDomain = helpers.extractDomainFromUrl(requestDetails.url, true);
|
|
isGoogleFont = requestAnalyzer.isGoogleFont(targetDomain);
|
|
isGoogleMaterialIcons = requestAnalyzer.isGoogleMaterialIcons(requestDetails.url);
|
|
|
|
if (BrowserType.FIREFOX && isGoogleFont && !isGoogleMaterialIcons) {
|
|
initiatorDomain = helpers.extractDomainFromUrl(tab.url, true);
|
|
isListed = helpers.checkAllowlisted(initiatorDomain, interceptor.allowedDomainsGoogleFonts);
|
|
// Check if the website is allowed to load Google Fonts
|
|
if (interceptor.blockGoogleFonts === true && isListed === false) {
|
|
return {
|
|
'redirectUrl': chrome.runtime.getURL('resources/google-fonts-placeholder.css')
|
|
};
|
|
} else if (interceptor.blockGoogleFonts === false || isListed === true) {
|
|
return {
|
|
'cancel': false
|
|
};
|
|
}
|
|
}
|
|
|
|
if (targetDetails['result'] === false) {
|
|
if (!IgnoredHost[targetDomain]) {
|
|
++stateManager.tabs[tabIdentifier].missing;
|
|
}
|
|
return interceptor._handleMissingCandidate(requestDetails.url, tabIdentifier);
|
|
}
|
|
|
|
console.log(`${LogString.PREFIX} ${LogString.REPLACED_RESOURCE} ${targetDetails.path}`);
|
|
log.append(tab.url, requestDetails.url, targetDetails.path, false, iframe);
|
|
|
|
return {
|
|
'redirectUrl': chrome.runtime.getURL(targetDetails.path + fileGuard.secret)
|
|
};
|
|
};
|
|
|
|
|
|
/**
|
|
* Private Methods
|
|
*/
|
|
|
|
interceptor._handleMissingCandidate = function (requestUrl, tabIdentifier) {
|
|
let requestUrlSegments, injectionCount, missingCount;
|
|
|
|
if (stateManager.showIconBadge === true) {
|
|
injectionCount = Object.keys(stateManager.tabs[tabIdentifier].injections).length || 0;
|
|
if (stateManager.changeBadgeColorMissingResources === true) {
|
|
missingCount = stateManager.tabs[tabIdentifier].missing || 0;
|
|
if (missingCount > 0 && injectionCount === 0) {
|
|
wrappers.setBadgeText(tabIdentifier, injectionCount);
|
|
wrappers.setBadgeColoring(tabIdentifier, BadgeSettingMissingResource.TYPE);
|
|
}
|
|
} else {
|
|
wrappers.setBadgeText(tabIdentifier, injectionCount);
|
|
}
|
|
}
|
|
|
|
if (interceptor.blockMissing === true) {
|
|
return {
|
|
'cancel': true
|
|
};
|
|
}
|
|
|
|
requestUrlSegments = new URL(requestUrl);
|
|
|
|
if (requestUrlSegments.protocol === Address.HTTP) {
|
|
requestUrlSegments.protocol = Address.HTTPS;
|
|
requestUrl = requestUrlSegments.toString();
|
|
|
|
return {
|
|
'redirectUrl': requestUrl
|
|
};
|
|
} else {
|
|
return {
|
|
'cancel': false
|
|
};
|
|
}
|
|
};
|
|
|
|
interceptor._handleStorageChanged = function (changes) {
|
|
if (Setting.XHR_TEST_DOMAIN in changes) {
|
|
interceptor.xhrTestDomain = changes.xhrTestDomain.newValue;
|
|
}
|
|
|
|
if (Setting.BLOCK_MISSING in changes) {
|
|
interceptor.blockMissing = changes.blockMissing.newValue;
|
|
}
|
|
|
|
if (Setting.BLOCK_GOOGLE_FONTS in changes) {
|
|
interceptor.blockGoogleFonts = changes.blockGoogleFonts.newValue;
|
|
}
|
|
|
|
if (Setting.ALLOWED_DOMAINS_GOOGLE_FONTS in changes) {
|
|
interceptor.allowedDomainsGoogleFonts = changes.allowedDomainsGoogleFonts.newValue;
|
|
}
|
|
};
|
|
|
|
interceptor._isBadResource = function (requestUrl) {
|
|
requestUrl = requestUrl.replace(/(^\w+:|^)\/\//, '');
|
|
return Object.keys(BadResources).filter((path) => requestUrl.startsWith(path)).length !== 0;
|
|
};
|
|
|
|
/**
|
|
* Event Handlers
|
|
*/
|
|
|
|
chrome.storage.onChanged.addListener(interceptor._handleStorageChanged);
|