7e9077d97232f067062f07de1a2202c523329261
[oom.git] / kubernetes / contrib / dns-server-for-vhost-ingress-testing / deploy_dns.sh
1 #!/bin/bash -e
2
3 #   Copyright 2020 Samsung Electronics Co., Ltd.
4 #
5 #   Licensed under the Apache License, Version 2.0 (the "License");
6 #   you may not use this file except in compliance with the License.
7 #   You may obtain a copy of the License at
8 #
9 #       http://www.apache.org/licenses/LICENSE-2.0
10 #
11 #   Unless required by applicable law or agreed to in writing, software
12 #   distributed under the License is distributed on an "AS IS" BASIS,
13 #   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 #   See the License for the specific language governing permissions and
15 #   limitations under the License.
16 #
17 DNS_PORT=31555
18 CLUSTER_CONTROL=$( kubectl get no -l node-role.kubernetes.io/controlplane=true -o jsonpath='{.items..metadata.name}')
19 CLUSTER_IP=$(kubectl get no $CLUSTER_CONTROL  -o jsonpath='{.metadata.annotations.rke\.cattle\.io/external-ip }')
20 SPATH="$( dirname "$( which "$0" )" )"
21
22
23
24 usage() {
25 cat << ==usage
26 $0 [cluster_domain] [lb_ip] [helm_chart_args] ...
27     [cluster_domain] Default value simpledemo.onap.org
28     [lb_ip] Default value LoadBalancer IP
29     [helm_chart_args] ... Optional arguments passed to helm install command
30 $0 --help This message
31 $0 --info Display howto configure target machine
32 ==usage
33 }
34
35
36 target_machine_notice_info() {
37 cat << ==infodeploy
38 Extra DNS server already deployed:
39 1. You can add the DNS server to the target machine using following commands:
40     sudo iptables -t nat -A OUTPUT -p tcp -d 192.168.211.211 --dport 53 -j DNAT --to-destination $CLUSTER_IP:$DNS_PORT
41     sudo iptables -t nat -A OUTPUT -p udp -d 192.168.211.211 --dport 53 -j DNAT --to-destination $CLUSTER_IP:$DNS_PORT
42     sudo sysctl -w net.ipv4.conf.all.route_localnet=1
43     sudo sysctl -w net.ipv4.ip_forward=1
44 2. Update /etc/resolv.conf file with nameserver 192.168.211.211 entry on your target machine
45 ==infodeploy
46 }
47
48
49 list_node_with_external_addrs()
50 {
51     local WORKER_NODES=$(kubectl get no -l node-role.kubernetes.io/worker=true -o jsonpath='{.items..metadata.name}')
52     for worker in $WORKER_NODES; do
53         local external_ip=$(kubectl get no $worker  -o jsonpath='{.metadata.annotations.rke\.cattle\.io/external-ip }')
54         local internal_ip=$(kubectl get no $worker  -o jsonpath='{.metadata.annotations.rke\.cattle\.io/internal-ip }')
55         if [ $internal_ip != $external_ip ]; then
56             echo $external_ip
57             break
58         fi
59     done
60 }
61
62 ingress_controller_ip() {
63     local metal_ns=$(kubectl get ns --no-headers --output=custom-columns=NAME:metadata.name |grep metallb-system)
64     if [ -z $metal_ns ]; then
65         echo $CLUSTER_IP
66     else
67         list_node_with_external_addrs
68     fi
69 }
70
71 deploy() {
72     local ingress_ip=$(ingress_controller_ip)
73     initdir = $(pwd)
74     cd $SPATH/bind9dns
75     if [ $# -eq 0 ]; then
76         local cl_domain="simpledemo.onap.org"
77     else
78         local cl_domain=$1
79         shift
80     fi
81     if [ $# -ne 0 ]; then
82         ingress_ip=$1
83         shift
84     fi
85     helm install . --set dnsconf.wildcard="$cl_domain=$ingress_ip" $@
86     cd $initdir
87     target_machine_notice_info
88 }
89
90 if [ $# -eq 1 ] && [ "$1" = "-h" ]; then
91     usage
92 elif [ $# -eq 1 ] && [ "$1" = "--help" ]; then
93     usage
94 elif [ $# -eq 1 ] && [ "$1" = "--info" ]; then
95        target_machine_notice_info
96 else
97     deploy $@
98 fi