oh-my-zsh/plugins/nginx/nginx.plugin.zsh

196 lines
4.8 KiB
Bash
Raw Normal View History

2012-09-02 13:43:20 +00:00
: ${NGINX_DIR:=/etc/nginx}
: ${NGINX_VHOST_TEMPLATE:=$ZSH/plugins/nginx/templates/symfony2}
if [ $use_sudo -eq 1 ]; then
sudo="sudo"
else
sudo=""
fi
# nginx basic completition
_nginx_get_en_command_list () {
ls -a $NGINX_DIR/sites-available | awk '/^[a-z][a-z.-]+$/ { print $1 }'
}
_nginx_get_dis_command_list () {
ls -a $NGINX_DIR/sites-enabled | awk '/^[a-z][a-z.-]+$/ { print $1 }'
}
_nginx_en () {
compadd `_nginx_get_en_command_list`
}
_nginx_dis () {
compadd `_nginx_get_dis_command_list`
}
# Enabling a site
en () {
if [ ! $1 ]; then
echo "\033[337;41m\nThe name of the vhost is required!\n\033[0m";
return
fi
if [ ! -e $NGINX_DIR/sites-available/$1 ]; then
echo "\033[31m$1\033[0m doesn't exist";
return
fi
if [ ! -e $NGINX_DIR/sites-enabled/$1 ]; then
$sudo ln -s $NGINX_DIR/sites-available/$1 $NGINX_DIR/sites-enabled/$1;
if [ -e /etc/nginx/sites-enabled/$1 ]; then
echo "\033[32m$1\033[0m successfully enabled";
else
echo "An error occured during the enabling of \033[31m$1\033[0m";
fi
else
echo "\033[31m$1\033[0m is already enabled";
fi
}
compdef _nginx_en en
# Disabling a site
dis () {
if [ ! $1 ]; then
echo "\033[337;41m\nThe name of the vhost is required!\n\033[0m";
return
fi
if [ ! -e $NGINX_DIR/sites-enabled/$1 ]; then
echo "\033[31m$1\033[0m doesn't exist";
else
$sudo rm -f $NGINX_DIR/sites-enabled/$1;
if [ ! -e $NGINX_DIR/sites-enabled/$1 ]; then
echo "\033[32m$1\033[0m successfully disabled";
else
echo "An error occured during the disabling of \033[31m$1\033[0m";
fi
fi
}
compdef _nginx_dis dis
# Completition of vhost
_nginx_get_possible_vhost_list () {
ls -a $HOME/www | awk '/^[^.][a-z0-9._]+$/ { print $1 }'
}
_nginx_vhost () {
compadd `_nginx_get_possible_vhost_list`
}
# Parsing arguments
vhost () {
user=$USER;
template=$NGINX_VHOST_TEMPLATE
tpl="non_existing_template"
enable=1
write_hosts=0
args=""
while getopts ":lu:t:nwh" option
do
case $option in
l ) ls $NGINX_DIR/sites-enabled; return ;;
u ) user=$OPTARG; args="$args -u $OPTARG" ;;
t ) tpl=$OPTARG; args="$args -t $OPTARG" ;;
n ) enable=0; args="$args -n" ;;
w ) write_hosts=1; args="$args -w" ;;
h ) _vhost_usage; return ;;
esac
done
vhost=${@: -1}
vhostNotGiven=0
if [ ! $vhost ]; then
vhostNotGiven=1
else
if [ $(echo $args | grep -o $vhost) ]; then
vhostNotGiven=1
fi
fi
if [ $vhostNotGiven -eq 1 ]; then
echo "\033[337;41m\nThe name of the vhost is required!\n\033[0m"
return
fi
if [ -e $ZSH/plugins/nginx/templates/$tpl ]; then
template=$ZSH/plugins/nginx/templates/$tpl
elif [ -e $tpl ]; then
template=$tpl
fi
_vhost_generate $vhost $user
if [ $enable -eq 1 ]; then
en $vhost
fi
if [ $write_hosts -eq 1 ]; then
_write_hosts $vhost
fi
}
compdef _nginx_vhost vhost
_vhost_usage () {
echo "Usage: vhost [options] [vhost_name]"
echo
echo "Options"
echo " -l Lists enabled vhosts"
echo " -u Sets the user - defaults to the current user ($USER)"
echo " -t Sets the template"
echo " -n Does not enable the generated vhost"
echo " -w Write the vhost to the /etc/hosts file pointing to 127.0.0.1 (writes it at the end of the first line actually)"
echo " -h Get this help message"
return
}
# Generate config file
_vhost_generate () {
user=$(cat /etc/passwd | grep $2 | awk -F : '{print $1 }')
if [ ! $user ]; then
echo "User \033[31m$2\033[0m doesn't have an account on \033[33m$HOST\033[0m"
return
fi
echo "Generating \033[32m$1\033[0m vhost for \033[33m$user\033[0m user"
user_id=$(cat /etc/passwd | grep $2 | awk -F : '{print $3 }')
pool_port=1$user_id
conf=$(sed -e 's/{vhost}/'$1'/g' -e 's/{user}/'$user'/g' -e 's/{pool_port}/'$pool_port'/g' $template )
echo $conf > $1.tmp
$sudo mv $1.tmp $NGINX_DIR/sites-available/$1
if [ -e $NGINX_DIR/sites-available/$1 ]; then
echo "\033[32m$1\033[0m vhost has been successfully created"
else
echo "An error occured during the creating of \033[31m$1\033[0m vhost"
fi
}
# Write the /etc/hosts file
_write_hosts () {
temp=$HOME/hosts.temp
exec < /etc/hosts
while read line
do
if [ -e $temp ]; then
echo "$line" >> $temp;
else
echo "$line $1" > $temp;
fi
done
$sudo mv $temp /etc/hosts;
"\033[32m$1\033[0m vhost has been successfully written in /etc/hosts"
}
alias ngt="$sudo nginx -t"
alias ngr="$sudo service nginx restart"