| Index: depot-tools-auth.py
|
| diff --git a/depot-tools-auth.py b/depot-tools-auth.py
|
| new file mode 100755
|
| index 0000000000000000000000000000000000000000..3ebc239d8753b53911d59755a0f4fcd1b7eb83e1
|
| --- /dev/null
|
| +++ b/depot-tools-auth.py
|
| @@ -0,0 +1,102 @@
|
| +#!/usr/bin/env python
|
| +# Copyright 2015 The Chromium Authors. All rights reserved.
|
| +# Use of this source code is governed by a BSD-style license that can be
|
| +# found in the LICENSE file.
|
| +
|
| +"""Manages cached OAuth2 tokens used by other depot_tools scripts.
|
| +
|
| +Usage:
|
| + depot-tools-auth login codereview.chromium.org
|
| + depot-tools-auth info codereview.chromium.org
|
| + depot-tools-auth logout codereview.chromium.org
|
| +"""
|
| +
|
| +import logging
|
| +import optparse
|
| +import sys
|
| +
|
| +from third_party import colorama
|
| +
|
| +import auth
|
| +import subcommand
|
| +
|
| +__version__ = '1.0'
|
| +
|
| +
|
| +@subcommand.usage('<hostname>')
|
| +def CMDlogin(parser, args):
|
| + """Performs interactive login and caches authentication token."""
|
| + # Forcefully relogin, revoking previous token.
|
| + hostname, authenticator = parser.parse_args(args)
|
| + authenticator.logout()
|
| + authenticator.login()
|
| + print_token_info(hostname, authenticator)
|
| + return 0
|
| +
|
| +
|
| +@subcommand.usage('<hostname>')
|
| +def CMDlogout(parser, args):
|
| + """Revokes cached authentication token and removes it from disk."""
|
| + _, authenticator = parser.parse_args(args)
|
| + done = authenticator.logout()
|
| + print 'Done.' if done else 'Already logged out.'
|
| + return 0
|
| +
|
| +
|
| +@subcommand.usage('<hostname>')
|
| +def CMDinfo(parser, args):
|
| + """Shows email associated with a cached authentication token."""
|
| + # If no token is cached, AuthenticationError will be caught in 'main'.
|
| + hostname, authenticator = parser.parse_args(args)
|
| + print_token_info(hostname, authenticator)
|
| + return 0
|
| +
|
| +
|
| +def print_token_info(hostname, authenticator):
|
| + token_info = authenticator.get_token_info()
|
| + print 'Logged in to %s as %s.' % (hostname, token_info['email'])
|
| + print ''
|
| + print 'To login with a different email run:'
|
| + print ' depot-tools-auth login %s' % hostname
|
| + print 'To logout and purge the authentication token run:'
|
| + print ' depot-tools-auth logout %s' % hostname
|
| +
|
| +
|
| +class OptionParser(optparse.OptionParser):
|
| + def __init__(self, *args, **kwargs):
|
| + optparse.OptionParser.__init__(
|
| + self, *args, prog='depot-tools-auth', version=__version__, **kwargs)
|
| + self.add_option(
|
| + '-v', '--verbose', action='count', default=0,
|
| + help='Use 2 times for more debugging info')
|
| + auth.add_auth_options(self, auth.make_auth_config(use_oauth2=True))
|
| +
|
| + def parse_args(self, args=None, values=None):
|
| + """Parses options and returns (hostname, auth.Authenticator object)."""
|
| + options, args = optparse.OptionParser.parse_args(self, args, values)
|
| + levels = [logging.WARNING, logging.INFO, logging.DEBUG]
|
| + logging.basicConfig(level=levels[min(options.verbose, len(levels) - 1)])
|
| + auth_config = auth.extract_auth_config_from_options(options)
|
| + if len(args) != 1:
|
| + self.error('Expecting single argument (hostname).')
|
| + if not auth_config.use_oauth2:
|
| + self.error('This command is only usable with OAuth2 authentication')
|
| + return args[0], auth.get_authenticator_for_host(args[0], auth_config)
|
| +
|
| +
|
| +def main(argv):
|
| + dispatcher = subcommand.CommandDispatcher(__name__)
|
| + try:
|
| + return dispatcher.execute(OptionParser(), argv)
|
| + except auth.AuthenticationError as e:
|
| + print >> sys.stderr, e
|
| + return 1
|
| +
|
| +
|
| +if __name__ == '__main__':
|
| + colorama.init()
|
| + try:
|
| + sys.exit(main(sys.argv[1:]))
|
| + except KeyboardInterrupt:
|
| + sys.stderr.write('interrupted\n')
|
| + sys.exit(1)
|
|
|