c4ffd39478
This makes platform independence easier. There are some cases where we still use the yum module, where we use yum-specific module parameters. Also switch use of the state 'installed' to 'present', which is supported by all the package modules, whereas installed is supported by the yum module only. Change-Id: Id1cf845adc7aa6565a7a570569c9a81a478560f0
41 lines
1.4 KiB
YAML
41 lines
1.4 KiB
YAML
---
|
|
# Facts may not be available for the Ansible control host, so read the OS
|
|
# release manually.
|
|
- name: Check the OS release
|
|
local_action:
|
|
module: shell . /etc/os-release && echo $ID
|
|
changed_when: False
|
|
register: ip_allocation_os_release
|
|
|
|
- name: Include RedHat family-specific variables
|
|
include_vars: "RedHat.yml"
|
|
when: ip_allocation_os_release.stdout in ['centos', 'fedora', 'rhel']
|
|
|
|
- name: Include Debian family-specific variables
|
|
include_vars: "Debian.yml"
|
|
when: ip_allocation_os_release.stdout in ['debian', 'ubuntu']
|
|
|
|
# Note: Currently we install these using the system package manager rather than
|
|
# pip to a virtualenv. This is because Yum is required elsewhere and cannot
|
|
# easily be installed in a virtualenv.
|
|
- name: Ensure package dependencies are installed
|
|
local_action:
|
|
module: package
|
|
name: "{{ item }}"
|
|
state: present
|
|
use: "{{ ip_allocation_package_manager }}"
|
|
become: True
|
|
with_items: "{{ ip_allocation_package_dependencies }}"
|
|
run_once: True
|
|
|
|
- name: Ensure IP addresses are allocated
|
|
local_action:
|
|
module: ip_allocation
|
|
allocation_file: "{{ ip_allocation_filename }}"
|
|
hostname: "{{ ip_allocation_hostname }}"
|
|
net_name: "{{ item.net_name }}"
|
|
cidr: "{{ item.cidr }}"
|
|
allocation_pool_start: "{{ item.allocation_pool_start | default(omit) }}"
|
|
allocation_pool_end: "{{ item.allocation_pool_end | default(omit) }}"
|
|
with_items: "{{ ip_allocations }}"
|