Merge remote-tracking branch 'origin/pr/4046'

This commit is contained in:
Florian Bruhin 2018-10-05 23:36:40 +02:00
commit 14957c75ff
4 changed files with 16 additions and 14 deletions

View File

@ -110,9 +110,10 @@ class HostBlocker:
config.instance.changed.connect(self._update_files) config.instance.changed.connect(self._update_files)
def is_blocked(self, url): def is_blocked(self, url, first_party_url=None):
"""Check if the given URL (as QUrl) is blocked.""" """Check if the given URL (as QUrl) is blocked."""
if not config.val.content.host_blocking.enabled: if not config.instance.get('content.host_blocking.enabled',
url=first_party_url):
return False return False
host = url.host() host = url.host()
return ((host in self._blocked_hosts or return ((host in self._blocked_hosts or

View File

@ -70,21 +70,21 @@ class RequestInterceptor(QWebEngineUrlRequestInterceptor):
resource_type, navigation_type)) resource_type, navigation_type))
url = info.requestUrl() url = info.requestUrl()
firstparty = info.firstPartyUrl() first_party = info.firstPartyUrl()
if ((url.scheme(), url.host(), url.path()) == if ((url.scheme(), url.host(), url.path()) ==
('qute', 'settings', '/set')): ('qute', 'settings', '/set')):
if (firstparty != QUrl('qute://settings/') or if (first_party != QUrl('qute://settings/') or
info.resourceType() != info.resourceType() !=
QWebEngineUrlRequestInfo.ResourceTypeXhr): QWebEngineUrlRequestInfo.ResourceTypeXhr):
log.webview.warning("Blocking malicious request from {} to {}" log.webview.warning("Blocking malicious request from {} to {}"
.format(firstparty.toDisplayString(), .format(first_party.toDisplayString(),
url.toDisplayString())) url.toDisplayString()))
info.block(True) info.block(True)
return return
# FIXME:qtwebengine only block ads for NavigationTypeOther? # FIXME:qtwebengine only block ads for NavigationTypeOther?
if self._host_blocker.is_blocked(url): if self._host_blocker.is_blocked(url, first_party):
log.webview.info("Request to {} blocked by host blocker.".format( log.webview.info("Request to {} blocked by host blocker.".format(
url.host())) url.host()))
info.block(True) info.block(True)

View File

@ -376,14 +376,6 @@ class NetworkManager(QNetworkAccessManager):
for header, value in shared.custom_headers(url=req.url()): for header, value in shared.custom_headers(url=req.url()):
req.setRawHeader(header, value) req.setRawHeader(header, value)
host_blocker = objreg.get('host-blocker')
if host_blocker.is_blocked(req.url()):
log.webview.info("Request to {} blocked by host blocker.".format(
req.url().host()))
return networkreply.ErrorNetworkReply(
req, HOSTBLOCK_ERROR_STRING, QNetworkReply.ContentAccessDenied,
self)
# There are some scenarios where we can't figure out current_url: # There are some scenarios where we can't figure out current_url:
# - There's a generic NetworkManager, e.g. for downloads # - There's a generic NetworkManager, e.g. for downloads
# - The download was in a tab which is now closed. # - The download was in a tab which is now closed.
@ -401,6 +393,14 @@ class NetworkManager(QNetworkAccessManager):
# the webpage shutdown here. # the webpage shutdown here.
current_url = QUrl() current_url = QUrl()
host_blocker = objreg.get('host-blocker')
if host_blocker.is_blocked(req.url(), current_url):
log.webview.info("Request to {} blocked by host blocker.".format(
req.url().host()))
return networkreply.ErrorNetworkReply(
req, HOSTBLOCK_ERROR_STRING, QNetworkReply.ContentAccessDenied,
self)
if 'log-requests' in self._args.debug_flags: if 'log-requests' in self._args.debug_flags:
operation = debug.qenum_key(QNetworkAccessManager, op) operation = debug.qenum_key(QNetworkAccessManager, op)
operation = operation.replace('Operation', '').upper() operation = operation.replace('Operation', '').upper()

View File

@ -529,6 +529,7 @@ content.headers.user_agent:
content.host_blocking.enabled: content.host_blocking.enabled:
default: true default: true
supports_pattern: true
type: Bool type: Bool
desc: Enable host blocking. desc: Enable host blocking.