diff options
author | aiju <aiju@phicode.de> | 2011-05-11 14:22:50 +0000 |
---|---|---|
committer | aiju <aiju@phicode.de> | 2011-05-11 14:22:50 +0000 |
commit | c2a41bb939c9c6518a941eb77f3ecba53c12010e (patch) | |
tree | 51a72b57b0954a36bc70305e01f425e183117e09 /sys/lib | |
parent | 2b5b3b9ec4e7ebdac56bab0ba69e8b1f318f2050 (diff) |
added 403 handling to hgfactotum
Diffstat (limited to 'sys/lib')
-rw-r--r-- | sys/lib/python/hgext/hgfactotum.py | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/sys/lib/python/hgext/hgfactotum.py b/sys/lib/python/hgext/hgfactotum.py index 654c7a7d3..cd8d0f44b 100644 --- a/sys/lib/python/hgext/hgfactotum.py +++ b/sys/lib/python/hgext/hgfactotum.py @@ -8,6 +8,8 @@ import base64 class factotumbasic(urllib2.BaseHandler): def __init__(self, passmgr=None): self.f = factotum.Factotum() + self.retried = 0 + self.auth = None def http_error_401(self, req, fp, code, msg, headers): host = urllib2.urlparse.urlparse(req.get_full_url())[1] authreq = headers.get('www-authenticate', None) @@ -16,13 +18,23 @@ class factotumbasic(urllib2.BaseHandler): if authreq[0].lower() != 'basic': return None chal = urllib2.parse_keqv_list(urllib2.parse_http_list(authreq[1])) realm = chal['realm'] + self.auth = (host, realm) + self.retried += 1 + if self.retried >= 3: + self.f.delkey(proto="pass", host=host, realm=realm, role="client") self.f.start(proto="pass", host=host, realm=realm, role="client") pw = self.f.read().replace(' ', ':', 1) val = 'Basic %s' % base64.b64encode(pw).strip() if req.headers.get('Authorization', None) == val: return None req.add_header('Authorization', val) - return self.parent.open(req) - + result = self.parent.open(req) + self.retried = 0 + return result + def http_error_403(self, req, fp, code, msg, headers): + if self.auth != None: + self.f.delkey(proto="pass", host=self.auth[0], realm=self.auth[1], role="client") + self.auth = None + class factotumdigest(urllib2.BaseHandler): auth_header = 'Authorization' handler_order = 490 |