aboutsummaryrefslogtreecommitdiffstats
path: root/ansible/roles/ansible-vvp-bootstrap/tasks/dnsmasq.yml
blob: 48dad1c08c6092644440013129970cb5f2d78e5f (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
# -*- encoding: utf-8 -*- 
# ============LICENSE_START======================================================= 
# org.onap.vvp/engagementmgr
# ===================================================================
# Copyright © 2017 AT&T Intellectual Property. All rights reserved.
# ===================================================================
#
# Unless otherwise specified, all software contained herein is licensed
# under the Apache License, Version 2.0 (the “License”);
# you may not use this software except in compliance with the License.
# You may obtain a copy of the License at
#
#             http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
#
#
# Unless otherwise specified, all documentation contained herein is licensed
# under the Creative Commons License, Attribution 4.0 Intl. (the “License”);
# you may not use this documentation except in compliance with the License.
# You may obtain a copy of the License at
#
#             https://creativecommons.org/licenses/by/4.0/
#
# Unless required by applicable law or agreed to in writing, documentation
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# ============LICENSE_END============================================
#
# ECOMP is a trademark and service mark of AT&T Intellectual Property.
- name: Install nf_conntrack_tftp
  modprobe:
    name: nf_conntrack_tftp
    state: present

- name: Copy our pxe client
  copy: src=iceundionly.kpxe dest="{{files_dir}}/iceundionly.kpxe"
  when: pxe_chainload

- name: Create DNSMASQ leases file
  file: path="{{files_dir}}/leases" mode=0644 state=touch

- name: DROP DNS, tftp requests from public
  shell: iptables -I INPUT 1 -p udp --dport {{item}} -i {{ops_public_interface}} -j DROP
  with_items:
  - 53
  - 69

- name: DROP DNS, tftp requests to public
  shell: iptables -I OUTPUT 1 -p udp --sport {{item}} -o {{ops_public_interface}} -j DROP
  with_items:
  - 53
  - 69

- name: Allow Inbound UDP DHCP Requests
  shell: iptables -A INPUT -p udp --dport {{item}} -j ACCEPT
  with_items:
  - 53
  - 67:69

- name: Allow Outbound UDP DNS, DHCP
  shell: iptables -A OUTPUT -p udp --sport {{item}} -j ACCEPT
  with_items:
  - 53
  - 67:69

- name: Allow TFTP file transfers on arbitrary ports.
  shell: 'iptables -A OUTPUT -p udp -o {{ ops_management_interface }} --sport 1023: --dport 1024: -m state --state ESTABLISHED,RELATED -j ACCEPT'

- name: Allow TFTP file transfers on arbitrary ports.
  shell: 'iptables -A INPUT -p udp -i {{ops_management_interface}} --dport 1023: -m state --state ESTABLISHED,RELATED -j ACCEPT'

- name: Render DNSMASQ configuration
  template:
    src: dnsmasq.conf.j2
    dest: "{{files_dir}}/dnsmasq.conf"

- name: Is dnsmasq already running?
  shell: docker ps | grep dnsmasq | awk '{ print $1 }'
  register: dnsmasq_id

- name: Kill dnsmasq!
  shell: docker kill "{{dnsmasq_id.stdout}}"
  when: dnsmasq_id.stdout != ""

- name: Start DNSMASQ
  command: "docker run -d
    --net=host
    --cap-add=NET_ADMIN
    -v {{files_dir}}/leases:/var/lib/misc/dnsmasq.leases:Z
    -v {{files_dir}}/dnsmasq.conf:/etc/dnsmasq.conf:Z
{% if pxe_chainload %}
    -v {{files_dir}}/iceundionly.kpxe:/var/lib/tftpboot/iceundionly.kpxe:Z
{% endif %}
    quay.io/coreos/dnsmasq -d -q"