summaryrefslogtreecommitdiff
path: root/contrib/rackspace/resources/cloud_server.py
diff options
context:
space:
mode:
authorAnderson Mesquita <andersonvom@gmail.com>2014-01-24 16:44:32 -0600
committerRichard Lee <rblee88@gmail.com>2014-02-20 10:56:11 -0600
commitfa37be061cc19545550eace9531250e5209bb1be (patch)
tree99186530d1f45d3f9792a9b056d85d8b496f2ce8 /contrib/rackspace/resources/cloud_server.py
parent33c1be512b1680ba92b55ca00dfa385d48d4d6ca (diff)
downloadheat-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.py19
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 {}