blob: 0440cd1466e09c735200b10d756ac191b6e1f399 [file] [log] [blame]
#!/bin/bash
# ----------------------------------------------------------------------------
#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you 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.
#
# ----------------------------------------------------------------------------
# EC2 Demo configuration script for Apache Stratos
# ----------------------------------------------------------------------------
# Die on any error:
set -e
# General commands
if [ "$(uname)" == "Darwin" ]; then
# Do something under Mac OS X platform
SED=`which gsed` && : || (echo "Command 'gsed' is not installed."; exit 10;)
else
# Do something else under some other platform
SED=`which sed` && : || (echo "Command 'sed' is not installed."; exit 10;)
fi
source "./conf/setup.conf"
SLEEP=40
export LOG=$log_path/stratos-ec2-user-data.log
# Make sure the user is running as root.
if [ "$UID" -ne "0" ]; then
echo ; echo " You must be root to run $0. (Try running 'sudo bash' first.)" ; echo
exit 69
fi
if [[ ! -d $log_path ]]; then
mkdir -p $log_path
fi
# Configuring Amazon EC2 user data.
# ----------------------------------------------------------------------------
# Following is helpful if you've mistakenly added data in user-data and want to recover.
read -p "Please confirm whether you want to be prompted, irrespective of the data available in user-data? [y/n] " answer
if [[ $answer = n && `curl -o /dev/null --silent --head --write-out '%{http_code}\n' http://169.254.169.254/latest/user-data` = "200" ]] ; then
echo "Trying to find values via user-data" >> $LOG
wget http://169.254.169.254/latest/user-data -O /opt/user-data.txt >> $LOG
userData=`cat /opt/user-data.txt`
echo "Extracted user-data: $userData" >> $LOG
# Assign values obtained through user-data
for i in {1..8}
do
entry=`echo $userData | cut -d',' -f$i | sed 's/,//g'`
key=`echo $entry | cut -d'=' -f1 | sed 's/=//g'`
value=`echo $entry | cut -d'=' -f2 | sed 's/=//g'`
if [[ "$key" == *ACCESS_KEY* ]] ; then ACCESS_KEY=$value;
elif [[ "$key" == *SECRET_KEY* ]] ; then SECRET_KEY=$value;
elif [[ "$key" == *OWNER_ID* ]] ; then OWNER_ID=$value;
elif [[ "$key" == *AVAILABILITY_ZONE* ]] ; then AVAILABILITY_ZONE=$value;
elif [[ "$key" == *SECURITY_GROUP* ]] ; then SECURITY_GROUP=$value;
elif [[ "$key" == *KEY_PAIR_NAME* ]] ; then KEY_PAIR_NAME=$value;
elif [[ "$key" == *DOMAIN* ]] ; then DOMAIN=$value;
fi
done
fi
# Prompt for the values that are not retrieved via user-data
if [[ -z $ACCESS_KEY ]]; then
echo -n "Access Key of EC2 account: "
read ACCESS_KEY
fi
if [[ -z $SECRET_KEY ]]; then
echo -n "Secret key of EC2 account: "
read SECRET_KEY
fi
if [[ -z $OWNER_ID ]]; then
echo -n "Owner id of EC2 account: "
read OWNER_ID
fi
if [[ -z $AVAILABILITY_ZONE ]]; then
echo -n "Availability zone: "
read AVAILABILITY_ZONE
fi
if [[ -z $SECURITY_GROUP ]]; then
echo -n "Name of the EC2 security group: "
read SECURITY_GROUP
fi
if [[ -z $KEY_PAIR_NAME ]]; then
echo -n "Name of the key pair: "
read KEY_PAIR_NAME
fi
if [[ -z $DOMAIN ]]; then
echo -n "Domain name for Stratos [stratos.apache.org]: "
read DOMAIN
fi
if [ -z "$DOMAIN" ]; then
DOMAIN="stratos.apache.org"
fi
echo "Updating conf/setup.conf with user data"
${SED} -i "s@export stratos_domain=\"*.*\"@export stratos_domain=\"$DOMAIN\"@g" conf/setup.conf
${SED} -i "s@export ec2_keypair_name=\"*.*\"@export ec2_keypair_name=\"$KEY_PAIR_NAME\"@g" conf/setup.conf
${SED} -i "s@export ec2_identity=\"*.*\"@export ec2_identity=\"$ACCESS_KEY\"@g" conf/setup.conf
${SED} -i "s@export ec2_credential=\"*.*\"@export ec2_credential=\"$SECRET_KEY\"@g" conf/setup.conf
${SED} -i "s@export ec2_owner_id=\"*.*\"@export ec2_owner_id=\"$OWNER_ID\"@g" conf/setup.conf
${SED} -i "s@export ec2_availability_zone=\"*.*\"@export ec2_availability_zone=\"$AVAILABILITY_ZONE\"@g" conf/setup.conf
${SED} -i "s@export ec2_security_groups=\"*.*\"@export ec2_security_groups=\"$SECURITY_GROUP\"@g" conf/setup.conf
# Updating conf/setup.conf with relevent data
# ----------------------------------------------------------------------------
ip=`facter ipaddress`
echo "Setting private ip addresses $ip" >> $LOG
${SED} -i "s@export host_ip=\"*.*\"@export host_ip=\"$ip\"@g" conf/setup.conf
${SED} -i "s@export mb_ip=\"*.*\"@export mb_ip=\"$ip\"@g" conf/setup.conf
${SED} -i "s@export puppet_ip=\"*.*\"@export puppet_ip=\"$ip\"@g" conf/setup.conf
${SED} -i "s@export stratos_domain=\"*.*\"@export stratos_domain=\"$DOMAIN\"@g" conf/setup.conf
${SED} -i "s@\s*\$mb_ip\s*=\s*'.*'\s*@ \$mb_ip = '$ip'@g" /etc/puppet/manifests/nodes.pp
${SED} -i "s@\s*\$cep_ip\s*=\s*'.*'\s*@ \$cep_ip = '$ip'@g" /etc/puppet/manifests/nodes.pp
hostname $puppet_hostname
service puppetmaster restart
echo "Setup configuration completed successfully"
# Server configurations
# ----------------------------------------------------------------------------
su -c "$setup_path/setup.sh -s"