summaryrefslogtreecommitdiffstats
path: root/xci/infra/bifrost/playbooks/xci-prepare-env.yml
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