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.
60 lines
1.4 KiB
60 lines
1.4 KiB
#!/bin/bash
|
|
# info: open file
|
|
# options: USER FILE
|
|
#
|
|
# example: v-check-fs-permission admin readme.txt
|
|
#
|
|
# This function opens/reads files on the file system
|
|
|
|
#----------------------------------------------------------#
|
|
# Variables & Functions #
|
|
#----------------------------------------------------------#
|
|
|
|
user=$1
|
|
src=$2
|
|
|
|
# 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 '2' "$#" 'USER FILE'
|
|
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 path
|
|
if [ -n "$src" ]; then
|
|
rpath=$(readlink -f "$src")
|
|
if [ -z "$(echo $rpath | egrep "^/tmp|^$homedir")" ]; then
|
|
echo "Error: invalid source path $user $src"
|
|
exit 2
|
|
fi
|
|
fi
|
|
|
|
# Checking if file has readable permission
|
|
user_exec ls "$src" > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
echo "Error: can't read $src"
|
|
exit 1
|
|
fi
|
|
|
|
# Exiting
|
|
exit
|