summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOwen W. Taylor <otaylor@fishsoup.net>2009-04-25 13:52:13 -0400
committerOwen W. Taylor <otaylor@fishsoup.net>2009-04-25 13:52:13 -0400
commit721b1174e58e7386d1eaa113cdb3bf20d6c06c04 (patch)
tree647efb9ed27d2448bb814c68e48ece66edd0ba96
parente7a525e5380dd4049cccd2177b9fa00ec1c38ca0 (diff)
downloadgit-bz-721b1174e58e7386d1eaa113cdb3bf20d6c06c04.tar.gz
Factor out common code between Firefox and Epiphany cookie reading
Make both call a common get_cookies_from_sqlite() to avoid code duplication. Return errors by raising a CookieError so that we can centralize information about git-config bz.browser into one place.
-rwxr-xr-xgit-bz90
1 files changed, 44 insertions, 46 deletions
diff --git a/git-bz b/git-bz
index 681d169..81918a5 100755
--- a/git-bz
+++ b/git-bz
@@ -354,7 +354,6 @@ def get_browser():
except CalledProcessError:
return 'firefox3'
-
# Per-tracker configuration variables
# ===================================
@@ -475,6 +474,28 @@ def resolve_bug_reference(bug_reference):
return host, https, id
+class CookieError(Exception):
+ pass
+
+def get_cookies_from_sqlite(host, cookies_sqlite, browser):
+ result = {}
+
+ connection = sqlite.connect(cookies_sqlite)
+ cursor = connection.cursor()
+ cursor.execute("select name,value,path,expiry from moz_cookies where host = :host", { 'host': host })
+
+ now = time.time()
+ for name,value,path,expiry in cursor.fetchall():
+ # Excessive caution: toss out values that need to be quoted in a cookie header
+ if float(expiry) > now and not re.search(r'[()<>@,;:\\"/\[\]?={} \t]', value):
+ result[name] = value
+ connection.close()
+
+ if not ('Bugzilla_login' in result and 'Bugzilla_logincookie' in result):
+ raise CookieError("You don't appear to be signed into %s; please log in with %s")
+
+ return result
+
def get_bugzilla_cookies_ff3(host):
profiles_dir = os.path.expanduser('~/.mozilla/firefox')
profile_path = None
@@ -490,67 +511,44 @@ def get_bugzilla_cookies_ff3(host):
profile_path = os.path.join(profiles_dir, cp.get(section, "Path").strip())
if not profile_path:
- die("Cannot find default Firefox profile")
+ raise CookieError("Cannot find default Firefox profile")
cookies_sqlite = os.path.join(profile_path, "cookies.sqlite")
if not os.path.exists(cookies_sqlite):
- die("%s doesn't exist. Perhaps try git config bz.browser."
- % cookies_sqlite)
+ raise CookieError("%s doesn't exist." % cookies_sqlite)
- result = {}
-
- connection = sqlite.connect(cookies_sqlite)
- cursor = connection.cursor()
- cursor.execute("select name,value,path,expiry from moz_cookies where host = :host", { 'host': host })
-
- now = time.time()
- for name,value,path,expiry in cursor.fetchall():
- # Excessive caution: toss out values that need to be quoted in a cookie header
- if float(expiry) > now and not re.search(r'[()<>@,;:\\"/\[\]?={} \t]', value):
- result[name] = value
- connection.close()
-
- if not ('Bugzilla_login' in result and 'Bugzilla_logincookie' in result):
- die("You don't appear to be signed into %s; "
- "please log in with Firefox or do 'git config bz.browser'"
- % host)
-
- return result
+ return get_cookies_from_sqlite(host, cookies_sqlite, "Firefox")
def get_bugzilla_cookies_epy(host):
ff_dir = os.path.expanduser('~/.gnome2/epiphany/mozilla/epiphany')
cookies_sqlite = os.path.join(ff_dir, "cookies.sqlite")
if not os.path.exists(cookies_sqlite):
- die("%s doesn't exist. Perhaps try git config bz.browser."
- % cookies_sqlite)
+ raise CookieError("%s doesn't exist" % cookies_sqlite)
- result = {}
+ return get_cookies_from_sqlite(host, cookies_sqlite, "Epiphany")
- connection = sqlite.connect(cookies_sqlite)
- cursor = connection.cursor()
- cursor.execute("select name,value,path,expiry from moz_cookies where host = :host", { 'host': host })
+browsers = { 'firefox3': get_bugzilla_cookies_ff3,
+ 'epiphany': get_bugzilla_cookies_epy }
- now = time.time()
- for name,value,path,expiry in cursor.fetchall():
- # Excessive caution: toss out values that need to be quoted in a cookie header
- if float(expiry) > now and not re.search(r'[()<>@,;:\\"/\[\]?={} \t]', value):
- result[name] = value
- connection.close()
-
- if not ('Bugzilla_login' in result and 'Bugzilla_logincookie' in result):
- die("You don't appear to be signed into %s; please log in with Epiphany" % host)
-
- return result
+def browser_list():
+ return ", ".join(sorted(browsers.keys()))
def get_bugzilla_cookies(host):
- d = {'firefox3': get_bugzilla_cookies_ff3,
- 'epiphany': get_bugzilla_cookies_epy}
browser = get_browser()
- if browser in d:
- do_get_cookies = d[browser]
+ if browser in browsers:
+ do_get_cookies = browsers[browser]
else:
- die('Unsupported browser %s (we only support %s)' % (browser, d.keys()))
- return do_get_cookies(host)
+ die('Unsupported browser %s (we only support %s)' % (browser, browser_list()))
+
+ try:
+ return do_get_cookies(host)
+ except CookieError, e:
+ die("""Error getting login cookie from browser:
+ %s
+
+Configured browser: %s (change with 'git config --global bz.browser <value>')
+Possible browsers: %s""" %
+ (str(e), browser, browser_list()))
# Based on http://code.activestate.com/recipes/146306/ - Wade Leftwich
def encode_multipart_formdata(fields, files):