- Dependencies
- Requirements
- Role Variables
- defaults/main.yml
- vars/debian.yml
- vars/redhat.yml
- Example Group Variables for Supporting Roles
- Example Playbook
- License
- Author Information
This role is part of the ITC Automated Build Pods Project
Deploy and configure the Foreman server with smart-proxy managed TFTP and DHCP services.
The role itself has no dependencies and can be used to install a basic foreman server. However it is intended to be used as part of the ITC Automated Build Pods Project which requires additional Ansible roles and configurations.
- The initial configuration of the Foreman Smart-Proxy is handled using foreman-yml. This role supports configuration of DHCP, deployed via Ansible ISC DHCP Server Role and TFTP, deployed via Ansible TFTP Role.
- Extended configuration of the Foreman server is handled via Ansible Foreman Modules and should be handled via
group_vars
- If you wish to use Postgres or MySQL for the Foreman Database backend, you can deploy it in a container using this Ansible Docker Role. The default database is Postgres
- Proxied requests to the Foreman server and API are handled by NGINX, which is deployed using this Ansible NGINX Role.
www_domain: "{{ ansible_domain }}"
foreman_install_version: 1.23
foreman_plugins_version: 1.23
foreman_enable_service: True
foreman_hostname: "{{ ansible_hostname }}"
foreman_interface: 0.0.0.0
foreman_port: 3000
foreman_config_dir: /etc/foreman
foreman_admin_user: foreman
foreman_admin_password: "{{ vault_foreman_admin_password | default('password') }}"
foreman_env: production
foreman_runas_user: foreman
foreman_proxy_enable_service: True
foreman_proxy_config_dir: /etc/foreman-proxy
foreman_proxy_user: foreman-proxy
foreman_proxy_group: foreman-proxy
foreman_proxy_protocol: http
foreman_proxy_bind_host: "{{ ansible_default_ipv4.address }}"
foreman_proxy_port: 8000
foreman_proxy_foreman_url: http://127.0.0.1
foreman_proxy_dhcp: True
foreman_proxy_dhcp_protocol: http
foreman_proxy_dhcp_server: 127.0.0.1
foreman_proxy_dhcp_omapi_port: 7911
foreman_proxy_dhcp_subnets: []
foreman_proxy_httpboot: True
foreman_proxy_tftp: True
foreman_proxy_tftp_server: 127.0.0.1
foreman_proxy_tftp_protocol: http
foreman_proxy_tftp_dir: /srv/tftp
foreman_proxy_tftp_pxe_dir:
- boot
- pxelinux.cfg
foreman_db_adapter: postgresql
foreman_db_host: localhost
foreman_db_name: foreman
foreman_db_username: foreman
foreman_db_password: "{{ vault_foreman_db_password | default('password') }}"
foreman_db_timeout: 5000
foreman_db_pool: 5
foreman_db_sqlite_dir: /var/lib/foreman/db
foreman_yml_template: foreman_config.yml.j2
foreman_perform_rake_tasks: False
foreman_default_settings:
- name: "default_pxe_item_global"
value: "discovery"
- name: "update_ip_from_built_request"
value: "True"
- name: "token_duration"
value: "0"
- name: "discovery_auto"
value: "True"
- name: "safemode_render"
value: "False"
- name: "discovery_location"
value: "Default Location"
- name: "discovery_organization"
value: "Default Organization"
foreman_extra_settings: []
foreman_installation_mediums: []
foreman_operatingsystems: []
foreman_os_default_templates: []
foreman_hostgroups: []
foreman_global_parameters: []
foreman_gpg_key_url: https://deb.theforeman.org/pubkey.gpg
foreman_repo_url: http://deb.theforeman.org/
python_pip_pkg:
- python-pip
- python3-pip
foreman_python2_pkgs:
- apypie
- requests
- foreman-yml
- foreman
- PyYAML
- setuptools
foreman_python3_pkgs:
- apypie
- requests
- foreman
- PyYAML
- setuptools
foreman_dependency_pkgs:
- ca-certificates
- python-httplib2
- python3-httplib2
- python-apt
- python3-apt
- curl
- apt-transport-https
- wget
- syslinux-utils
- isolinux
foreman_pkgs:
- foreman
- foreman-libvirt
- foreman-console
- foreman-debug
- foreman-journald
- foreman-cli
- ruby-foreman
- ruby-hammer-cli
- ruby-hammer-cli-foreman
- ruby-hammer-cli-foreman-discovery
- ruby-hammer-cli-foreman-remote-execution
- ruby-hammer-cli-foreman-bootdisk
- ruby-hammer-cli-foreman-ansible
- ruby-powerbar
- ruby-foreman-templates
- ruby-foreman-cockpit
- ruby-foreman-tasks
- ruby-foreman-remote-execution
- ruby-foreman-discovery
- ruby-foreman-bootdisk
- ruby-foreman-dhcp-browser
foreman_proxy_pkgs:
- foreman-proxy
- foreman-proxy-journald
- ruby-smart-proxy-discovery
#- ruby-smart-proxy-remote-execution-ssh
foreman_proxy_extra_repos_pkg: []
foreman_proxy_dhcp_config_dir: /etc/dhcp
foreman_proxy_dhcp_config: /etc/dhcp/dhcpd.conf
foreman_proxy_dhcp_leases: /var/lib/dhcp/dhcpd.leases
foreman_db_sqlite_adapter_pkg: foreman-sqlite3
foreman_db_mysql_adapter_pkg: foreman-mysql2
foreman_db_pgsql_adapter_pkg: foreman-postgresql
foreman_db_socket: /var/run/mysqld/mysqld.sock
foreman_db_sqlite_adapter_pkg: foreman-sqlite
foreman_db_mysql_adapter_pkg: foreman-mysql2
foreman_db_pgsql_adapter_pkg: foreman-postgresql
foreman_db_socket: /var/lib/mysql/mysql.sock
python_pip_pkg: python-pip
foreman_dependency_pkgs:
- ca-certificates
- python-httplib2
- curl
- wget
- gcc
- python-devel
- python-setuptools
foreman_python_pkgs:
- apypie
- requests
- foreman-yml
- foreman
- PyYAML
foreman_pkgs:
- foreman
- foreman-libvirt
- foreman-console
- foreman-debug
- foreman-journald
- foreman-cli
- ruby-foreman
- ruby-hammer-cli
- ruby-hammer-cli-foreman
- ruby-hammer-cli-foreman-discovery
- ruby-hammer-cli-foreman-remote-execution
- ruby-powerbar
- ruby-foreman-templates
- ruby-foreman-tasks
- ruby-foreman-remote-execution
- ruby-foreman-discovery
- ruby-foreman-bootdisk
- ruby-foreman-dhcp-browser
foreman_proxy_pkgs:
- foreman-proxy
- foreman-proxy-journald
- ruby-smart-proxy-discovery
foreman_proxy_extra_repos_pkg: []
foreman_proxy_dhcp_config_dir: /etc/dhcp
foreman_proxy_dhcp_config: /etc/dhcp/dhcpd.conf
foreman_proxy_dhcp_leases: /var/lib/dhcp/dhcpd.leases
foreman_db_sqlite_adapter_pkg: foreman-sqlite3
foreman_db_mysql_adapter_pkg: foreman-mysql2
foreman_db_pgsql_adapter_pkg: foreman-postgresql
timezone: "America/Denver"
shared_storage: False
www_domain: lab.wwt.local
foreman_install_version: 1.24
foreman_plugins_version: 1.24
foreman_hostname: foreman
foreman_interface: 0.0.0.0
foreman_port: 3000
foreman_proxy_tftp: True
foreman_proxy_dhcp: True
foreman_db_name: foreman
foreman_db_username: foreman
foreman_db_password: "{{ vault_foreman_db_password }}"
foreman_admin_user: admin
foreman_admin_password: "{{ vault_foreman_admin_password }}"
foreman_env: production
foreman_extra_settings:
- name: "root_pass"
value: "{{ vault_foreman_admin_password }}"
foreman_global_parameters:
- name: remote_execution_ssh_keys
value: "{{ vault_ssh_pubkey }}"
- name: ansible_host_config_key
value: "16a4a143-0f6e-49b6-8051-fe135b6fdffa"
- name: "ansible_job_template_id"
value: 11
parameter_type: integer
- name: ansible_tower_fqdn
value: "{{ awx_web_url }}"
- name: cockpit_enabled
parameter_type: boolean
value: True
- name: ansible_tower_provisioning
parameter_type: boolean
value: True
foreman_proxy_dhcp_subnets:
- name: "10.0.10.0/24"
network: "10.0.10.0"
mask: "255.255.255.0"
gateway: "10.0.10.1"
from_ip: "10.0.10.240"
to_ip: "10.0.10.250"
mtu: 9000
domains:
- "{{ www_domain }}"
dns_primary: 10.0.10.1
foreman_installation_mediums:
- name: "Ubuntu mirror"
path: "http://archive.ubuntu.com/ubuntu"
os_family: Debian
foreman_operatingsystems:
- name: "Ubuntu"
description: "Ubuntu 18.04"
release_name: "bionic"
family: "Debian"
major: "18"
minor: "4"
provisioning_templates:
- "Preseed default iPXE"
- "Preseed default"
- "Preseed default PXELinux"
- "Preseed default finish"
- "Preseed default user data"
ptables:
- "Preseed default"
architectures:
- x86_64
media: "Ubuntu mirror"
foreman_os_default_templates:
- operatingsystem: "Ubuntu 18.04"
template_kind: "finish"
provisioning_template: "Preseed default finish"
- operatingsystem: "Ubuntu 18.04"
template_kind: "provision"
provisioning_template: "Preseed default"
- operatingsystem: "Ubuntu 18.04"
template_kind: "PXELinux"
provisioning_template: "Preseed default PXELinux"
- operatingsystem: "Ubuntu 18.04"
template_kind: "iPXE"
provisioning_template: "Preseed default iPXE"
- operatingsystem: "Ubuntu 18.04"
template_kind: "user_data"
provisioning_template: "Preseed default user data"
foreman_hostgroups:
- name: "kvm"
description: "KVM Hostgroup"
architecture: x86_64
operatingsystem: "Ubuntu 18.04"
medium: "Ubuntu mirror"
ptable: "Preseed default"
domain: "{{ www_domain }}"
subnet: "10.0.10.0/24"
nginx_backends:
- service: foreman
servers:
- localhost:3000
- service: awx
servers:
- localhost:8052
nginx_vhosts:
- servername: "{{ foreman_hostname | default(ansible_hostname) + '.' + www_domain | default(ansible_domain) }}"
serveralias: "{{ ansible_default_ipv4.address }} {{ ansible_fqdn }}"
serverlisten: 80
extra_parameters: |
error_page 404 /404.html;
error_page 500 502 503 504 /50x.html;
locations:
- name: /
proxy: True
backend: foreman
- name: 404.html
docroot: "/usr/share/nginx/html"
- name: 50x.html
docroot: "/usr/share/nginx/html"
- servername: "awx.home.prettybaked.com"
serveralias: "awx"
serverlisten: 80
locations:
- name: /
proxy: True
backend: awx
nginx_vhosts_ssl: []
docker_networks:
docker_awx:
ipam_config:
- subnet: 172.3.27.0/24
docker_containers:
postgres:
description: "Foreman Postgresql DB"
image: postgres:11
env:
PUID: '0'
PGID: '0'
VERSION: 'latest'
POSTGRES_USER: '{{ foreman_db_username }}'
POSTGRES_PASSWORD: '{{ vault_foreman_db_password }}'
POSTGRES_DB: '{{ foreman_db_name }}'
ports:
- '5432:5432'
volumes:
- '/etc/localtime:/etc/localtime:ro'
- '/var/lib/postgresql/data:/var/lib/postgresql/data'
awx_postgres:
description: AWX Postgres DB
image: postgres:10
hostname: postgres
networks:
- name: docker_awx
aliases: postgres
volumes:
- "{{ awx_postgres_data_dir }}/10/data/:/var/lib/postgresql/data/pgdata:Z"
env:
POSTGRES_USER: "{{ awx_pg_username }}"
POSTGRES_PASSWORD: "{{ awx_pg_password }}"
POSTGRES_DB: "{{ awx_pg_database }}"
PGDATA: "/var/lib/postgresql/data/pgdata"
http_proxy: "{{ http_proxy | default('') }}"
https_proxy: "{{ https_proxy | default('') }}"
no_proxy: "{{ no_proxy | default('') }}"
awx_rabbitmq:
description: AWX RabbitMQ Service
image: "{{ awx_rabbitmq_image }}"
volumes:
- '/etc/localtime:/etc/localtime:ro'
networks:
- name: docker_awx
aliases: rabbitmq
hostname: rabbitmq
env:
RABBITMQ_DEFAULT_VHOST: "{{ awx_rabbitmq_default_vhost }}"
RABBITMQ_DEFAULT_USER: "{{ awx_rabbitmq_user }}"
RABBITMQ_DEFAULT_PASS: "{{ awx_rabbitmq_password | quote }}"
RABBITMQ_ERLANG_COOKIE: "{{ awx_rabbitmq_erlang_cookie }}"
http_proxy: "{{ http_proxy | default('') }}"
https_proxy: "{{ https_proxy | default('') }}"
no_proxy: "{{ no_proxy | default('') }}"
awx_memcached:
description: AWX Memcached Service
image: "{{ awx_memcached_image }}:{{ awx_memcached_version }}"
hostname: "{{ awx_memcached_host }}"
networks:
- name: docker_awx
aliases: "{{ awx_memcached_host }}"
volumes:
- '/etc/localtime:/etc/localtime:ro'
env:
http_proxy: "{{ http_proxy | default('') }}"
https_proxy: "{{ https_proxy | default('') }}"
no_proxy: "{{ no_proxy | default('') }}"
awx:
description: AWX Service
image: "{{ awx_dockerhub_base }}/awx_task:{{ awx_dockerhub_version }}"
hostname: "{{ awx_task_hostname }}"
depends_on:
- docker-awx_memcached.service
- docker-awx_rabbitmq.service
- docker-awx_postgres.service
networks:
- name: docker_awx
aliases:
- task
- awx
links:
- awxweb:awx_web
- awxweb:web
user: root
volumes:
- "{{ awx_docker_compose_dir }}/SECRET_KEY:/etc/tower/SECRET_KEY"
- "{{ awx_docker_compose_dir }}/environment.sh:/etc/tower/conf.d/environment.sh"
- "{{ awx_docker_compose_dir }}/credentials.py:/etc/tower/conf.d/credentials.py"
- "{{ awx_project_data_dir }}:/var/lib/awx/projects:rw"
env:
http_proxy: "{{ http_proxy | default('') }}"
https_proxy: "{{ https_proxy | default('') }}"
no_proxy: "{{ no_proxy | default('') }}"
awxweb:
description: AWX Web Application
image: "{{ awx_dockerhub_base }}/awx_web:{{ awx_dockerhub_version }}"
depends_on:
- docker-awx_memcached.service
- docker-awx_rabbitmq.service
- docker-awx_postgres.service
ports:
- "{{ awx_host_port }}:8052"
networks:
- name: docker_awx
aliases:
- web
- awxweb
links:
- awx:awx_task
- awx:task
hostname: "{{ awx_web_hostname }}"
user: root
volumes:
- "{{ awx_docker_compose_dir }}/SECRET_KEY:/etc/tower/SECRET_KEY"
- "{{ awx_docker_compose_dir }}/environment.sh:/etc/tower/conf.d/environment.sh"
- "{{ awx_docker_compose_dir }}/credentials.py:/etc/tower/conf.d/credentials.py"
- "{{ awx_docker_compose_dir }}/nginx.conf:/etc/nginx/nginx.conf:ro"
- "{{ awx_project_data_dir }}:/var/lib/awx/projects:rw"
env:
http_proxy: "{{ http_proxy | default('') }}"
https_proxy: "{{ https_proxy | default('') }}"
no_proxy: "{{ no_proxy | default('') }}"
awx_host_port: 8080
awx_web_url: "http://{{ ansible_default_ipv4.address }}:{{ awx_host_port }}"
awx_project_data_dir: /var/lib/awx
awx_rabbitmq_erlang_cookie: "{{ vault_rabbitmq_erlang_cookie }}"
awx_rabbitmq_password: "{{ vault_rabbitmq_password }}"
awx_pg_password: "{{ vault_pg_password }}"
awx_pg_admin_password: "{{ vault_pg_admin_password }}"
awx_secret_key: "{{ vault_secret_key }}"
awx_admin_user: admin
awx_admin_password: "{{ vault_awx_admin_password }}"
sshd_permit_root_login: 'yes'
ssh_users:
ajanis:
password: "{{ vault_ajanis_pw }}"
cn: "Alan Janis"
givenname: "Alan"
sn: "Janis"
mail: "alan.janis@wwt.com"
shell: /bin/zsh
gecos: ajanis
uid: 1043
gid: 1042
pubkey: "{{ vault_ssh_pubkey }}"
state: present
wwt:
password: "{{ vault_wwt_pw }}"
cn: "WWT Admin"
givenname: "WWT"
sn: "Admin"
mail: "wwt@lab.wwt.local"
shell: /bin/bash
gecos: wwt
uid: 1044
gid: 1042
pubkey: "{{ vault_ssh_pubkey }}"
state: present
ssh_groups:
admin:
description: Administrators Group
gid: 1042
members:
- ajanis
users:
description: SSH Users Group
gid: 2002
members:
- ajanis
- wwt
NOTE: If foreman_proxy_dhcp_subnets
is defined, it will be used by the isc-dhcp-server role to configure dhcpd.conf, so you do not need to define your DHCP subnets again as isc_dhcp_server_subnets
- name: "Deploy Foreman Server"
hosts: buildhost
remote_user: root
vars_files:
- vault.yml
tasks:
- name: Wait for server to come online
wait_for_connection:
delay: 60
sleep: 10
connect_timeout: 5
timeout: 900
- include_role:
name: common
tags:
- common
- include_role:
name: isc_dhcp_server
public: yes
apply:
tags:
- dhcp
when: foreman_proxy_dhcp
tags:
- dhcp
- include_role:
name: tftp
public: yes
apply:
tags:
- tftp
when: foreman_proxy_tftp
tags:
- tftp
- include_role:
name: nginx
public: yes
apply:
tags:
- nginx
tags:
- nginx
- include_role:
name: awx
public: yes
apply:
tags:
- awx
tags:
- awx
- include_role:
name: docker
public: yes
apply:
tags:
- docker
tags:
- docker
- include_role:
name: awx
tasks_from: container-tasks.yml
public: yes
apply:
tags:
- awx
tags:
- awx
- include_role:
name: foreman
public: yes
tags:
- install
- configure
- foreman
- smartproxy
- customize
- include_role:
name: ansible-project
public: yes
tags:
- never
- project
- projectimport
- projectclone
MIT
Created by Alan Janis