0869e7b756
At some point the Ironic iPXE configuration changed. The params now passed are full URLs and it is no longer necessary for us to write the beginning of the URL out. Additionally update the ownership of the boot.ipxe file so ironic is able to overwrite it. Far from ideal, but required at this time. Closes-Bug: #1490546 Closes-Bug: #1490557 Change-Id: I1a54ac6dce1497823795f896907663b44ebaa67d
54 lines
2.4 KiB
YAML
54 lines
2.4 KiB
YAML
# Copyright (c) 2015 Hewlett-Packard Development Company, L.P.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
# implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
---
|
|
- name: "Setting up PXE and iPXE folders"
|
|
file: name={{item}} owner=ironic group=ironic state=directory
|
|
with_items:
|
|
- /tftpboot
|
|
- /tftpboot/pxelinux.cfg
|
|
- "{{ http_boot_folder }}"
|
|
- name: "Placing tftpd map-file"
|
|
copy: src=tftpboot-map-file dest=/tftpboot/map-file owner=ironic group=ironic
|
|
- name: "Disable service tftpd-hpa"
|
|
service: name=tftpd-hpa state=stopped enabled=no
|
|
- name: "Set pxelinux.0 source (for Ubuntu >=14.10)"
|
|
set_fact:
|
|
syslinux_tftp_dir: '/usr/lib/PXELINUX'
|
|
when: ansible_distribution == 'Ubuntu' and ansible_distribution_version|version_compare('14.10', '>=')
|
|
- name: "Determine if pxelinux.0 is in place"
|
|
stat: path=/tftpboot/pxelinux.0
|
|
register: test_pxelinux
|
|
- name: "Placing pxelinux.0"
|
|
copy: src={{ syslinux_tftp_dir }}/pxelinux.0 dest=/tftpboot
|
|
when: test_pxelinux.stat.exists == false
|
|
- name: "Place boot.ipxe helper script to HTTP root"
|
|
copy: src=boot.ipxe dest=/httpboot/boot.ipxe owner=ironic group=ironic
|
|
- name: "Place tftp config file"
|
|
copy: src=xinetd.tftp dest=/etc/xinetd.d/tftp
|
|
- name: "Copy iPXE image into place"
|
|
copy: src={{ ipxe_dir }}/undionly.kpxe dest=/tftpboot/
|
|
# NOTE(TheJulia): Copy full iPXE chain loader images in case they are required.
|
|
- name: "Copy full iPXE image into /httpboot"
|
|
copy: src={{ ipxe_dir }}/{{ ipxe_full_binary }} dest=/httpboot/
|
|
- name: "Copy full iPXE image into /tftpboot"
|
|
copy: src={{ ipxe_dir }}/{{ ipxe_full_binary }} dest=/tftpboot/
|
|
# Similar logic to below can be utilized to retrieve files
|
|
- name: "Determine if folder exists, else create and populate folder."
|
|
stat: path=/tftpboot/master_images
|
|
register: test_master_images
|
|
- name: "Create master_images folder"
|
|
file: name=/tftpboot/master_images state=directory owner=ironic group=ironic
|
|
when: test_master_images.stat.exists == false
|