blob: 166b510920cc8dd02ccde86f5a867868f4346931 [file] [log] [blame]
heat_template_version: queens
parameters:
metadata:
type: json
default: {}
node_type:
type: string
key_name:
type: string
description: Name of keypair to assign to servers
image:
type: string
description: Name of image to use for servers
flavor:
type: string
description: Flavor to use for servers
accessible_network:
type: string
accessible_subnet_id:
type: string
private_floating_network:
type: string
private_floating_network_cidr:
type: string
private_floating_subnet_id:
type: string
private_floating_interface:
type: string
host_interface:
type: string
functions_override:
type: string
boot_timeout:
type: number
description: Boot timeout for instance
default: 1200
ucp_master_host:
type: string
default: ''
public_net_id:
type: string
default: ''
resources:
software_config:
type: OS::Heat::SoftwareConfig
properties:
group: ungrouped
config:
str_replace:
template: { get_file: ../scripts/instance_boot.sh }
params:
$node_type: { get_param: node_type }
$wait_condition_notify: { get_attr: [ wait_handle, curl_cli ] }
$ucp_license_key: { get_file: ../scripts/license.lic }
$ucp_master_host: { get_param: ucp_master_host }
$node_metadata: { get_param: metadata }
$host_interface: { get_param: host_interface }
$private_floating_interface: { get_param: private_floating_interface }
$private_floating_network_cidr: { str_split: ['/', { get_param: private_floating_network_cidr }, 1] }
$private_floating_interface_ip: { get_attr: [private_floating_server_port, fixed_ips, 0, ip_address] }
$functions_override: { get_param: functions_override }
server:
type: OS::Nova::Server
properties:
image: { get_param: image }
flavor: { get_param: flavor }
key_name: { get_param: key_name }
availability_zone: nova
networks:
- network: { get_param: accessible_network }
# NOTE(ohryhorov): connect to accessible network only as ironic doesn't
# support multitenancy use-case. Use private_floating_network for IPAM only.
user_data_format: RAW
user_data: { get_resource: software_config }
metadata: { get_param: metadata }
private_floating_server_port:
type: OS::Neutron::Port
properties:
network_id: { get_param: private_floating_network }
port_security_enabled: false
fixed_ips:
- subnet: { get_param: private_floating_subnet_id }
wait_handle:
type: OS::Heat::WaitConditionHandle
wait_condition:
type: OS::Heat::WaitCondition
properties:
handle: { get_resource: wait_handle }
timeout: { get_param: boot_timeout }
outputs:
server_private_ip:
description: IP address of server in private network
value: { get_attr: [server, networks, { get_param: accessible_network}, 0]}
server_private_floating_ip:
description: IP address of server in private floating network
value: { get_attr: [private_floating_server_port, fixed_ips, 0, ip_address] }
server_public_ip:
description: Floating IP address of server in public network
value: { get_attr: [server, networks, { get_param: accessible_network}, 0]}