Files @ 1cc95d998f7c
Branch filter:

Location: majic-ansible-roles/roles/php_website/molecule/default/prepare.yml - annotation

branko
MAR-197: Implement collapsible environment indicator for web server role.
92011aae7258
92011aae7258
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
dfc058f43e70
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
7dd7757be724
92011aae7258
92011aae7258
14eb78a4f466
92011aae7258
92011aae7258
e75d5d4fba3b
14eb78a4f466
14eb78a4f466
92011aae7258
92011aae7258
14eb78a4f466
92011aae7258
92011aae7258
92011aae7258
92011aae7258
14eb78a4f466
14eb78a4f466
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
14eb78a4f466
92011aae7258
92011aae7258
92011aae7258
92011aae7258
14eb78a4f466
92011aae7258
92011aae7258
92011aae7258
92011aae7258
14eb78a4f466
92011aae7258
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
12eceb5941eb
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
92011aae7258
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
ff510f233909
---

- name: Set-up fixtures
  hosts: localhost
  connection: local
  gather_facts: false
  tasks:

    - name: Initialise CA hierarchy
      command: "gimmecert init"
      args:
        creates: ".gimmecert/ca/level1.cert.pem"
        chdir: "tests/data/"

    - name: Generate server private keys and certificates
      command:
      args:
        chdir: "tests/data/"
        creates: ".gimmecert/server/{{ item.name }}.cert.pem"
        argv:
          - "gimmecert"
          - "server"
          - "{{ item.name }}"
          - "{{ item.fqdn }}"
      with_items:
        - name: parameters-mandatory_https
          fqdn: parameters-mandatory
        - name: parameters-optional_https
          fqdn: parameters-optional.local
        - name: php-website_https
          fqdn: php-website

    - name: Set-up link to generated X.509 material
      file:
        src: ".gimmecert"
        dest: "tests/data/x509"
        state: link

- name: Prepare
  hosts: all
  gather_facts: false
  tasks:
    - name: Install python for Ansible
      raw: test -e /usr/bin/python3 || (apt -y update && apt install -y python3-minimal)
      become: true
      changed_when: false

- hosts: all
  become: true
  tasks:

    - name: Update all caches to avoid errors due to missing remote archives
      apt:
        update_cache: true
      changed_when: false

    - name: Set-up /etc/hosts entries
      lineinfile:
        dest: /etc/hosts
        line: "{{ ansible_eth0.ipv4.address }} parameters-mandatory parameters-optional.local php-website"

    - name: Install curl for testing redirects and webpage content
      apt:
        name: curl
        state: present

    - name: Install swaks for testing mail forwarding
      apt:
        name: swaks
        state: present

    - name: Install Postfix for testing mail forwarding (Exim4 not covered)
      apt:
        name: postfix
        state: present

    - name: Install procmail for consistency with mail_server and mail_forwarder roles
      apt:
        name: procmail
        state: present

    - name: Update Postfix configuration
      lineinfile:
        path: /etc/postfix/main.cf
        regexp: "^{{ item.key }}"
        line: "{{ item.value }}"
        state: present
      with_dict:
        myhostname: "myhostname = {{ inventory_hostname }}"
        mailbox_command: 'mailbox_command = procmail -a "$EXTENSION"'
      notify:
        - Restart Postfix

    - name: Direct all mails from the root account to vagrant
      lineinfile:
        path: /etc/aliases
        regexp: "^root"
        line: "root: vagrant"
        state: present
      notify:
        - Generate aliases database

    - name: Set-up group for an additional user
      group:
        name: user
        state: present

    - name: Set-up additional user for testing mail delivery
      user:
        name: user
        group: user
        shell: /bin/bash

  handlers:

    - name: Restart Postfix
      service:
        name: postfix
        state: restarted

    - name: Generate aliases database
      command: "/usr/bin/newaliases"