Merge branch 'Konubinix-netrc'
This commit is contained in:
commit
cdb6c6b3a3
@ -182,6 +182,7 @@ Contributors, sorted by the number of commits in descending order:
|
||||
* zwarag
|
||||
* Tim Harder
|
||||
* Thiago Barroso Perrotta
|
||||
* Samuel Loury
|
||||
* Matthias Lisin
|
||||
* Jean-Christophe Petkovich
|
||||
* Helen Sherwood-Taylor
|
||||
|
@ -20,6 +20,7 @@
|
||||
"""Our own QNetworkAccessManager."""
|
||||
|
||||
import collections
|
||||
import netrc
|
||||
|
||||
from PyQt5.QtCore import (pyqtSlot, pyqtSignal, PYQT_VERSION, QCoreApplication,
|
||||
QUrl, QByteArray)
|
||||
@ -241,12 +242,33 @@ class NetworkManager(QNetworkAccessManager):
|
||||
@pyqtSlot('QNetworkReply', 'QAuthenticator')
|
||||
def on_authentication_required(self, reply, authenticator):
|
||||
"""Called when a website needs authentication."""
|
||||
answer = self._ask("Username ({}):".format(authenticator.realm()),
|
||||
user, password = None, None
|
||||
if not hasattr(reply, "netrc_used"):
|
||||
reply.netrc_used = True
|
||||
try:
|
||||
net = netrc.netrc()
|
||||
authenticators = net.authenticators(reply.url().host())
|
||||
if authenticators is not None:
|
||||
# pylint: disable=unpacking-non-sequence
|
||||
(user, _account, password) = authenticators
|
||||
except FileNotFoundError:
|
||||
log.misc.debug("No .netrc file found")
|
||||
except OSError:
|
||||
log.misc.exception("Unable to read the netrc file")
|
||||
except netrc.NetrcParseError:
|
||||
log.misc.exception("Error when parsing the netrc file")
|
||||
|
||||
if user is None:
|
||||
# netrc check failed
|
||||
answer = self._ask(
|
||||
"Username ({}):".format(authenticator.realm()),
|
||||
mode=usertypes.PromptMode.user_pwd,
|
||||
owner=reply)
|
||||
if answer is not None:
|
||||
authenticator.setUser(answer.user)
|
||||
authenticator.setPassword(answer.password)
|
||||
user, password = answer.user, answer.password
|
||||
if user is not None:
|
||||
authenticator.setUser(user)
|
||||
authenticator.setPassword(password)
|
||||
|
||||
@pyqtSlot('QNetworkProxy', 'QAuthenticator')
|
||||
def on_proxy_authentication_required(self, proxy, authenticator):
|
||||
|
3
scripts/dev/run_vulture.py
Normal file → Executable file
3
scripts/dev/run_vulture.py
Normal file → Executable file
@ -88,6 +88,9 @@ def whitelist_generator():
|
||||
yield 'qutebrowser.utils.log.VDEBUG'
|
||||
yield 'qutebrowser.utils.log.QtWarningFilter.filter'
|
||||
yield 'logging.LogRecord.log_color'
|
||||
# vulture doesn't notice the hasattr() and thus thinks netrc_used is unused
|
||||
# in NetworkManager.on_authentication_required
|
||||
yield 'PyQt5.QtNetwork.QNetworkReply.netrc_used'
|
||||
|
||||
for attr in ('fileno', 'truncate', 'closed', 'readable'):
|
||||
yield 'qutebrowser.utils.qtutils.PyQIODevice.' + attr
|
||||
|
Loading…
Reference in New Issue
Block a user