blob: d576324dc61ba2e541c8589d48e8992dac3a59ee (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
- name: Prepare deployment host
hosts: deployment_host
gather_facts: True
tasks:
- name: Ensure common private key has correct permissions
file:
path: "{{ xci_path }}/xci/scripts/vm/id_rsa_for_dib"
mode: "0600"
- name: Remove host from known_hosts file if necessary
shell:
ssh-keygen -R {{ hostvars['opnfv'].ip }}
failed_when: false
- name: Prepare the OPNFV host
hosts: opnfv
gather_facts: True
vars_files:
- "{{ xci_path }}/xci/var/opnfv.yml"
tasks:
- name: Configure SSH key for devuser
user:
name: devuser
generate_ssh_key: yes
ssh_key_bits: 2048
ssh_key_comment: xci
ssh_key_type: rsa
state: present
- name: Determine local user
become: no
local_action: command whoami
changed_when: False
register: _ansible_user
- name: Fetch local SSH key
delegate_to: localhost
become: no
slurp:
src: "/home/{{ _ansible_user.stdout }}/.ssh/id_rsa.pub"
register: _local_ssh_key
- name: "Configure {{ inventory_hostname }} authorized_keys file (devuser)"
authorized_key:
exclusive: no
user: devuser
state: present
manage_dir: yes
key: "{{ _local_ssh_key['content'] | b64decode }}"
comment: "deployer's key"
- name: "Configure {{ inventory_hostname }} authorized_keys file (root)"
authorized_key:
exclusive: no
user: root
state: present
manage_dir: yes
key: "{{ _local_ssh_key['content'] | b64decode }}"
comment: "deployer's key"
become: yes
- name: Ensure /httpboot directory exists
file:
path: /httpboot
state: directory
become: yes
# Directory must exist before passing the static config
- name: "Setup Inventory DHCP Hosts Directory"
file:
path: "/etc/dnsmasq.d/bifrost.dhcp-hosts.d"
state: directory
owner: "root"
group: "root"
mode: 0755
become: yes
- name: Copy bifrost files
copy:
src: "{{ item.src }}"
dest: "{{ item.dst }}"
with_items:
- { src: '/tmp/baremetal.json', dst: '/tmp/baremetal.json' }
- { src: '/tmp/baremetalstaticips', dst: '/etc/dnsmasq.d/bifrost.dhcp-hosts.d/baremetalstaticips' }
become: yes
- name: Copy original qcow2 image to OPNFV VM
synchronize:
src: "{{ xci_cache }}/{{ item }}"
dest: /httpboot/
recursive: yes
delete: yes
with_items:
- "deployment_image.qcow2"
- "deployment_image.qcow2.sha256.txt"
become: yes
- name: Configure DNS on openSUSE
block:
- stat:
path: /etc/resolv.conf.netconfig
register: _resolv_conf_netconfig
- shell: |
mv /etc/resolv.conf.netconfig /etc/resolv.conf
become: yes
when: _resolv_conf_netconfig.stat.exists
when: ansible_pkg_mgr == 'zypper'
#TODO: Find a way to do this with Ansible
- name: Make sure the default gateway is correct
shell: "ip route del default"
become: yes
#TODO: Find a way to do this with Ansible
- name: Make sure the default gateway is correct
shell: "ip route add default via {{ host_info[inventory_hostname].public.gateway }}"
become: yes
|