Files
uberspace-webadmin/action.sh

497 lines
11 KiB
Bash
Raw Normal View History

2016-04-26 23:51:27 +02:00
#!/bin/bash
2015-07-09 00:06:31 +03:00
########################################################################
2016-04-26 23:51:27 +02:00
# Copyright (C) 2016 Max Mehl <mail [at] mehl [dot] mx>
2015-07-09 00:06:31 +03:00
########################################################################
2021-12-18 12:01:20 +01:00
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
2015-07-10 19:13:39 +03:00
# License, or (at your option) any later version.
2021-12-18 12:01:20 +01:00
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2015-07-10 19:13:39 +03:00
# GNU Affero General Public License for more details.
2021-12-18 12:01:20 +01:00
#
# You should have received a copy of the GNU Affero General Public
# License along with this program. If not, see
2015-07-10 19:13:39 +03:00
# <http://www.gnu.org/licenses/>.
2021-12-18 12:01:20 +01:00
#
2015-07-09 00:06:31 +03:00
########################################################################
2021-12-18 12:01:20 +01:00
#
2015-07-09 00:06:31 +03:00
# This script handles calls from submit.php.
# It checks the validity of usernames, executes basic command
# When password entries are required, it starts the respective python
# scripts
2021-12-18 12:01:20 +01:00
#
2015-07-09 00:06:31 +03:00
########################################################################
# Test if config.cfg exists and set needed variables
if [ ! -e config.cfg ]; then echo "Missing config.cfg file. Edit and rename config.cfg.sample"; exit 1; fi
source config.cfg
ACTION=$1 # adduser, changepw, listusers, userdetail, deluser, sizeall, sizeuser, viewdata
USER=$2
PASSFILE=$3 # $3 is a file containing the password
2015-07-11 00:15:33 +03:00
PASS=$(cat $PASSFILE)
PATH=$PATH:$HOME/bin
2015-07-10 23:59:33 +03:00
2015-07-09 00:06:31 +03:00
## FUNCTIONS
function checkaction {
2015-07-13 14:24:05 +03:00
REGEX="^adduser$|^changepw$|^listusers$|^userdetail$|^deluser$|^sizeall$|^sizeuser$|^viewdata$|^addalias$|^quota$|^installwp$|^uninstallwp$"
2021-12-18 12:01:20 +01:00
if [[ $1 =~ $REGEX ]]; then
echo "true"
2015-07-09 00:06:31 +03:00
else
echo "false"
fi
}
function checkuser {
2015-07-10 14:58:30 +03:00
REGEX="^[A-Za-z0-9._+-]+$" # Allowed symbols
2021-12-18 12:01:20 +01:00
if [[ $1 =~ $REGEX ]]; then
echo "true"
2015-07-09 00:06:31 +03:00
else
echo "false"
fi
}
function checkpass {
2015-07-10 17:47:22 +03:00
REGEX="[ '\\]" # Not allowed symbols
2021-12-18 12:01:20 +01:00
if [[ $(grep -E "$REGEX" $1 ; echo $?) == 1 ]]; then
echo "true"
2015-07-09 00:06:31 +03:00
else
echo "false"
fi
}
function userexists {
STATUS=$(listvdomain | cut -d" " -f 1 | sed '1d' | grep -q "^$1$" ; echo $?)
if [ $STATUS == 0 ]; then
echo "true"
else
echo "false"
fi
}
2021-12-18 12:01:20 +01:00
function mailsend {
2015-07-09 00:06:31 +03:00
TOEMAIL="$TOEMAIL";
FREMAIL="$FREMAIL";
SUBJECT="[$DOMAIN] $1";
MSGBODY1="$2"
MSGBODY2="$3"
2015-07-10 12:06:14 +03:00
2015-07-10 12:16:05 +03:00
printf '%s\n' "From: $FREMAIL
2015-07-10 12:08:50 +03:00
To: $TOEMAIL
Reply-To: $FREMAIL
Subject: $SUBJECT
2015-07-10 12:06:14 +03:00
2015-07-10 12:08:50 +03:00
$MSGBODY1
2015-07-10 12:06:14 +03:00
2015-07-10 12:08:50 +03:00
$MSGBODY2
2015-07-10 12:41:32 +03:00
" > $MAILTMP
cat $MAILTMP | "$SENDMAILPATH" -t;
rm $MAILTMP;
}
function mailsendenc {
2021-12-18 12:01:20 +01:00
2015-07-10 12:41:32 +03:00
if [ ! -e $SSLKEY ]; then
#echo "Encryption key \"$SSLKEY\" is not available. Aborting."
#exit 1
2021-12-18 12:01:20 +01:00
2015-07-10 12:41:32 +03:00
openssl genrsa -out $SSLKEY 2048
fi
2021-12-18 12:01:20 +01:00
2015-07-10 12:41:32 +03:00
TOEMAIL="$TOEMAIL";
FREMAIL="$FREMAIL";
SUBJECT="[$DOMAIN] $1";
MSGBODY1="$2"
BOUNDARY="ZZafgwejwepfgkl.9453x1q"
2015-07-10 12:55:53 +03:00
ATTACHMENT=$(echo $3 | openssl rsautl -inkey $SSLKEY -encrypt | base64)
2015-07-10 12:41:32 +03:00
printf '%s\n' "From: $FREMAIL
To: $TOEMAIL
Reply-To: $FREMAIL
Subject: $SUBJECT
Mime-Version: 1.0
Content-Type: multipart/mixed; boundary=\"$BOUNDARY\"
--${BOUNDARY}
Content-Type: text/plain; charset=\"us-ascii\"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline
$MSGBODY1
2021-12-18 12:01:20 +01:00
Upload the attached encrypted file to your Account Administration Panel
in order to see sensitive details. Please visit the section \"Decrypt
2015-07-10 13:02:37 +03:00
system email\" for more details.
2015-07-10 12:41:32 +03:00
--${BOUNDARY}
Content-Type: text/plain
2015-07-10 13:02:37 +03:00
Content-Transfer-Encoding: 7bit
2015-07-10 12:41:32 +03:00
Content-Disposition: attachment; filename=\"message.txt.crypt\"
$ATTACHMENT
--${BOUNDARY}
" > $MAILTMP
cat $MAILTMP | "$SENDMAILPATH" -t;
rm $MAILTMP;
2015-07-09 00:06:31 +03:00
}
2021-12-18 12:01:20 +01:00
function notesdelete {
2015-07-10 16:07:34 +03:00
USER="$1"
2015-07-10 16:03:36 +03:00
# Extract Mail part | exclude LEAD and TAIL | delete user
sed -n "/$LEAD/,/$TAIL/ p" $NOTES | grep -v "$LEAD\|$TAIL" | sed "/User:[ \t]*$USER$/,+2d" > $NOTESTMP
# Put edited part in between $LEAD and $TAIL again
sed -i "/$LEAD/,/$TAIL/{ /$LEAD/{p; r $NOTESTMP
}; /$TAIL/p; d }" $NOTES
rm $NOTESTMP
}
2015-07-10 16:07:34 +03:00
function notesinsert {
# Update datasheet (add new entry in Email section)
USER=$1
PASSFILE=$2
2021-12-18 12:01:20 +01:00
# Create temporary file from $PASSFILE
2015-07-10 16:35:30 +03:00
sed -E "s/(.*)/User: $USER\nPass: \1\n\n/" $PASSFILE > .$PASSFILE.tmp
2021-12-18 12:01:20 +01:00
# Insert this edited file into the datasheet
sed -i "/$TAIL/ {
h
r .$PASSFILE.tmp
g
N
}" $NOTES
2015-07-10 16:35:30 +03:00
rm .$PASSFILE.tmp
2015-07-10 16:07:34 +03:00
}
2015-07-09 00:06:31 +03:00
## FIRST CHECKS
if ! $(checkaction "$ACTION"); then
echo "No valid action chosen"
exit 1
fi
2015-07-10 09:28:49 +03:00
2015-07-09 00:06:31 +03:00
# # # # #
# ADDING USER
# # # # #
if [ "$ACTION" == "adduser" ]; then
echo "Adding new Email user..."
echo
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
if ! $(checkuser "$USER"); then
echo "Username \"$USER\" invalid"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
if $(userexists "$USER"); then
echo "User \"$USER\" does already exist!"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-10 17:47:22 +03:00
if ! $(checkpass "$PASSFILE"); then
echo "Password \""$(cat $PASSFILE)"\" invalid"
2015-07-09 00:06:31 +03:00
exit 1
fi
2021-12-18 12:01:20 +01:00
python adduser.py "$USER" "$PASSFILE"
2021-12-18 12:01:20 +01:00
2015-07-10 09:28:49 +03:00
if [ $? == 0 ]; then
# Send infomail
2015-07-10 12:43:40 +03:00
$MAILTYPE "New Email account created" \
"A new Email account has been created." \
2015-07-10 17:47:22 +03:00
"User: $USER"
2021-12-18 12:01:20 +01:00
2015-07-10 16:10:03 +03:00
LEAD='## > EMAIL'
2015-07-10 09:28:49 +03:00
TAIL='## < EMAIL'
2015-07-10 16:19:10 +03:00
notesinsert "$USER" "$PASSFILE"
2021-12-18 12:01:20 +01:00
2015-07-10 09:28:49 +03:00
fi
2015-07-09 00:06:31 +03:00
fi # /adduser
2015-07-10 18:08:17 +03:00
# # # # #
# ADD ALIAS
# # # # #
if [ "$ACTION" == "addalias" ]; then
echo "Extracting details of Email account..."
echo
2021-12-18 12:01:20 +01:00
2015-07-10 18:08:17 +03:00
DEST=$PASS
2021-12-18 12:01:20 +01:00
2015-07-10 22:57:41 +03:00
if ! $(checkuser "$USER"); then
echo "Username \"$USER\" invalid"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-10 18:08:17 +03:00
if $(userexists "$USER"); then
echo "User \"$USER\" does already exist!"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-10 18:08:17 +03:00
if ! $(userexists "$DEST"); then
echo "Destination account \"$DEST\" does not exist!"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-10 18:08:17 +03:00
vaddalias $USER $DEST
2021-12-18 12:01:20 +01:00
2015-07-10 18:08:17 +03:00
fi # /addalias
2015-07-09 00:06:31 +03:00
# # # # #
# CHANGE PASSWORD
# # # # #
if [ "$ACTION" == "changepw" ]; then
echo "Changing password of Email account..."
echo
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
if ! $(userexists "$USER"); then
echo "User \"$USER\" does not exist!"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-10 17:47:22 +03:00
if ! $(checkpass "$PASSFILE"); then
echo "Password \""$(cat $PASSFILE)"\" invalid"
2015-07-09 00:06:31 +03:00
exit 1
fi
2021-12-18 12:01:20 +01:00
python changepw.py "$USER" "$PASSFILE"
2021-12-18 12:01:20 +01:00
if [ $? == 0 ]; then
# Send infomail
2015-07-10 12:43:40 +03:00
$MAILTYPE "Email password changed" \
"An Email account password has been changed." \
2015-07-10 17:47:22 +03:00
"User: $USER"
2015-07-10 10:41:38 +03:00
# Update datasheet (delete entry in Email section and add a new one with the new password)
# In fact a combination of deluser and adduser
LEAD='## > EMAIL'
TAIL='## < EMAIL'
2021-12-18 12:01:20 +01:00
notesdelete "$USER"
2015-07-10 16:19:10 +03:00
notesinsert "$USER" "$PASSFILE"
2021-12-18 12:01:20 +01:00
fi
2015-07-10 09:28:49 +03:00
fi # /changepw
2015-07-09 00:06:31 +03:00
# # # # #
2015-07-09 00:26:45 +03:00
# LIST USERS
2015-07-09 00:06:31 +03:00
# # # # #
if [ "$ACTION" == "listusers" ]; then
echo "Listing all Email accounts..."
echo
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
listvdomain | column -s $' ' -t
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
fi # /listusers
2015-07-09 00:26:45 +03:00
# # # # #
# SIZE ALL USERS
# # # # #
if [ "$ACTION" == "sizeall" ]; then
echo "Calculate total size of all Email accounts..."
echo
2021-12-18 12:01:20 +01:00
2015-07-09 01:01:15 +03:00
du -sBM ~/users/* | sed -e "s:/home/$SYSUSER/users/::g"
2021-12-18 12:01:20 +01:00
2015-07-09 00:26:45 +03:00
fi # /sizeall
# # # # #
# VIEW DATASHEET
# # # # #
if [ "$ACTION" == "viewdata" ]; then
echo "Extracting data sheet..."
echo
2021-12-18 12:01:20 +01:00
cat $NOTES
2021-12-18 12:01:20 +01:00
fi # /viewdata
2015-07-09 00:26:45 +03:00
# # # # #
# SIZE USER
# # # # #
if [ "$ACTION" == "sizeuser" ]; then
echo "Calculate size of all folders of an Email account..."
echo
2021-12-18 12:01:20 +01:00
2015-07-09 01:01:15 +03:00
# Show size in MB, strip long paths, strip tmp and new folders, rename .INBOX cur-folder
du -BM ~/users/"$USER" | sed -e "s:/home/$SYSUSER/users/$USER/::g" | grep -v "/cur$\|new$\|tmp$" | sed "s:cur$:.INBOX:" | grep -v "/home/$SYSUSER/users/$USER" | sort -nr
2021-12-18 12:01:20 +01:00
2015-07-09 00:26:45 +03:00
fi # /sizeuser
2015-07-09 00:06:31 +03:00
# # # # #
# USER DETAIL
# # # # #
if [ "$ACTION" == "userdetail" ]; then
echo "Extracting details of Email account..."
echo
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
if ! $(userexists "$USER"); then
echo "User \"$USER\" does not exist!"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
dumpvuser "$USER" | column -s $' ' -t
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
fi # /userdetail
2015-07-10 19:07:54 +03:00
# # # # #
# QUOTA
# # # # #
if [ "$ACTION" == "quota" ]; then
echo "Calculating account disk usage..."
echo
2021-12-18 12:01:20 +01:00
2021-12-18 13:02:49 +01:00
USAGE=$(cat quota | tail -n 1 | awk -F" " '{ print $2 }')
QUOTA=$(cat quota | tail -n 1 | awk -F" " '{ print $3 }' | sed 's/[A-Za-z]//g')
2021-12-18 12:01:20 +01:00
2015-07-10 23:38:35 +03:00
# If smaller than 1M, set usage to 1M to avoid miscalcuations
2021-12-18 12:01:20 +01:00
if ! echo $USAGE | grep -q "[A-Za-z]$"; then
2015-07-10 23:38:35 +03:00
USAGE="1"
else
USAGE=$(echo $USAGE | sed 's/[A-Za-z]//g')
2015-07-10 23:38:35 +03:00
fi
2021-12-18 12:01:20 +01:00
2015-07-10 19:07:54 +03:00
PERC=$(echo "scale=2; $USAGE/$QUOTA" | bc)
PERC=$(echo "scale=2; $PERC*100" | bc)
2021-12-18 12:01:20 +01:00
2015-07-10 19:07:54 +03:00
echo "$USAGE MB of $QUOTA MB are used ($PERC %)."
2021-12-18 12:01:20 +01:00
2015-07-10 19:07:54 +03:00
PERC=$(echo "scale=2; 100 - $PERC" | bc)
2021-12-18 12:01:20 +01:00
2021-12-18 13:02:49 +01:00
echo "You have "$(($QUOTA - $USAGE))" MB free ($PERC %)."
2021-12-18 12:01:20 +01:00
2015-07-10 19:07:54 +03:00
fi # /quota
2015-07-09 00:06:31 +03:00
# # # # #
# DELETE USER
# # # # #
if [ "$ACTION" == "deluser" ]; then
echo "Extracting details of Email account..."
echo
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
if ! $(userexists "$USER"); then
echo "User \"$USER\" does not exist!"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-09 00:06:31 +03:00
vdeluser "$USER"
2021-12-18 12:01:20 +01:00
if [ $? == 0 ]; then
# Send infomail
2015-07-10 12:43:40 +03:00
$MAILTYPE "Email account deleted" \
"An Email account has been deleted." \
"User: $USER"
2021-12-18 12:01:20 +01:00
# Update datasheet (delete entry in Email section)
LEAD='## > EMAIL'
TAIL='## < EMAIL'
2021-12-18 12:01:20 +01:00
notesdelete "$USER"
fi
2015-07-09 00:06:31 +03:00
fi # /deluser
2015-07-10 22:57:41 +03:00
# # # # #
# INSTALL WORDPRESS
# # # # #
if [ "$ACTION" == "installwp" ]; then
echo "Installing WordPress..."
echo
2021-12-18 12:01:20 +01:00
2015-07-10 22:57:41 +03:00
# $USER: Username for Wordpress
# $PASS: Email address for Wordpress user
2021-12-18 12:01:20 +01:00
2015-07-10 22:57:41 +03:00
if ! $(checkuser "$USER"); then
echo "Username \"$USER\" invalid"
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-10 22:57:41 +03:00
WEBDIR=$HOME/html
WPUSER=$USER
WPPASS=$(apg -n 1 -M NCL -m 14)
WPMAIL=$PASS
WPDOMAIN=http://$DOMAIN
# Get MySQL password
LEAD='## > MYSQL'
TAIL='## < MYSQL'
MYSQLUSER=$SYSUSER
MYSQLDB=${MYSQLUSER}_wp
MYSQLPASS=$(sed -n "/$LEAD/,/$TAIL/ p" $NOTES | grep "^Pass:" | awk -F" " '{ print $2 }')
# Check if ready for install: WEBDIR empty, Database available
if [ $(ls -a $WEBDIR | wc -l) -gt 2 ]; then
echo "The website directory \"$WEBDIR\" doesn't seem to be empty."
exit 1
fi
if [ $(mysql -e "SHOW DATABASES;" | tr -d "| " | grep -v Database | grep "^$$WPDB$" ; echo $?) = 0 ]; then
echo "The default database \"${USER}_wp\" already exists."
exit 1
fi
2021-12-18 12:01:20 +01:00
2015-07-10 22:57:41 +03:00
# Downloading wordpress
wget $WPDL
unzip $(basename $WPDL)
2015-07-10 22:57:41 +03:00
mv wordpress/* $WEBDIR
rm -r wordpress $(basename $WPDL)
2015-07-10 22:57:41 +03:00
# Downloading wp-cli
curl -O https://raw.githubusercontent.com/wp-cli/builds/gh-pages/phar/wp-cli.phar
chmod +x wp-cli.phar
2015-07-10 23:50:32 +03:00
mv wp-cli.phar $HOME/bin/wp-cli
2015-07-10 22:57:41 +03:00
# Create database
2015-07-10 23:50:32 +03:00
mysql -e "CREATE DATABASE $MYSQLDB;"
2021-12-18 12:01:20 +01:00
2015-07-10 22:57:41 +03:00
# Use wp-cli to create config.php and install WP
2015-07-10 23:50:32 +03:00
wp-cli core config --dbname=${MYSQLDB} --dbpass=${MYSQLPASS} --dbuser=${MYSQLUSER} --path=${WEBDIR}
wp-cli core install --url="$WPDOMAIN" --title="CHANGE THIS TITLE" --admin_user=${WPUSER} --admin_password=${WPPASS} --admin_email=${WPMAIL} --path=${WEBDIR}
2015-07-10 22:57:41 +03:00
# Update datasheet
TAIL='## < WORDPRESS'
sed -i "/$TAIL/i User: $WPUSER\nPass: $WPPASS\n" $NOTES
2021-12-18 12:01:20 +01:00
echo
2015-07-10 22:57:41 +03:00
echo "Wordpress successfully installed to $WPDOMAIN"
echo "You can login on $WPDOMAIN/wp-login.php"
echo "Please take a look into your data sheet for the login data."
2021-12-18 12:01:20 +01:00
2015-07-10 22:57:41 +03:00
fi # /installwp
2015-07-13 14:24:05 +03:00
# # # # #
# REMOVE WORDPRESS
# # # # #
if [ "$ACTION" == "uninstallwp" ]; then
echo "Uninstalling WordPress..."
echo
2021-12-18 12:01:20 +01:00
2015-07-13 14:24:05 +03:00
# $USER: Username for Wordpress
# $PASS: Email address for Wordpress user
2021-12-18 12:01:20 +01:00
2015-07-13 14:24:05 +03:00
WEBDIR=$HOME/html
MYSQLUSER=$SYSUSER
MYSQLDB=${MYSQLUSER}_wp
2021-12-18 12:01:20 +01:00
2015-07-13 14:24:05 +03:00
# Delete database and content of ~/htmp
mysql -e "DROP DATABASE ${MYSQLDB};"
rm -rf $WEBDIR/*
rm -rf $WEBDIR/.*
# Update datasheet
LEAD='## > WORDPRESS'
TAIL='## < WORDPRESS'
2021-12-18 12:01:20 +01:00
2015-07-13 14:24:05 +03:00
notesdelete ".*"
2021-12-18 12:01:20 +01:00
2015-07-13 14:24:05 +03:00
echo
echo "Wordpress successfully uninstalled."
2021-12-18 12:01:20 +01:00
2015-07-13 14:24:05 +03:00
fi # /uninstallwp