2014-07-18 18:48:04 +00:00
|
|
|
#!/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.
|
|
|
|
|
|
|
|
# Prepopulate the name of the Master
|
|
|
|
mkdir -p /etc/salt/minion.d
|
|
|
|
echo "master: $MASTER_NAME" > /etc/salt/minion.d/master.conf
|
|
|
|
|
|
|
|
cat <<EOF >/etc/salt/minion.d/grains.conf
|
|
|
|
grains:
|
|
|
|
roles:
|
|
|
|
- kubernetes-master
|
2014-07-21 23:50:15 +00:00
|
|
|
cloud: azure
|
2014-07-18 18:48:04 +00:00
|
|
|
EOF
|
|
|
|
|
|
|
|
# Auto accept all keys from minions that try to join
|
|
|
|
mkdir -p /etc/salt/master.d
|
|
|
|
cat <<EOF >/etc/salt/master.d/auto-accept.conf
|
|
|
|
auto_accept: True
|
|
|
|
EOF
|
|
|
|
|
|
|
|
cat <<EOF >/etc/salt/master.d/reactor.conf
|
|
|
|
# React to new minions starting by running highstate on them.
|
|
|
|
reactor:
|
|
|
|
- 'salt/minion/*/start':
|
|
|
|
- /srv/reactor/start.sls
|
|
|
|
EOF
|
|
|
|
|
|
|
|
mkdir -p /srv/salt/nginx
|
|
|
|
echo $MASTER_HTPASSWD > /srv/salt/nginx/htpasswd
|
|
|
|
|
2014-07-22 21:54:03 +00:00
|
|
|
mkdir -p /etc/openvpn
|
|
|
|
umask=$(umask)
|
|
|
|
umask 0066
|
|
|
|
echo "$CA_CRT" > /etc/openvpn/ca.crt
|
|
|
|
echo "$SERVER_CRT" > /etc/openvpn/server.crt
|
|
|
|
echo "$SERVER_KEY" > /etc/openvpn/server.key
|
|
|
|
umask $umask
|
|
|
|
|
2014-07-18 18:48:04 +00:00
|
|
|
# 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
|
|
|
|
#
|
|
|
|
# -M installs the master
|
|
|
|
curl -L http://bootstrap.saltstack.com | sh -s -- -M -X
|
|
|
|
|
|
|
|
echo $MASTER_HTPASSWD > /srv/salt/nginx/htpasswd
|