#!/bin/bash # Copyright 2014 Google Inc. All rights reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file 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. mkdir -p /etc/openvpn umask=$(umask) umask 0066 echo "$CA_CRT" > /etc/openvpn/ca.crt echo "$CLIENT_CRT" > /etc/openvpn/client.crt echo "$CLIENT_KEY" > /etc/openvpn/client.key umask $umask # Prepopulate the name of the Master mkdir -p /etc/salt/minion.d echo "master: $MASTER_NAME" > /etc/salt/minion.d/master.conf # Turn on debugging for salt-minion # echo "DAEMON_ARGS=\"\$DAEMON_ARGS --log-file-level=debug\"" > /etc/default/salt-minion hostnamef=$(hostname -f) sudo apt-get install ipcalc netmask=$(ipcalc $MINION_IP_RANGE | grep Netmask | awk '{ print $2 }') network=$(ipcalc $MINION_IP_RANGE | grep Address | awk '{ print $2 }') cbrstring="$network $netmask" # Our minions will have a pool role to distinguish them from the master. cat </etc/salt/minion.d/grains.conf grains: roles: - kubernetes-pool cbr-cidr: $MINION_IP_RANGE cloud: azure hostnamef: $hostnamef cbr-string: $cbrstring EOF # Install Salt # # We specify -X to avoid a race condition that can cause minion failure to # install. See https://github.com/saltstack/salt-bootstrap/issues/270 curl -L http://bootstrap.saltstack.com | sh -s -- -X