Code

Handling of damaged login cookies
authorjhermann <jhermann@57a73879-2fb5-44c3-a270-3262357dd7e2>
Wed, 7 Nov 2001 02:34:06 +0000 (02:34 +0000)
committerjhermann <jhermann@57a73879-2fb5-44c3-a270-3262357dd7e2>
Wed, 7 Nov 2001 02:34:06 +0000 (02:34 +0000)
git-svn-id: http://svn.roundup-tracker.org/svnroot/roundup/trunk@376 57a73879-2fb5-44c3-a270-3262357dd7e2

roundup/cgi_client.py

index f1e960e91ed8902a9bf1e8434438aef7e9df7227..43b648e85cf70746552d98ee706e83ca8715d370 100644 (file)
@@ -15,7 +15,7 @@
 # BASIS, AND THERE IS NO OBLIGATION WHATSOEVER TO PROVIDE MAINTENANCE,
 # SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
 # 
-# $Id: cgi_client.py,v 1.54 2001-11-07 01:16:12 richard Exp $
+# $Id: cgi_client.py,v 1.55 2001-11-07 02:34:06 jhermann Exp $
 
 import os, cgi, pprint, StringIO, urlparse, re, traceback, mimetypes
 import binascii, Cookie, time
@@ -723,7 +723,12 @@ class Client:
             cookie = cookie['roundup_user'].value
             if len(cookie)%4:
               cookie = cookie + '='*(4-len(cookie)%4)
-            user, password = binascii.a2b_base64(cookie).split(':')
+            try:
+                user, password = binascii.a2b_base64(cookie).split(':')
+            except (TypeError, binascii.Error, binascii.Incomplete):
+                # damaged cookie!
+                user, password = 'anonymous', ''
+
             # make sure the user exists
             try:
                 uid = self.db.user.lookup(user)
@@ -950,6 +955,9 @@ def parsePropsFromForm(db, cl, form, nodeid=0):
 
 #
 # $Log: not supported by cvs2svn $
+# Revision 1.54  2001/11/07 01:16:12  richard
+# Remove the '=' padding from cookie value so quoting isn't an issue.
+#
 # Revision 1.53  2001/11/06 23:22:05  jhermann
 # More IE fixes: it does not like quotes around cookie values; in the
 # hope this does not break anything for other browser; if it does, we