From 0298fcc8415ffdf005b5dcb70a1f2272685848f0 Mon Sep 17 00:00:00 2001 From: Samuel Loury Date: Tue, 27 Oct 2015 08:07:11 +0100 Subject: [PATCH 1/2] Use credentials from netrc when available --- qutebrowser/browser/network/networkmanager.py | 34 +++++++++++++++---- scripts/dev/run_vulture.py | 3 ++ 2 files changed, 31 insertions(+), 6 deletions(-) mode change 100644 => 100755 scripts/dev/run_vulture.py diff --git a/qutebrowser/browser/network/networkmanager.py b/qutebrowser/browser/network/networkmanager.py index 66ec7595e..0ab090ca4 100644 --- a/qutebrowser/browser/network/networkmanager.py +++ b/qutebrowser/browser/network/networkmanager.py @@ -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()), - mode=usertypes.PromptMode.user_pwd, - owner=reply) - if answer is not None: - authenticator.setUser(answer.user) - authenticator.setPassword(answer.password) + 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: + 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): diff --git a/scripts/dev/run_vulture.py b/scripts/dev/run_vulture.py old mode 100644 new mode 100755 index 702d0bace..a26625834 --- a/scripts/dev/run_vulture.py +++ b/scripts/dev/run_vulture.py @@ -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 From a164cd4da24b7140688368802f0114b5a682795c Mon Sep 17 00:00:00 2001 From: Florian Bruhin Date: Wed, 18 Nov 2015 20:43:41 +0100 Subject: [PATCH 2/2] Regenerate authors. --- README.asciidoc | 1 + 1 file changed, 1 insertion(+) diff --git a/README.asciidoc b/README.asciidoc index 042e59270..3b9249a91 100644 --- a/README.asciidoc +++ b/README.asciidoc @@ -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