diff options
author | Anderson Mesquita <andersonvom@gmail.com> | 2014-01-24 16:44:32 -0600 |
---|---|---|
committer | Richard Lee <rblee88@gmail.com> | 2014-02-20 10:56:11 -0600 |
commit | fa37be061cc19545550eace9531250e5209bb1be (patch) | |
tree | 99186530d1f45d3f9792a9b056d85d8b496f2ce8 /contrib/rackspace/resources/cloud_server.py | |
parent | 33c1be512b1680ba92b55ca00dfa385d48d4d6ca (diff) | |
download | heat-fa37be061cc19545550eace9531250e5209bb1be.tar.gz |
Fix resource mapping for Rackspace
resource_mapping() always returns all existing resource names and
their classes. available_resource_mapping() takes the dependencies
into account and only returns the ones whose dependencies have been
met.
Partial-Bug: #1271226
Change-Id: I3a7467e87f7ff81badd51f121ecea98f2924e506
Diffstat (limited to 'contrib/rackspace/resources/cloud_server.py')
-rw-r--r-- | contrib/rackspace/resources/cloud_server.py | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/contrib/rackspace/resources/cloud_server.py b/contrib/rackspace/resources/cloud_server.py index 6bff9f3f2..c571c651b 100644 --- a/contrib/rackspace/resources/cloud_server.py +++ b/contrib/rackspace/resources/cloud_server.py @@ -14,8 +14,8 @@ import socket import copy import tempfile -import paramiko from Crypto.PublicKey import RSA +import paramiko from heat.common import exception from heat.engine.resources import nova_utils @@ -26,12 +26,9 @@ from heat.openstack.common.gettextutils import _ try: import pyrax # noqa + PYRAX_INSTALLED = True except ImportError: - def resource_mapping(): - return {} -else: - def resource_mapping(): - return {'Rackspace::Cloud::Server': CloudServer} + PYRAX_INSTALLED = False logger = logging.getLogger(__name__) @@ -417,3 +414,13 @@ bash -x /var/lib/cloud/data/cfn-userdata > /root/cfn-userdata.log 2>&1 || if name == 'privateIPv4': return nova_utils.get_ip(self.server, 'private', 4) return super(CloudServer, self)._resolve_attribute(name) + + +def resource_mapping(): + return {'Rackspace::Cloud::Server': CloudServer} + + +def available_resource_mapping(): + if PYRAX_INSTALLED: + return resource_mapping() + return {} |