You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
1.6 KiB
63 lines
1.6 KiB
#!/bin/bash
|
|
# info: change file permission
|
|
# options: USER FILE PERMISSIONS
|
|
#
|
|
# example: v-change-fs-file-permission admin readme.txt 0777
|
|
#
|
|
# This function changes file access permissions on the file system
|
|
|
|
user=$1
|
|
src_file=$2
|
|
permissions=$3
|
|
|
|
# Includes
|
|
# shellcheck source=/etc/hestiacp/hestia.conf
|
|
source /etc/hestiacp/hestia.conf
|
|
# shellcheck source=/usr/local/hestia/func/main.sh
|
|
source $HESTIA/func/main.sh
|
|
# load config file
|
|
source_conf "$HESTIA/conf/hestia.conf"
|
|
|
|
#----------------------------------------------------------#
|
|
# Verifications #
|
|
#----------------------------------------------------------#
|
|
|
|
check_args '3' "$#" 'USER FILE PERMISSIONS'
|
|
is_format_valid 'user'
|
|
is_object_valid 'user' 'USER' "$user"
|
|
|
|
# Perform verification if read-only mode is enabled
|
|
check_hestia_demo_mode
|
|
|
|
# Checking user homedir
|
|
homedir=$(grep "^$user:" /etc/passwd | cut -f 6 -d :)
|
|
if [ -z "$homedir" ]; then
|
|
echo "Error: user home directory doesn't exist"
|
|
exit 12
|
|
fi
|
|
|
|
# Checking source file
|
|
if [ ! -f "$src_file" ]; then
|
|
echo "Error: source file doesn't exist $src_file"
|
|
exit 3
|
|
fi
|
|
|
|
# Checking source path
|
|
rpath=$(readlink -f "$src_file")
|
|
if [ -z "$(echo $rpath | egrep "^/tmp|^$homedir")" ]; then
|
|
echo "Error: invalid source path $src_file"
|
|
exit 2
|
|
fi
|
|
|
|
# Changing file permissions
|
|
user_exec chmod -R $permissions "$src_file" > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
echo "Error: access permission on $src_file was not changed"
|
|
exit 3
|
|
fi
|
|
|
|
$BIN/v-log-action "system" "Info" "System" "File system permissions changed (User: $user, File: $src_file, Permissions: $permissions)."
|
|
|
|
# Exiting
|
|
exit
|