From 529fea844c96da8f181eb58c3423cab22986e018 Mon Sep 17 00:00:00 2001 From: nobody Date: Sun, 21 Feb 2021 19:50:41 +0100 Subject: [PATCH] Implemented: Simple logging page (#279) --- core/constants.js | 1 + core/interceptor.js | 2 +- core/messenger.js | 9 +++ core/request-analyzer.js | 6 +- icons/logging-dark.svg | 120 +++++++++++++++++++++++++++++++ icons/logging-light.svg | 120 +++++++++++++++++++++++++++++++ modules/internal/log.js | 28 ++++++++ pages/background/background.html | 1 + pages/options/options.html | 3 +- pages/options/options.js | 6 ++ pages/popup/popup.css | 14 +++- pages/popup/popup.html | 3 + pages/popup/popup.js | 23 +++++- pages/updates/updates.html | 1 + 14 files changed, 329 insertions(+), 8 deletions(-) create mode 100644 icons/logging-dark.svg create mode 100644 icons/logging-light.svg create mode 100644 modules/internal/log.js diff --git a/core/constants.js b/core/constants.js index bd4550ec..5f2f39ad 100644 --- a/core/constants.js +++ b/core/constants.js @@ -216,6 +216,7 @@ const Links = { 'LOCALCDN_TEST': 'https://www.localcdn.org/test', 'LOCALCDN_TEST_WEBSITE': 'https://www.localcdn.org/test/check', 'WEBLATE': 'https://hosted.weblate.org/projects/localcdn/localcdn/', + 'LOGGING': chrome.extension.getURL('pages/logging/logging.html'), }; const CDNs = { diff --git a/core/interceptor.js b/core/interceptor.js index 88f0221a..47323484 100644 --- a/core/interceptor.js +++ b/core/interceptor.js @@ -41,7 +41,7 @@ interceptor.handleRequest = function (requestDetails, tabIdentifier, tab) { }; } - targetDetails = requestAnalyzer.getLocalTarget(requestDetails); + targetDetails = requestAnalyzer.getLocalTarget(requestDetails, tab.url); targetPath = targetDetails.path; if (Regex.GOOGLE_FONTS.test(requestDetails.url)) { diff --git a/core/messenger.js b/core/messenger.js index 394bf106..e959f9a8 100644 --- a/core/messenger.js +++ b/core/messenger.js @@ -107,6 +107,15 @@ messenger._handleMessageReceived = function (message, sender, sendResponse) { 'runAt': 'document_start' }); } + + if (topic === 'logs:get') { + sendResponse({'logs': log.data}); + return MessageResponse.SYNCHRONOUS; + } + + if (topic === 'logs:delete') { + log.data = []; + } }; diff --git a/core/request-analyzer.js b/core/request-analyzer.js index 5c3a4334..86209f2e 100644 --- a/core/request-analyzer.js +++ b/core/request-analyzer.js @@ -65,7 +65,7 @@ requestAnalyzer.isValidCandidate = function (requestDetails, tabDetails) { return requestDetails.method === WebRequest.GET; }; -requestAnalyzer.getLocalTarget = function (requestDetails) { +requestAnalyzer.getLocalTarget = function (requestDetails, initiator) { let destinationUrl, destinationHost, destinationPath, hostMappings, basePath, resourceMappings, destinationSearchString; @@ -95,7 +95,7 @@ requestAnalyzer.getLocalTarget = function (requestDetails) { // Return either the local target's path or false. // eslint-disable-next-line max-len - return requestAnalyzer._findLocalTarget(resourceMappings, basePath, destinationHost, destinationPath, destinationSearchString); + return requestAnalyzer._findLocalTarget(resourceMappings, basePath, destinationHost, destinationPath, destinationSearchString, initiator); }; @@ -114,7 +114,7 @@ requestAnalyzer._matchBasePath = function (hostMappings, channelPath) { }; // eslint-disable-next-line max-len -requestAnalyzer._findLocalTarget = function (resourceMappings, basePath, channelHost, channelPath, destinationSearchString) { +requestAnalyzer._findLocalTarget = function (resourceMappings, basePath, channelHost, channelPath, destinationSearchString, initiator) { let resourcePath, versionNumber, resourcePattern, filename, shorthandResource; storageManager.type.get(Setting.LOGGING, function (items) { diff --git a/icons/logging-dark.svg b/icons/logging-dark.svg new file mode 100644 index 00000000..f06babd7 --- /dev/null +++ b/icons/logging-dark.svg @@ -0,0 +1,120 @@ + + + +image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/icons/logging-light.svg b/icons/logging-light.svg new file mode 100644 index 00000000..1506d4b2 --- /dev/null +++ b/icons/logging-light.svg @@ -0,0 +1,120 @@ + + + +image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/modules/internal/log.js b/modules/internal/log.js new file mode 100644 index 00000000..e6e2e6c1 --- /dev/null +++ b/modules/internal/log.js @@ -0,0 +1,28 @@ +/** + * Log + * Belongs to LocalCDN + * + * @author nobody + * @since 2021-02-19 + * + * @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'; + + +/** + * Log + */ + +var log = {}; + +log.append = function (initiator, resource, target, highlight) { + log.data.push({initiator, resource, target, highlight}); +}; + +log.data = []; diff --git a/pages/background/background.html b/pages/background/background.html index 938ba589..2058612d 100644 --- a/pages/background/background.html +++ b/pages/background/background.html @@ -12,6 +12,7 @@ + diff --git a/pages/options/options.html b/pages/options/options.html index 8d4d4ce4..8b815dba 100644 --- a/pages/options/options.html +++ b/pages/options/options.html @@ -302,7 +302,8 @@
  • Changelog (In-App)
  • Donate (In-App)
  • FAQ (In-App)
  • -
  • Statistics (In-App)

  • +
  • Statistics (In-App)
  • +
  • Logs (In-App)

  • Source (www.codeberg.org)
  • Website (www.localcdn.org)
  • Testing Utility (www.localcdn.org/test)
  • diff --git a/pages/options/options.js b/pages/options/options.js index cfa54777..cf07ee78 100644 --- a/pages/options/options.js +++ b/pages/options/options.js @@ -260,6 +260,12 @@ options.onOptionChanged = function ({target}) { case Setting.SELECTED_ICON: optionsOther._setIcon(optionValue); break; + case Setting.LOGGING: + console.log(optionValue); + if (optionValue === false) { + chrome.runtime.sendMessage({'topic': 'logs:delete', 'value': ''}); + } + break; } storageManager.type.set({ diff --git a/pages/popup/popup.css b/pages/popup/popup.css index 2b75bc42..336b42e5 100644 --- a/pages/popup/popup.css +++ b/pages/popup/popup.css @@ -196,7 +196,7 @@ footer { float: right; font-size: 12px; margin-left: 10px; - padding: 5px 22px; + padding: 5px 10px; -moz-user-select: none; -ms-user-select: none; -webkit-user-select: none; @@ -265,12 +265,18 @@ footer { #statistics-button:hover { filter: contrast(0.5); +#logging-button-svg { + background-image: url("../../icons/logging-dark.svg"); } -#statistics-button { +#statistics-button, #logging-button { display: none; } +#options-button:hover, #statistics-button:hover, #logging-button:hover { + filter: contrast(0.5); +} + /** * Toggles */ @@ -497,6 +503,10 @@ input:checked + .slider:hover { background-image: url(""); } + #logging-button-svg { + background-image: url("../../icons/logging-light.svg"); + } + input:checked + .slider { background-color: #6bb798; } diff --git a/pages/popup/popup.html b/pages/popup/popup.html index 97498199..fa01ba74 100644 --- a/pages/popup/popup.html +++ b/pages/popup/popup.html @@ -57,6 +57,9 @@
    Website broken?
    +
    +
    +
    diff --git a/pages/popup/popup.js b/pages/popup/popup.js index 07a21b8f..09192393 100644 --- a/pages/popup/popup.js +++ b/pages/popup/popup.js @@ -77,6 +77,11 @@ popup._renderNonContextualContents = function () { document.getElementById('statistics-button').style.display = 'block'; document.getElementById('statistics-button').addEventListener('mouseup', popup._onStatisticsButtonClicked); } + + if (popup._loggingStatus) { + document.getElementById('logging-button').style.display = 'block'; + document.getElementById('logging-button').addEventListener('mouseup', popup._onLoggingButtonClicked); + } }; popup._renderContextualContents = function () { @@ -261,8 +266,12 @@ popup._readLocalStorage = function () { popup._readStorage = function () { return new Promise((resolve) => { - storageManager.type.get([Setting.NEGATE_HTML_FILTER_LIST], function (items) { + storageManager.type.get([ + Setting.NEGATE_HTML_FILTER_LIST, + Setting.LOGGING + ], function (items) { popup.negateHtmlFilterList = items.negateHtmlFilterList; + popup._loggingStatus = items.enableLogging; resolve(); }); }); @@ -538,6 +547,17 @@ popup._onStatisticsButtonClicked = function () { } }; +popup._onLoggingButtonClicked = function () { + if (event.button === 0 || event.button === 1) { + chrome.tabs.create({ + 'url': Links.LOGGING, + 'active': event.button === 0, + }); + } + if (event.button === 0) { + window.close(); + } +}; /** * Initializations @@ -545,5 +565,6 @@ popup._onStatisticsButtonClicked = function () { popup.negateHtmlFilterList = false; popup._statisticsStatus = false; +popup._loggingStatus = false; document.addEventListener('DOMContentLoaded', popup._onDocumentLoaded); diff --git a/pages/updates/updates.html b/pages/updates/updates.html index 9fba07a7..c4ccc5e9 100644 --- a/pages/updates/updates.html +++ b/pages/updates/updates.html @@ -26,6 +26,7 @@