Use HOT instead of CFN heat template format
New Heaet features will get added to HOT but possibly not the older CFN format, and it's easier to make the change now than later. The only code change is in heat_stack to look for 'resources' instead of 'Resources'; all other changes are to the Heat template sections within PL class definitions. Keys are lower-cased and in some cases changed to match HOT (e.g. key_name instead of KeyName), and sections specifying Heat resources add heat_template_version to the template. Implements blueprint replace-cfn-templates-with-hot Change-Id: If4d34cd25a4e964d7555fedf218512d5c0f5615c
This commit is contained in:
parent
b91a329625
commit
b7626aa140
@ -61,18 +61,19 @@ Workflow:
|
|||||||
- $.ensureNetworkConfigured()
|
- $.ensureNetworkConfigured()
|
||||||
- $portname: $instance.name + '-port-to-' + $.id()
|
- $portname: $instance.name + '-port-to-' + $.id()
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
heat_template_version: '2013-05-23'
|
||||||
|
resources:
|
||||||
$portname:
|
$portname:
|
||||||
Type: 'OS::Neutron::Port'
|
type: 'OS::Neutron::Port'
|
||||||
Properties:
|
properties:
|
||||||
network_id: {Ref: $.net_res_name}
|
network_id: { get_resource: $.net_res_name }
|
||||||
fixed_ips: [{subnet_id: {Ref: $.subnet_res_name}}]
|
fixed_ips: [{ subnet_id: { get_resource: $.subnet_res_name } }]
|
||||||
security_groups:
|
security_groups:
|
||||||
- Ref: $securityGroupName
|
- get_resource: $securityGroupName
|
||||||
$instance.name:
|
$instance.name:
|
||||||
Properties:
|
properties:
|
||||||
NetworkInterfaces:
|
networks:
|
||||||
- Ref: $portname
|
- port: { get_resource: $portname }
|
||||||
- $.environment.stack.updateTemplate($template)
|
- $.environment.stack.updateTemplate($template)
|
||||||
|
|
||||||
- If: $assignFloatingIp
|
- If: $assignFloatingIp
|
||||||
@ -82,25 +83,23 @@ Workflow:
|
|||||||
Then:
|
Then:
|
||||||
- $fip_name: $instance.name + '-FloatingIP-' + $.id()
|
- $fip_name: $instance.name + '-FloatingIP-' + $.id()
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
resources:
|
||||||
$fip_name:
|
$fip_name:
|
||||||
Type: 'OS::Neutron::FloatingIP'
|
type: 'OS::Neutron::FloatingIP'
|
||||||
Properties:
|
properties:
|
||||||
floating_network_id: $extNetId
|
floating_network_id: $extNetId
|
||||||
$instance.name + '-FloatingIpAssoc-' + $.id():
|
$instance.name + '-FloatingIpAssoc-' + $.id():
|
||||||
Type: 'OS::Neutron::FloatingIPAssociation'
|
type: 'OS::Neutron::FloatingIPAssociation'
|
||||||
Properties:
|
properties:
|
||||||
floatingip_id:
|
floatingip_id:
|
||||||
Ref: $fip_name
|
get_resource: $fip_name
|
||||||
port_id:
|
port_id:
|
||||||
Ref: $portname
|
get_resource: $portname
|
||||||
Outputs:
|
outputs:
|
||||||
$instance.name + '-FloatingIPaddress':
|
$instance.name + '-FloatingIPaddress':
|
||||||
Value:
|
value:
|
||||||
Fn::GetAtt:
|
get_attr: [$fip_name, floating_ip_address]
|
||||||
- $fip_name
|
description: Floating IP assigned
|
||||||
- floating_ip_address
|
|
||||||
Description: Floating IP assigned
|
|
||||||
- $.environment.stack.updateTemplate($template)
|
- $.environment.stack.updateTemplate($template)
|
||||||
|
|
||||||
ensureNetworkConfigured:
|
ensureNetworkConfigured:
|
||||||
@ -132,21 +131,23 @@ Workflow:
|
|||||||
createNetwork:
|
createNetwork:
|
||||||
Body:
|
Body:
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
heat_template_version: '2013-05-23'
|
||||||
|
resources:
|
||||||
$.net_res_name:
|
$.net_res_name:
|
||||||
Type: 'OS::Neutron::Net'
|
type: 'OS::Neutron::Net'
|
||||||
Properties:
|
properties:
|
||||||
name: $.name
|
name: $.name
|
||||||
- $.environment.stack.updateTemplate($template)
|
- $.environment.stack.updateTemplate($template)
|
||||||
|
|
||||||
createSubnet:
|
createSubnet:
|
||||||
Body:
|
Body:
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
heat_template_version: '2013-05-23'
|
||||||
|
resources:
|
||||||
$.subnet_res_name:
|
$.subnet_res_name:
|
||||||
Type: 'OS::Neutron::Subnet'
|
type: 'OS::Neutron::Subnet'
|
||||||
Properties:
|
properties:
|
||||||
network_id: {Ref: $.net_res_name}
|
network_id: { get_resource: $.net_res_name }
|
||||||
ip_version: 4
|
ip_version: 4
|
||||||
dns_nameservers: [ $.dnsNameserver ]
|
dns_nameservers: [ $.dnsNameserver ]
|
||||||
cidr: $.subnetCidr
|
cidr: $.subnetCidr
|
||||||
@ -155,10 +156,11 @@ Workflow:
|
|||||||
createRouterInterface:
|
createRouterInterface:
|
||||||
Body:
|
Body:
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
heat_template_version: '2013-05-23'
|
||||||
|
resources:
|
||||||
$.name + '-ri-' + $.id():
|
$.name + '-ri-' + $.id():
|
||||||
Type: 'OS::Neutron::RouterInterface'
|
type: 'OS::Neutron::RouterInterface'
|
||||||
Properties:
|
properties:
|
||||||
router_id: $.externalRouterId
|
router_id: $.externalRouterId
|
||||||
subnet_id: {Ref: $.subnet_res_name}
|
subnet_id: { get_resource: $.subnet_res_name }
|
||||||
- $.environment.stack.updateTemplate($template)
|
- $.environment.stack.updateTemplate($template)
|
||||||
|
@ -36,10 +36,11 @@ Workflow:
|
|||||||
|
|
||||||
- $stack: $.environment.stack
|
- $stack: $.environment.stack
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
heat_template_version: '2013-05-23'
|
||||||
|
resources:
|
||||||
$groupName:
|
$groupName:
|
||||||
Type: 'OS::Neutron::SecurityGroup'
|
type: 'OS::Neutron::SecurityGroup'
|
||||||
Properties:
|
properties:
|
||||||
description: format('Composite security group of Murano environment {0}', $.environment.name)
|
description: format('Composite security group of Murano environment {0}', $.environment.name)
|
||||||
rules:
|
rules:
|
||||||
- port_range_min: null
|
- port_range_min: null
|
||||||
@ -56,10 +57,10 @@ Workflow:
|
|||||||
))
|
))
|
||||||
|
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
resources:
|
||||||
$groupName:
|
$groupName:
|
||||||
Type: 'OS::Neutron::SecurityGroup'
|
type: 'OS::Neutron::SecurityGroup'
|
||||||
Properties:
|
properties:
|
||||||
rules: $ingress
|
rules: $ingress
|
||||||
- $.environment.stack.updateTemplate($template)
|
- $.environment.stack.updateTemplate($template)
|
||||||
|
|
||||||
|
@ -69,20 +69,22 @@ Workflow:
|
|||||||
- $userData: $.prepareUserData()
|
- $userData: $.prepareUserData()
|
||||||
|
|
||||||
- $template:
|
- $template:
|
||||||
Resources:
|
heat_template_version: '2013-05-23'
|
||||||
|
resources:
|
||||||
$.name:
|
$.name:
|
||||||
Type: 'AWS::EC2::Instance'
|
type: 'OS::Nova::Server'
|
||||||
Properties:
|
properties:
|
||||||
InstanceType: $.flavor
|
flavor: $.flavor
|
||||||
ImageId: $.image
|
image: $.image
|
||||||
UserData: $userData
|
user_data: $userData
|
||||||
KeyName: $.keyname
|
key_name: $.keyname
|
||||||
|
|
||||||
|
|
||||||
Outputs:
|
outputs:
|
||||||
format('{0}-PublicIp', $.name):
|
format('{0}-PublicIp', $.name):
|
||||||
Value:
|
description: format('Public IP assigned to {0} instance', $.name)
|
||||||
- Fn::GetAtt: [$.name, PublicIp]
|
value:
|
||||||
|
get_attr: [$.name, PublicIp]
|
||||||
- $.environment.stack.updateTemplate($template)
|
- $.environment.stack.updateTemplate($template)
|
||||||
- $.environment.stack.push()
|
- $.environment.stack.push()
|
||||||
- $outputs: $.environment.stack.output()
|
- $outputs: $.environment.stack.output()
|
||||||
|
@ -165,7 +165,9 @@ class HeatStack(murano_object.MuranoObject):
|
|||||||
|
|
||||||
current_status = self._get_status()
|
current_status = self._get_status()
|
||||||
if current_status == 'NOT_FOUND':
|
if current_status == 'NOT_FOUND':
|
||||||
if self._template.get('Resources'):
|
# For now, allow older CFN style templates as well, but this
|
||||||
|
# should be removed to avoid mixing them
|
||||||
|
if 'resources' in self._template or 'Resources' in self._template:
|
||||||
self._heat_client.stacks.create(
|
self._heat_client.stacks.create(
|
||||||
stack_name=self._name,
|
stack_name=self._name,
|
||||||
parameters=self._parameters,
|
parameters=self._parameters,
|
||||||
@ -175,7 +177,9 @@ class HeatStack(murano_object.MuranoObject):
|
|||||||
self._wait_state(
|
self._wait_state(
|
||||||
lambda status: status == 'CREATE_COMPLETE')
|
lambda status: status == 'CREATE_COMPLETE')
|
||||||
else:
|
else:
|
||||||
if self._template.get('Resources'):
|
# For now, allow older CFN style templates as well, but this
|
||||||
|
# should be removed to avoid mixing them
|
||||||
|
if 'resources' in self._template or 'Resources' in self._template:
|
||||||
self._heat_client.stacks.update(
|
self._heat_client.stacks.update(
|
||||||
stack_id=self._name,
|
stack_id=self._name,
|
||||||
parameters=self._parameters,
|
parameters=self._parameters,
|
||||||
|
Loading…
Reference in New Issue
Block a user