Fixes on deployment

This commit is contained in:
Marc Aymerich 2015-10-02 13:31:19 +00:00
parent a5acb59a3b
commit df8d348e32

View file

@ -6,15 +6,6 @@ set -ue
# bash <( curl https://raw.githubusercontent.com/glic3rinu/django-orchestra/master/scripts/containers/deploy.sh ) [--noinput username] # bash <( curl https://raw.githubusercontent.com/glic3rinu/django-orchestra/master/scripts/containers/deploy.sh ) [--noinput username]
function main () { function main () {
run_ () {
echo " ${bold}\$ ${@}${normal}"
${@}
}
surun_ () {
echo " ${bold}\$ su $user -c \"${@}\"${normal}"
su $user -c "${@}"
}
noinput='' noinput=''
user=$USER user=$USER
if [[ $# -eq 2 ]]; then if [[ $# -eq 2 ]]; then
@ -30,14 +21,8 @@ function main () {
exit 1 exit 1
} }
noinput='--noinput' noinput='--noinput'
run () { run () { echo " ${bold}\$ ${@}${normal}"; ${@}; }
echo " ${bold}\$ ${@}${normal}" surun () { echo " ${bold}\$ su $user -c \"${@}\"${normal}"; su $user -c "${@}"; }
${@}
}
surun () {
echo " ${bold}\$ su $user -c \"${@}\"${normal}"
su $user -c "${@}"
}
user=$2 user=$2
elif [[ $# -eq 1 ]]; then elif [[ $# -eq 1 ]]; then
if [[ $1 != '--noinput' ]]; then if [[ $1 != '--noinput' ]]; then
@ -51,21 +36,15 @@ function main () {
echo -e "\nErr. This script should run as a regular user\n" >&2 echo -e "\nErr. This script should run as a regular user\n" >&2
exit 1 exit 1
} }
run () { run () { echo " ${bold}\$ ${@}${normal}"; ${@}; }
echo " ${bold}\$ ${@}${normal}" surun () { echo " ${bold}\$ ${@}${normal}"; ${@}; }
${@}
}
surun () {
echo " ${bold}\$ ${@}${normal}"
${@}
}
# Test sudo privileges # Test sudo privileges
sudo true sudo true
fi fi
bold=$(tput -T ${TERM:-xterm} bold) bold=$(tput -T ${TERM:-xterm} bold)
normal=$(tput -T ${TERM:-xterm} sgr0) normal=$(tput -T ${TERM:-xterm} sgr0)
project_name="panel" project_name="panel"
if [[ $noinput == '' ]]; then if [[ $noinput == '' ]]; then
while true; do while true; do
@ -86,8 +65,6 @@ function main () {
done done
fi fi
# TODO detect if already installed and don't ask stupid question
task=cronbeat task=cronbeat
if [[ $noinput == '' ]]; then if [[ $noinput == '' ]]; then
while true; do while true; do
@ -100,7 +77,7 @@ function main () {
esac esac
done done
fi fi
run sudo pip3 install django-orchestra==dev \ run sudo pip3 install django-orchestra==dev \
--allow-external django-orchestra \ --allow-external django-orchestra \
--allow-unverified django-orchestra --allow-unverified django-orchestra
@ -146,23 +123,33 @@ EOF
run sudo python3 -W ignore manage.py startservices run sudo python3 -W ignore manage.py startservices
surun "python3 -W ignore manage.py check --deploy" surun "python3 -W ignore manage.py check --deploy"
# Test if serving requests
ip_addr=$(ip addr show eth0 | grep 'inet ' | sed -r "s/.*inet ([^\s]*).*/\1/" | cut -d'/' -f1) ip_addr=$(ip addr show eth0 | grep 'inet ' | sed -r "s/.*inet ([^\s]*).*/\1/" | cut -d'/' -f1)
if [[ $ip_addr == '' ]]; then if [[ $ip_addr == '' ]]; then
ip_addr=127.0.0.1 ip_addr=127.0.0.1
fi fi
echo echo
echo echo ${bold}
echo "${bold}> Checking if Orchestra is serving at https://${ip_addr}/admin/${normal} ..." echo "> Checking if Orchestra is serving on https://${ip_addr}/admin/ ..."
if [[ $(curl https://$ip_addr/admin/ -I -k -s | grep 'HTTP/1.1 302 FOUND') ]]; then if [[ $noinput == '--noinput' ]]; then
echo "${bold} ** Orchestra appears to be working!${normal}" echo -e " - username: $user"
if [[ $noinput == '--noinput' ]]; then echo -e " - password: orchestra"
echo -e "${bold} username: $user${normal}" fi
echo -e "${bold} password: orchestra"
if [[ $(curl -L -k -v -c https://$ip_addr/admin/ -c /tmp/cookies.txt -b /tmp/cookies.txt | grep 'Panel Hosting Management') ]]; then
token=$(grep csrftoken /tmp/cookies.txt | awk {'print $7'})
if [[ $(curl -L -k -v -c /tmp/cookies.txt -b /tmp/cookies.txt \
-d "username=$user&password=orchestra&csrfmiddlewaretoken=$token" \
https://$ip_addr/admin/login/?next=/admin/ \
-e https://$ip_addr/admin/ | grep '<title>Panel Hosting Management</title>') ]]; then
echo " ** Orchestra appears to be working!"
else
echo " ** Err. Couldn't login :(" >&2
fi fi
else else
echo "${bold} ** Err. Orchestra is not responding responding at https://${ip_addr}/admin/${normal}" >&2 echo " ** Err. Orchestra is not responding responding on https://${ip_addr}/admin/" >&2
fi fi
echo echo ${normal}
} }
# Wrap it all on a function to avoid partial executions when running through wget/curl # Wrap it all on a function to avoid partial executions when running through wget/curl