X-Git-Url: https://gitweb.stoutner.com/?p=PrivacyBrowserPC.git;a=blobdiff_plain;f=src%2Fviews%2FBrowserView.cpp;fp=src%2Fviews%2FBrowserView.cpp;h=440c694ab02a7ca130bfc58dbeb85ba9fa2a1b8b;hp=777d12efcda177e1ed877a615cd03938045625f0;hb=588db73b94af7b596b0e532f4557aa8b6c41f5c3;hpb=2facce32fb6d97b52a7dc148044cae4b36a65d4c diff --git a/src/views/BrowserView.cpp b/src/views/BrowserView.cpp index 777d12e..440c694 100644 --- a/src/views/BrowserView.cpp +++ b/src/views/BrowserView.cpp @@ -69,10 +69,10 @@ BrowserView::BrowserView(QWidget *parent) : QWidget(parent) // Populate the privacy web engine list. privacyWebEngineListPointer->append(currentPrivacyWebEnginePointer); - // Set the cookie filter. + // Set the local storage filter. webEngineCookieStorePointer->setCookieFilter([this](const QWebEngineCookieStore::FilterRequest &filterRequest) { - // qDebug() << "Cookie page URL: " << filterRequest.firstPartyUrl << ", Cookie URL: " << filterRequest.origin << ", Is third-party: " << filterRequest.thirdParty; + // qDebug() << "Page URL: " << filterRequest.firstPartyUrl << ", Local storage URL: " << filterRequest.origin << ", Is third-party: " << filterRequest.thirdParty; // Block all third party local storage requests, including the sneaky ones that don't register a first party URL. if (filterRequest.thirdParty || (filterRequest.firstPartyUrl == QStringLiteral(""))) @@ -82,7 +82,7 @@ BrowserView::BrowserView(QWidget *parent) : QWidget(parent) for (PrivacyWebEngine *privacyWebEnginePointer : *privacyWebEngineListPointer) { // Allow this local storage request if it comes from a tab with local storage enabled. - if (privacyWebEnginePointer->cookiesEnabled && (webEngineViewPointer->url().host() == filterRequest.firstPartyUrl.host())) + if (privacyWebEnginePointer->localStorageEnabled && (webEngineViewPointer->url().host() == filterRequest.firstPartyUrl.host())) return true; } @@ -152,8 +152,7 @@ BrowserView::~BrowserView() webEnginePagePointer->deleteLater(); } -// The cookie is copied instead of referenced so that changes made to the cookie do not create a race condition with the display of the cookie in the dialog. -void BrowserView::addCookieToStore(QNetworkCookie cookie) const +void BrowserView::addCookieToStore(QNetworkCookie &cookie) const { // Create a url. QUrl url; @@ -213,56 +212,81 @@ void BrowserView::applyDomainSettings(const QString &hostname, const bool reload // Set the JavaScript status. switch (domainRecord.field(DomainsDatabaseHelper::JAVASCRIPT).value().toInt()) { + // Set the default JavaScript status. case (DomainsDatabaseHelper::SYSTEM_DEFAULT): { - // Set the default JavaScript status. webEngineSettingsPointer->setAttribute(QWebEngineSettings::JavascriptEnabled, Settings::javaScriptEnabled()); break; } + // Disable JavaScript. case (DomainsDatabaseHelper::DISABLED): { - // Disable JavaScript. webEngineSettingsPointer->setAttribute(QWebEngineSettings::JavascriptEnabled, false); break; } + // Enable JavaScript. case (DomainsDatabaseHelper::ENABLED): { - // Enable JavaScript. webEngineSettingsPointer->setAttribute(QWebEngineSettings::JavascriptEnabled, true); break; } } - // Set the cookie status. TODO. - currentPrivacyWebEnginePointer->cookiesEnabled = Settings::cookiesEnabled(); + // Set the local storage status. + switch (domainRecord.field(DomainsDatabaseHelper::LOCAL_STORAGE).value().toInt()) + { + // Set the default local storage status. + case (DomainsDatabaseHelper::SYSTEM_DEFAULT): + { + currentPrivacyWebEnginePointer->localStorageEnabled = Settings::localStorageEnabled(); - // Set DOM storage. + break; + } + + // Disable local storage. + case (DomainsDatabaseHelper::DISABLED): + { + currentPrivacyWebEnginePointer->localStorageEnabled = false; + + break; + } + + // Enable local storage. + case (DomainsDatabaseHelper::ENABLED): + { + currentPrivacyWebEnginePointer->localStorageEnabled = true; + + break; + } + } + + // Set the DOM storage status. switch (domainRecord.field(DomainsDatabaseHelper::DOM_STORAGE).value().toInt()) { + // Set the default DOM storage status. case (DomainsDatabaseHelper::SYSTEM_DEFAULT): { - // Set the default DOM storage status. webEngineSettingsPointer->setAttribute(QWebEngineSettings::LocalStorageEnabled, Settings::domStorageEnabled()); break; } + // Disable DOM storage. case (DomainsDatabaseHelper::DISABLED): { - // Disable DOM storage. webEngineSettingsPointer->setAttribute(QWebEngineSettings::LocalStorageEnabled, false); break; } + // Enable DOM storage. case (DomainsDatabaseHelper::ENABLED): { - // Enable DOM storage. webEngineSettingsPointer->setAttribute(QWebEngineSettings::LocalStorageEnabled, true); break; @@ -295,8 +319,8 @@ void BrowserView::applyDomainSettings(const QString &hostname, const bool reload // Set the JavaScript status. webEngineSettingsPointer->setAttribute(QWebEngineSettings::JavascriptEnabled, Settings::javaScriptEnabled()); - // Set the cookie status. - currentPrivacyWebEnginePointer->cookiesEnabled = Settings::cookiesEnabled(); + // Set the local storage status. + currentPrivacyWebEnginePointer->localStorageEnabled = Settings::localStorageEnabled(); // Set DOM storage. webEngineSettingsPointer->setAttribute(QWebEngineSettings::LocalStorageEnabled, Settings::domStorageEnabled()); @@ -316,7 +340,7 @@ void BrowserView::applyDomainSettings(const QString &hostname, const bool reload // Emit the update actions signals. emit updateJavaScriptAction(webEngineSettingsPointer->testAttribute(QWebEngineSettings::JavascriptEnabled)); - emit updateCookiesAction(currentPrivacyWebEnginePointer->cookiesEnabled); + emit updateLocalStorageAction(currentPrivacyWebEnginePointer->localStorageEnabled); emit updateDomStorageAction(webEngineSettingsPointer->testAttribute(QWebEngineSettings::LocalStorageEnabled)); emit updateUserAgentActions(webEngineProfilePointer->httpUserAgent()); emit updateZoomFactorAction(webEngineViewPointer->zoomFactor()); @@ -511,13 +535,13 @@ void BrowserView::refresh() const webEngineViewPointer->reload(); } -void BrowserView::toggleCookies() +void BrowserView::toggleDomStorage() const { - // Toggle cookies. - currentPrivacyWebEnginePointer->cookiesEnabled = !currentPrivacyWebEnginePointer->cookiesEnabled; + // Toggle DOM storage. + webEngineSettingsPointer->setAttribute(QWebEngineSettings::LocalStorageEnabled, !webEngineSettingsPointer->testAttribute(QWebEngineSettings::LocalStorageEnabled)); - // Update the cookies icon. - emit updateCookiesAction(currentPrivacyWebEnginePointer->cookiesEnabled); + // Update the DOM storage action. + emit updateDomStorageAction(webEngineSettingsPointer->testAttribute(QWebEngineSettings::LocalStorageEnabled)); // Reload the website. webEngineViewPointer->reload(); @@ -528,20 +552,20 @@ void BrowserView::toggleJavaScript() const // Toggle JavaScript. webEngineSettingsPointer->setAttribute(QWebEngineSettings::JavascriptEnabled, !webEngineSettingsPointer->testAttribute(QWebEngineSettings::JavascriptEnabled)); - // Update the JavaScript icon. + // Update the JavaScript action. emit updateJavaScriptAction(webEngineSettingsPointer->testAttribute(QWebEngineSettings::JavascriptEnabled)); // Reload the website. webEngineViewPointer->reload(); } -void BrowserView::toggleDomStorage() const +void BrowserView::toggleLocalStorage() { - // Toggle DOM storage. - webEngineSettingsPointer->setAttribute(QWebEngineSettings::LocalStorageEnabled, !webEngineSettingsPointer->testAttribute(QWebEngineSettings::LocalStorageEnabled)); + // Toggle local storeage. + currentPrivacyWebEnginePointer->localStorageEnabled = !currentPrivacyWebEnginePointer->localStorageEnabled; - // Update the DOM storage action icon. - emit updateDomStorageAction(webEngineSettingsPointer->testAttribute(QWebEngineSettings::LocalStorageEnabled)); + // Update the local storage action. + emit updateLocalStorageAction(currentPrivacyWebEnginePointer->localStorageEnabled); // Reload the website. webEngineViewPointer->reload();