add-sftp-user/add-sftp.sh

64 lines
1.6 KiB
Bash

#!/bin/bash
LOG_FILE="/home/jelastic/add-sftp-user-addon/logs/script_output.log"
VERBOSE=1
log() {
local filename=${2:-$LOG_FILE}
local timestamp=$(date +"%Y-%m-%d %H:%M:%S")
local message="$timestamp - $1"
if [ "$VERBOSE" -eq 1 ]; then
echo "$message" | tee -a $filename
else
echo "$message" >> $filename
fi
}
# Generate random username
generate_username() {
echo "user$(shuf -i 10000-99999 -n 1)"
}
USERNAME=$1
PASSWORD=$2
# Check if user already exists, if yes generate a new one
while id "$USERNAME" &>/dev/null; do
USERNAME=$(generate_username)
done
USER_HOME="/home/sftpusers/$USERNAME"
ROOT_DIRECTORY="/var/www/webroot/ROOT"
ROOT_GROUP=$(stat -c '%G' $ROOT_DIRECTORY)
log "Script started"
[ ! -d "$ROOT_DIRECTORY" ] && { log "ERROR: ROOT_DIRECTORY $ROOT_DIRECTORY does not exist."; exit 2; }
mkdir -p $USER_HOME
useradd -d $USER_HOME $USERNAME
echo "$USERNAME:$PASSWORD" | chpasswd
log "User $USERNAME created with home directory $USER_HOME"
ln -s $ROOT_DIRECTORY $USER_HOME/ROOT
log "Symlink created for $USERNAME pointing to $ROOT_DIRECTORY"
usermod -aG $ROOT_GROUP $USERNAME
log "$USERNAME added to group $ROOT_GROUP"
chown $USERNAME:$ROOT_GROUP $USER_HOME
chmod 750 $USER_HOME
chown -R :$ROOT_GROUP /var/www/webroot/ROOT/
find /var/www/webroot/ROOT/ -type d -exec chmod 770 {} \;
find /var/www/webroot/ROOT/ -type f -exec chmod 660 {} \;
chmod g+s $ROOT_DIRECTORY
log "Script completed for user $USERNAME"
# Output the created username and password
echo "export CREATED_USERNAME=$USERNAME" >> /etc/profile
echo "export CREATED_PASSWORD=$PASSWORD" >> /etc/profile