Chris Yeoh a29b7c7cc7 Adds keypairs support for the Nova V3 API
Adds support and tests for the keypairs extension for
the Nova V3 API. The V3 version of the keypair extension
has been made part of the core V3 API and as a result no longer
has the "os-" prefix in the url.

Differences between the V2 and V3 API are described here:
https://wiki.openstack.org/wiki/NovaAPIv2tov3

Partially implements blueprint v3-api

Change-Id: Id4a77e1e4565f63ecdf7753d3c224975519fc07c
2013-12-19 23:40:00 +10:30

92 lines
2.8 KiB
Python

# Copyright 2011 OpenStack Foundation
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
"""
Keypair interface (1.1 extension).
"""
from novaclient import base
class Keypair(base.Resource):
"""
A keypair is a ssh key that can be injected into a server on launch.
"""
def __repr__(self):
return "<Keypair: %s>" % self.id
def _add_details(self, info):
dico = 'keypair' in info and \
info['keypair'] or info
for (k, v) in dico.items():
# NOTE(rpodolyaka): keypair name allows us to uniquely identify
# a specific keypair, while its id attribute
# is nothing more than an implementation
# detail. We can safely omit the id attribute
# here to ensure setattr() won't raise
# AttributeError trying to set read-only
# property id
if k != 'id':
setattr(self, k, v)
@property
def id(self):
return self.name
def delete(self):
self.manager.delete(self)
class KeypairManager(base.ManagerWithFind):
resource_class = Keypair
keypair_prefix = "os-keypairs"
def get(self, keypair):
"""
Get a keypair.
:param keypair: The ID of the keypair to get.
:rtype: :class:`Keypair`
"""
return self._get("/%s/%s" % (self.keypair_prefix, base.getid(keypair)),
"keypair")
def create(self, name, public_key=None):
"""
Create a keypair
:param name: name for the keypair to create
:param public_key: existing public key to import
"""
body = {'keypair': {'name': name}}
if public_key:
body['keypair']['public_key'] = public_key
return self._create('/%s' % self.keypair_prefix, body, 'keypair')
def delete(self, key):
"""
Delete a keypair
:param key: The :class:`Keypair` (or its ID) to delete.
"""
self._delete('/%s/%s' % (self.keypair_prefix, base.getid(key)))
def list(self):
"""
Get a list of keypairs.
"""
return self._list('/%s' % self.keypair_prefix, 'keypairs')