heat_template_version: pike description: > OpenStack Ironic conductor configured with Puppet parameters: ServiceData: default: {} description: Dictionary packing service data type: json ServiceNetMap: default: {} description: Mapping of service_name -> network name. Typically set via parameter_defaults in the resource registry. This mapping overrides those in ServiceNetMapDefaults. type: json DefaultPasswords: default: {} type: json RoleName: default: '' description: Role name on which the service is applied type: string RoleParameters: default: {} description: Parameters specific to the role type: json EndpointMap: default: {} description: Mapping of service endpoint -> protocol. Typically set via parameter_defaults in the resource registry. type: json IronicCleaningDiskErase: default: 'full' description: Type of disk cleaning before and between deployments, "full" for full cleaning, "metadata" to clean only disk metadata (partition table). type: string IronicCleaningNetwork: default: 'provisioning' description: Name or UUID of the *overcloud* network used for cleaning bare metal nodes. The default value of "provisioning" can be left during the initial deployment (when no networks are created yet) and should be changed to an actual UUID in a post-deployment stack update. type: string IronicDefaultBootOption: default: 'local' description: How to boot the bare metal instances. Set to 'local' (the default) to use local bootloader (requires grub2 for partition images). Set to 'netboot' to make the instances boot from controllers using PXE/iPXE. type: string IronicDefaultNetworkInterface: default: 'flat' description: Network interface implementation to use by default. Set to "flat" (the default) to use one flat provider network. Set to "neutron" to make Ironic interact with the Neutron ML2 driver to enable other network types and certain advances networking features. Requires IronicProvisioningNetwork to be correctly set. type: string IronicEnabledDrivers: default: ['pxe_ipmitool', 'pxe_drac', 'pxe_ilo'] description: Enabled Ironic drivers type: comma_delimited_list IronicEnabledHardwareTypes: default: ['ipmi', 'redfish'] description: Enabled Ironic hardware types type: comma_delimited_list IronicEnabledManagementInterfaces: default: ['ipmitool', 'redfish'] description: Enabled management interface implementations. Each hardware type must have at least one valid implementation enabled. type: comma_delimited_list IronicEnabledPowerInterfaces: default: ['ipmitool', 'redfish'] description: Enabled power interface implementations. Each hardware type must have at least one valid implementation enabled. type: comma_delimited_list IronicIPXEEnabled: default: true description: Whether to use iPXE instead of PXE for deployment. type: boolean IronicIPXEPort: default: 8088 description: Port to use for serving images when iPXE is used. type: string IronicPassword: description: The password for the Ironic service and db account, used by the Ironic services type: string hidden: true IronicProvisioningNetwork: default: 'provisioning' description: Name or UUID of the *overcloud* network used for provisioning of bare metal nodes, if IronicDefaultNetworkInterface is set to "neutron". The default value of "provisioning" can be left during the initial deployment (when no networks are created yet) and should be changed to an actual UUID in a post-deployment stack update. type: string MonitoringSubscriptionIronicConductor: default: 'overcloud-ironic-conductor' type: string resources: IronicBase: type: ./ironic-base.yaml properties: ServiceData: {get_param: ServiceData} ServiceNetMap: {get_param: ServiceNetMap} DefaultPasswords: {get_param: DefaultPasswords} EndpointMap: {get_param: EndpointMap} RoleName: {get_param: RoleName} RoleParameters: {get_param: RoleParameters} outputs: role_data: description: Role data for the Ironic conductor role. value: service_name: ironic_conductor monitoring_subscription: {get_param: MonitoringSubscriptionIronicConductor} config_settings: map_merge: - get_attr: [IronicBase, role_data, config_settings] - ironic::conductor::api_url: {get_param: [EndpointMap, IronicInternal, uri_no_suffix]} ironic::conductor::cleaning_disk_erase: {get_param: IronicCleaningDiskErase} ironic::conductor::cleaning_network: {get_param: IronicCleaningNetwork} ironic::conductor::provisioning_network: {get_param: IronicProvisioningNetwork} ironic::conductor::default_boot_option: {get_param: IronicDefaultBootOption} ironic::conductor::enabled_drivers: {get_param: IronicEnabledDrivers} ironic::conductor::enabled_hardware_types: {get_param: IronicEnabledHardwareTypes} # We need an endpoint containing a real IP, not a VIP here ironic_conductor_http_host: {get_param: [ServiceNetMap, IronicNetwork]}