Merge "[UUI] Service Mesh Compliance for UUI"
[oom.git] / kubernetes / contrib / dns-server-for-vhost-ingress-testing / deploy_dns.sh
1 #!/bin/sh -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 {
38 cat << ==infodeploy
39 Extra DNS server already deployed:
40 1. You can add the DNS server to the target machine using following commands:
41     sudo iptables -t nat -A OUTPUT -p tcp -d 192.168.211.211 --dport 53 -j DNAT --to-destination $CLUSTER_IP:$DNS_PORT
42     sudo iptables -t nat -A OUTPUT -p udp -d 192.168.211.211 --dport 53 -j DNAT --to-destination $CLUSTER_IP:$DNS_PORT
43     sudo sysctl -w net.ipv4.conf.all.route_localnet=1
44     sudo sysctl -w net.ipv4.ip_forward=1
45 2. Update /etc/resolv.conf file with nameserver 192.168.211.211 entry on your target machine
46 ==infodeploy
47 }
48
49
50 list_node_with_external_addrs()
51 {
52     local WORKER_NODES
53     WORKER_NODES=$(kubectl get no -l node-role.kubernetes.io/worker=true -o jsonpath='{.items..metadata.name}')
54     for worker in $WORKER_NODES; do
55         local external_ip
56         external_ip=$(kubectl get no $worker  -o jsonpath='{.metadata.annotations.rke\.cattle\.io/external-ip }')
57         local internal_ip
58         internal_ip=$(kubectl get no $worker  -o jsonpath='{.metadata.annotations.rke\.cattle\.io/internal-ip }')
59         if [ $internal_ip != $external_ip ]; then
60             echo $external_ip
61             break
62         fi
63     done
64 }
65
66 ingress_controller_ip() {
67     local metal_ns
68     metal_ns=$(kubectl get ns --no-headers --output=custom-columns=NAME:metadata.name |grep metallb-system)
69     if [ -z $metal_ns ]; then
70         echo $CLUSTER_IP
71     else
72         list_node_with_external_addrs
73     fi
74 }
75
76 deploy() {
77     local ingress_ip
78     ingress_ip=$(ingress_controller_ip)
79     initdir = $(pwd)
80     cd $SPATH/bind9dns
81     if [ $# -eq 0 ]; then
82         local cl_domain
83         cl_domain="simpledemo.onap.org"
84     else
85         local cl_domain
86         cl_domain=$1
87         shift
88     fi
89     if [ $# -ne 0 ]; then
90         ingress_ip=$1
91         shift
92     fi
93     helm install . --set dnsconf.wildcard="$cl_domain=$ingress_ip" $@
94     cd $initdir
95     target_machine_notice_info
96 }
97
98 if [ $# -eq 1 ] && [ "$1" = "-h" ]; then
99     usage
100 elif [ $# -eq 1 ] && [ "$1" = "--help" ]; then
101     usage
102 elif [ $# -eq 1 ] && [ "$1" = "--info" ]; then
103        target_machine_notice_info
104 else
105     deploy $@
106 fi