Add support for keypair-add command reading public key from stdin

If given filename is `-` for `--pub-key` option, reads public key
from stdin.

  $ cat id_rsa.pub | nova keypair-add --pub-key - keyname

Change-Id: Ib6dfe5a7b08d588868a923defb9ddd15fc28e01f
Closes-Bug: #1333476
This commit is contained in:
Natsuki Maruyama 2014-11-30 20:21:03 +09:00
parent 578390ee7e
commit 45000677ec
2 changed files with 19 additions and 7 deletions

View File

@ -2304,6 +2304,14 @@ class ShellTest(utils.TestCase):
'POST', '/os-keypairs', { 'POST', '/os-keypairs', {
'keypair': {'public_key': 'FAKE_PUBLIC_KEY', 'name': 'test'}}) 'keypair': {'public_key': 'FAKE_PUBLIC_KEY', 'name': 'test'}})
def test_keypair_stdin(self):
with mock.patch('sys.stdin', six.StringIO('FAKE_PUBLIC_KEY')):
self.run_command('keypair-add --pub-key - test')
self.assert_called(
'POST', '/os-keypairs', {
'keypair':
{'public_key': 'FAKE_PUBLIC_KEY', 'name': 'test'}})
def test_keypair_list(self): def test_keypair_list(self):
self.run_command('keypair-list') self.run_command('keypair-list')
self.assert_called('GET', '/os-keypairs') self.assert_called('GET', '/os-keypairs')

View File

@ -2865,13 +2865,17 @@ def do_keypair_add(cs, args):
pub_key = args.pub_key pub_key = args.pub_key
if pub_key: if pub_key:
if pub_key == '-':
pub_key = sys.stdin.read()
else:
try: try:
with open(os.path.expanduser(pub_key)) as f: with open(os.path.expanduser(pub_key)) as f:
pub_key = f.read() pub_key = f.read()
except IOError as e: except IOError as e:
raise exceptions.CommandError(_("Can't open or read '%(key)s': " raise exceptions.CommandError(
"%(exc)s") % {'key': pub_key, _("Can't open or read '%(key)s': %(exc)s")
'exc': e}) % {'key': pub_key, 'exc': e}
)
keypair = cs.keypairs.create(name, pub_key) keypair = cs.keypairs.create(name, pub_key)