Mercurial > hg
changeset 37996:0fa050bc68cb
phabricator: migrate [phabricator.auth] to [auth]
This resurrects the warning mechanism removed in 20a4543e9a2b. I'm not worried
about the copy/paste of the code for a brief transitional period.
author | Matt Harbison <matt_harbison@yahoo.com> |
---|---|
date | Sat, 12 May 2018 00:34:01 -0400 |
parents | 6f9ac3cb0987 |
children | 71cf20d47f25 |
files | contrib/phabricator.py |
diffstat | 1 files changed, 47 insertions(+), 13 deletions(-) [+] |
line wrap: on
line diff
--- a/contrib/phabricator.py Sat May 12 15:33:09 2018 +0900 +++ b/contrib/phabricator.py Sat May 12 00:34:01 2018 -0400 @@ -31,10 +31,10 @@ # the internal library. curlcmd = curl --connect-timeout 2 --retry 3 --silent - [phabricator.auth] + [auth] example.url = https://phab.example.com/ # API token. Get it from https://$HOST/conduit/login/ - example.token = cli-xxxxxxxxxxxxxxxxxxxxxxxxxxxx + example.phabtoken = cli-xxxxxxxxxxxxxxxxxxxxxxxxxxxx """ from __future__ import absolute_import @@ -100,17 +100,13 @@ process('', params) return util.urlreq.urlencode(flatparams) -def readurltoken(repo): - """return conduit url, token and make sure they exist +printed_token_warning = False - Currently read from [phabricator] config section. In the future, it might - make sense to read from .arcconfig and .arcrc as well. +def readlegacytoken(repo, url): + """Transitional support for old phabricator tokens. + + Remove before the 4.7 release. """ - url = repo.ui.config('phabricator', 'url') - if not url: - raise error.Abort(_('config %s.%s is required') - % ('phabricator', 'url')) - groups = {} for key, val in repo.ui.configitems('phabricator.auth'): if '.' not in key: @@ -128,9 +124,47 @@ if token: break + global printed_token_warning + + if token and not printed_token_warning: + printed_token_warning = True + repo.ui.warn(_('phabricator.auth.token is deprecated - please ' + 'migrate to auth.phabtoken.\n')) + return token + +def readurltoken(repo): + """return conduit url, token and make sure they exist + + Currently read from [phabricator] config section. In the future, it might + make sense to read from .arcconfig and .arcrc as well. + """ + url = repo.ui.config('phabricator', 'url') + if not url: + raise error.Abort(_('config %s.%s is required') + % ('phabricator', 'url')) + + groups = {} + for key, val in repo.ui.configitems('auth'): + if '.' not in key: + repo.ui.warn(_("ignoring invalid [auth] key '%s'\n") + % key) + continue + group, setting = key.rsplit('.', 1) + groups.setdefault(group, {})[setting] = val + + token = None + for group, auth in groups.iteritems(): + if url != auth.get('url'): + continue + token = auth.get('phabtoken') + if token: + break + if not token: - raise error.Abort(_('Can\'t find conduit token associated to %s') - % (url,)) + token = readlegacytoken(repo, url) + if not token: + raise error.Abort(_('Can\'t find conduit token associated to %s') + % (url,)) return url, token