blob: bea8d126066eeed43916c8685b4e3afabfe5419d [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
storage_frontend_network_cidr:
type: string
storage_frontend_network:
type: string
storage_frontend_subnet_id:
type: string
storage_frontend_interface:
type: string
control_network_cidr:
type: string
ironic_baremetal_network:
type: string
ironic_baremetal_subnet_id:
type: string
ironic_baremetal_network_cidr:
type: string
ironic_baremetal_tunnel_cidr:
type: string
ironic_mt_enabled:
type: boolean
functions_override:
type: string
boot_timeout:
type: number
description: Boot timeout for instance
default: 3600
ucp_master_host:
type: string
default: ''
docker_ucp_image:
type: string
public_net_id:
type: string
default: ''
docker_ee_release:
type: string
docker_ee_url:
type: string
hardware_metadata:
description: The content of lab metadata.
type: string
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 ] }
$docker_ee_url: { get_param: docker_ee_url }
$docker_ee_release: { get_param: docker_ee_release }
$ucp_master_host: { get_param: ucp_master_host }
$docker_ucp_image: { get_param: docker_ucp_image }
$node_metadata: { get_param: metadata }
$control_network_cidr: { get_param: control_network_cidr }
$private_floating_interface: { get_param: private_floating_interface }
$private_floating_network_cidr: { get_param: private_floating_network_cidr }
$private_floating_interface_ip: { get_attr: [private_floating_server_port, fixed_ips, 0, ip_address] }
$functions_override: { get_param: functions_override }
$storage_frontend_interface: { get_param: storage_frontend_interface }
$storage_frontend_network_interface_ip: { get_attr: [storage_frontend_server_port, fixed_ips, 0, ip_address] }
$storage_frontend_network_cidr: { get_param: storage_frontend_network_cidr }
$ironic_baremetal_interface_ip: { get_attr: [ironic_baremetal_server_port, fixed_ips, 0, ip_address] }
$ironic_baremetal_network_cidr: { get_param: ironic_baremetal_network_cidr }
$ironic_baremetal_tunnel_cidr: { get_param: ironic_baremetal_tunnel_cidr }
$ironic_mt_enabled: { get_param: ironic_mt_enabled }
inject_files:
type: "OS::Heat::CloudConfig"
properties:
cloud_config:
write_files:
- path: /usr/sbin/prepare-metadata.py
owner: "root:root"
permissions: "0755"
content: {get_file: ../scripts/prepare-metadata.py}
- path: /usr/share/metadata/lab-metadata.yaml
owner: "root:root"
permissions: "0644"
content: { get_param: hardware_metadata}
install_config_agent:
type: "OS::Heat::MultipartMime"
properties:
parts:
- config: {get_resource: software_config}
- config: {get_resource: inject_files}
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.
# NOTE(vsaienko): ditto about ironic baremetal network
user_data_format: SOFTWARE_CONFIG
user_data: { get_resource: install_config_agent}
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 }
storage_frontend_server_port:
type: OS::Neutron::Port
properties:
network_id: { get_param: storage_frontend_network }
port_security_enabled: false
fixed_ips:
- subnet: { get_param: storage_frontend_subnet_id }
ironic_baremetal_server_port:
type: OS::Neutron::Port
properties:
network_id: { get_param: ironic_baremetal_network }
port_security_enabled: false
fixed_ips:
- subnet: { get_param: ironic_baremetal_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_ironic_baremetal_ip:
description: IP address of server in ironic baremetal network
value: { get_attr: [ironic_baremetal_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]}
wc_data:
description: Metadata from instance
value: { get_attr: [wait_condition, data]}