{"id":581,"sha1":"facd4fa24db8b83ed7c2745e3cfc4b4a732451e5","playbook":{"id":4,"items":{"plays":104,"tasks":1377,"results":1365,"hosts":2,"files":504,"records":0},"arguments":{"version":null,"verbosity":0,"private_key_file":null,"remote_user":null,"connection":"openstack.osa.ssh","timeout":null,"ssh_common_args":null,"sftp_extra_args":null,"scp_extra_args":null,"ssh_extra_args":null,"ask_pass":false,"connection_password_file":null,"force_handlers":true,"flush_cache":false,"become":false,"become_method":"sudo","become_user":null,"become_ask_pass":false,"become_password_file":null,"tags":["all"],"skip_tags":[],"check":false,"diff":false,"inventory":["/home/zuul/src/opendev.org/openstack/openstack-ansible/inventory/dynamic_inventory.py","/home/zuul/src/opendev.org/openstack/openstack-ansible/inventory/inventory.ini","/etc/openstack_deploy/inventory.ini"],"listhosts":false,"subset":null,"extra_vars":"Not saved by ARA as configured by 'ignored_arguments'","vault_ids":[],"ask_vault_pass":false,"vault_password_files":[],"forks":8,"module_path":null,"syntax":false,"listtasks":false,"listtags":false,"step":false,"start_at_task":null,"args":["setup-openstack.yml"]},"labels":[{"id":1,"name":"check:False"},{"id":2,"name":"tags:all"}],"started":"2025-12-08T13:39:52.478534Z","ended":"2025-12-08T14:14:54.510371Z","duration":"00:35:02.031837","name":null,"ansible_version":"2.18.6","client_version":"1.7.4","python_version":"3.12.3","server_version":"1.7.4","status":"failed","path":"/home/zuul/src/opendev.org/openstack/openstack-ansible/playbooks/setup-openstack.yml","controller":"aio1.openstack.local","user":"root"},"content":"---\n# Copyright 2017, Rackspace US, Inc.\n#\n# Licensed under the Apache License, Version 2.0 (the \"License\");\n# you may not use this file except in compliance with the License.\n# You may obtain a copy of the License at\n#\n#     http://www.apache.org/licenses/LICENSE-2.0\n#\n# Unless required by applicable law or agreed to in writing, software\n# distributed under the License is distributed on an \"AS IS\" BASIS,\n# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n# See the License for the specific language governing permissions and\n# limitations under the License.\n\n_ironic_api_is_first_play_host: >-\n  {{\n    (ironic_services['ironic-api']['group'] in group_names and\n      inventory_hostname == (groups[ironic_services['ironic-api']['group']] | select('in', ansible_play_hosts)) | first) | bool\n  }}\n_ironic_inspector_is_first_play_host: >-\n  {{\n    (ironic_services['ironic-inspector']['group'] in group_names and\n      inventory_hostname == (groups[ironic_services['ironic-inspector']['group']] | select('in', ansible_play_hosts)) | first) | bool\n  }}\n_ironic_oslomsg_rpc_vhost_conf: >-\n  {{\n    (ironic_oslomsg_rpc_vhost is string) | ternary(\n      ironic_oslomsg_rpc_vhost, ironic_oslomsg_rpc_vhost | selectattr('state', 'eq', 'present') | map(attribute='name') | first)\n  }}\n_ironic_oslomsg_notify_vhost_conf: >-\n  {{\n    (ironic_oslomsg_notify_vhost is string) | ternary(\n      ironic_oslomsg_notify_vhost, ironic_oslomsg_notify_vhost | selectattr('state', 'eq', 'present') | map(attribute='name') | first)\n  }}\n_ironic_inspector_oslomsg_rpc_vhost_conf: >-\n  {{\n    (ironic_inspector_oslomsg_rpc_vhost is string) | ternary(\n      ironic_inspector_oslomsg_rpc_vhost, ironic_inspector_oslomsg_rpc_vhost | selectattr('state', 'eq', 'present') | map(attribute='name') | first)\n  }}\n# This special list brings together all of the package installations into one\n# task to save time.\n\nironic_driver_types:\n  no_driver:\n    inspect: no-inspect\n    console: no-console\n    raid: no-raid\n  agent_ilo:\n    hardware_type: ilo\n    boot: ilo-virtual-media\n    deploy: direct\n    inspect: ilo\n    management: ilo\n    power: ilo\n    console: ilo\n    raid: agent\n  agent_ipmitool:\n    hardware_type: ipmi\n    boot: pxe\n    deploy: direct\n    inspect: inspector\n    management: ipmitool\n    power: ipmitool\n    console: no-console\n    raid: agent\n  agent_ipmitool_socat:\n    hardware_type: ipmi\n    boot: pxe\n    deploy: direct\n    inspect: inspector\n    management: ipmitool\n    power: ipmitool\n    console: ipmitool-socat\n    raid: agent\n  agent_irmc:\n    hardware_type: irmc\n    boot: irmc-virtual-media\n    deploy: direct\n    inspect: irmc\n    management: irmc\n    power: irmc\n    console: ipmitool-socat\n    raid: irmc\n  pxe_drac:\n    hardware_type: idrac\n    boot: pxe\n    deploy: direct\n    inspect: idrac-redfish\n    management: idrac-redfish\n    power: idrac-redfish\n    console: no-console\n    raid: idrac-redfish\n  pxe_drac_inspector:\n    hardware_type: idrac\n    boot: pxe\n    deploy: direct\n    inspect: inspector\n    management: idrac-redfish\n    power: idrac-redfish\n    console: no-console\n    raid: idrac-redfish\n  pxe_ilo:\n    hardware_type: ilo\n    boot: ilo-pxe\n    deploy: direct\n    inspect: ilo\n    management: ilo\n    power: ilo\n    console: ilo\n    raid: ilo\n  pxe_ipmitool:\n    hardware_type: ipmi\n    boot: pxe\n    deploy: direct\n    inspect: inspector\n    management: ipmitool\n    power: ipmitool\n    console: no-console\n    raid: no-raid\n  pxe_ipmitool_socat:\n    hardware_type: ipmi\n    boot: pxe\n    deploy: direct\n    inspect: inspector\n    management: ipmitool\n    power: ipmitool\n    console: ipmitool-socat\n    raid: no-raid\n  pxe_irmc:\n    hardware_type: irmc\n    boot: irmc-pxe\n    deploy: direct\n    inspect: irmc\n    management: irmc\n    power: irmc\n    console: ipmitool-socat\n    raid: irmc\n  pxe_snmp:\n    hardware_type: snmp\n    boot: pxe\n    deploy: direct\n    inspect: no-inspect\n    management: fake\n    power: snmp\n    console: no-console\n    raid: no-raid\n  pxe_redfish:\n    hardware_type: redfish\n    boot: pxe\n    deploy: direct\n    inspect: redfish\n    management: redfish\n    power: redfish\n    console: no-console\n    raid: no-raid\n\nironic_packages_list: |-\n  {%- set package_list = [] %}\n  {%- if ironic_services['ironic-api']['group'] in group_names %}\n  {%-   set package_list = package_list + ironic_api_distro_packages %}\n  {%- endif %}\n  {%- if ironic_services['ironic-conductor']['group'] in group_names %}\n  {%-   set package_list = package_list + ironic_conductor_distro_packages %}\n  {%-   if ironic_standalone | bool %}\n  {%-     set package_list = package_list + ironic_conductor_standalone_distro_packages %}\n  {%-   endif %}\n  {%- endif %}\n  {%- if ironic_inspector_dhcp_type == \"dnsmasq\" %}\n  {%-   set package_list = package_list + ironic_inspector_dnsmasq_distro_packages %}\n  {%- else %}\n  {%-   set package_list = package_list + ironic_inspector_isc_dhcp_distro_packages %}\n  {%- endif %}\n  {%- if ironic_inspector_boot_mode == \"http\" %}\n  {%-   set package_list = package_list + ironic_inspector_http_distro_packages %}\n  {%- endif %}\n  {%- if 'ipmitool-socat' in (filtered_ironic_drivers | json_query('[*].console') | unique) %}\n  {%-   set package_list = package_list + ironic_ipmitool_socat_distro_packages %}\n  {%- endif %}\n  {{- package_list -}}\n\nironic_service_user_list: >\n  {%- set service_user_list = [] %}\n  {%- if ironic_services['ironic-api']['group'] in group_names %}\n  {%-   set _ = service_user_list.append(\n          {\n            'name': ironic_service_user_name,\n            'password': ironic_service_password,\n            'role': ironic_service_role_names\n          }\n        )\n  %}\n  {%- endif %}\n  {%- if ironic_services['ironic-inspector']['group'] in group_names %}\n  {%-   set _ = service_user_list.append(\n          {\n            'name': ironic_inspector_service_user_name,\n            'password': ironic_inspector_service_password,\n            'role': ironic_inspector_service_role_names\n          }\n        )\n  %}\n  {%- endif %}\n  {{- service_user_list -}}\n\nironic_service_endpoint_list: >\n  {%- set service_endpoint_list = [] %}\n  {%- if ironic_services['ironic-api']['group'] in group_names %}\n  {%-   set _ = service_endpoint_list.append(\n          {\n            'service': ironic_service_name,\n            'interface': 'public',\n            'url': ironic_service_publicurl\n          }\n        )\n  %}\n  {%-   set _ = service_endpoint_list.append(\n          {\n            'service': ironic_service_name,\n            'interface': 'internal',\n            'url': ironic_service_internalurl\n          }\n        )\n  %}\n  {%-   set _ = service_endpoint_list.append(\n          {\n            'service': ironic_service_name,\n            'interface': 'admin',\n            'url': ironic_service_adminurl\n          }\n        )\n  %}\n  {%- endif %}\n  {%- if ironic_services['ironic-inspector']['group'] in group_names %}\n  {%-   set _ = service_endpoint_list.append(\n          {\n            'service': ironic_inspector_service_name,\n            'interface': 'public',\n            'url': ironic_inspector_service_publicurl\n          }\n        )\n  %}\n  {%-   set _ = service_endpoint_list.append(\n          {\n            'service': ironic_inspector_service_name,\n            'interface': 'internal',\n            'url': ironic_inspector_service_internalurl\n          }\n        )\n  %}\n  {%-   set _ = service_endpoint_list.append(\n          {\n            'service': ironic_inspector_service_name,\n            'interface': 'admin',\n            'url': ironic_inspector_service_adminurl\n          }\n        )\n  %}\n  {%- endif %}\n  {{- service_endpoint_list -}}\n\nironic_service_catalog_list: >\n  {%- set service_catalog_list = [] %}\n  {%- if ironic_services['ironic-api']['group'] in group_names %}\n  {%-   set _ = service_catalog_list.append(\n          {\n            'name': ironic_service_name,\n            'type': ironic_service_type,\n            'description': ironic_service_description\n          }\n        )\n  %}\n  {%- endif %}\n  {%- if ironic_services['ironic-inspector']['group'] in group_names %}\n  {%-   set _ = service_catalog_list.append(\n          {\n            'name': ironic_inspector_service_name,\n            'type': ironic_inspector_service_type,\n            'description': ironic_inspector_service_description\n          }\n        )\n  %}\n  {%- endif %}\n  {{- service_catalog_list -}}\n\nfiltered_ironic_services: |-\n  {% set services = [] %}\n  {% for key, value in ironic_services.items() %}\n  {%   if (value['group'] in group_names) and\n          (('service_en' not in value) or\n           ('service_en' in value and value['service_en'])) and\n           not ('wsgi_app' in value and value['wsgi_app']) %}\n  {%     set _ = value.update(\n           {\n             'service_key': key,\n             'enabled': value['enabled'] | default(True),\n             'state': value['state'] | default('started'),\n             'config_overrides': value.init_config_overrides\n           }\n         )\n  %}\n  {%     set _ = value.pop('init_config_overrides') %}\n  {# Note (noonedeadpunk): The following if statement is added for backwards compatibility #}\n  {# As up to train release ironic role didn't have 'execstarts' in ironic_services keys #}\n  {%     if ('execstarts' not in value) %}\n  {%       set _ = value.update({'execstarts': value.program_override | default(ironic_bin ~ '/' ~ value.service_name)}) %}\n  {%     endif %}\n  {%     set _ = services.append(value) %}\n  {%   endif %}\n  {% endfor %}\n  {{ services }}\n\nuwsgi_ironic_services: |-\n  {% set services = {} %}\n  {% for key, value in ironic_services.items() %}\n  {%   if (value['group'] in group_names) and\n         (('condition' not in value) or ('condition' in value and value['condition']))\n         and ('wsgi_app' in value and value['wsgi_app']) %}\n  {%     set _ = value.update(\n            {\n             'wsgi_venv': ironic_bin | dirname,\n             'uwsgi_uid': ironic_system_user_name,\n             'uwsgi_guid': ironic_system_group_name,\n             'uwsgi_processes': ironic_wsgi_processes,\n             'uwsgi_threads': ironic_wsgi_threads\n           }\n         ) %}\n  {%     set _ = services.update({key: value}) %}\n  {%   endif %}\n  {% endfor %}\n  {{ services }}\n\nfiltered_ironic_drivers: |-\n  {% if ironic_ipxe_enabled | bool %}\n  {% set concat_drivers = [{'boot': 'ipxe'}] %}\n  {% else %}\n  {% set concat_drivers = [] %}\n  {% endif %}\n  {% set _driver_types = ironic_driver_types | combine(ironic_user_driver_types, recursive=True) %}\n  {% for driver in ironic_drivers_enabled %}\n  {%   if driver in _driver_types.keys() %}\n  {%     set _ = concat_drivers.append(_driver_types[driver]) %}\n  {%   endif %}\n  {% endfor %}\n  {{ concat_drivers }}\n\nironic_venv_packages: |-\n  {%- set pkg_list = ironic_pip_packages %}\n  {%- set _ = pkg_list.extend(ironic_user_pip_packages) %}\n  {%- set _ = pkg_list.extend(ironic_inspector_pip_packages) %}\n  {%- set _ = pkg_list.extend(ironic_inspector_user_pip_packages) %}\n  {{- pkg_list | unique }}\n\nironic_ipmitool_socat_distro_packages:\n  - socat\n","created":"2025-12-08T13:40:04.878529Z","updated":"2025-12-08T13:40:04.878567Z","path":"/home/zuul/src/opendev.org/openstack/openstack-ansible-os_ironic/vars/main.yml"}