|
|
@ -7,34 +7,40 @@ lgsm_version="150316" |
|
|
|
|
|
|
|
# Description: Checks script, files and folders ownership and permissions. |
|
|
|
|
|
|
|
# Initializing useful variables |
|
|
|
# Useful variables |
|
|
|
currentuser="$(whoami)" |
|
|
|
scriptfullpath="${rootdir}/${selfname}" |
|
|
|
conclusionpermissionerror="0" |
|
|
|
|
|
|
|
fn_check_ownership(){ |
|
|
|
# Check script ownership |
|
|
|
if [ "${currentuser}" != "$(stat -c %U "${scriptfullpath}")" ] && [ "${currentuser}" != "$(stat -c %G "${scriptfullpath}")" ]; then |
|
|
|
conclusionpermissionerror="1" |
|
|
|
fn_print_fail_nl "Permission denied" |
|
|
|
fn_print_fail_nl "Oops ! Permission denied on ${selfname}" |
|
|
|
echo " * To check allowed user and group run ls -l ${selfname}" |
|
|
|
exit 1 |
|
|
|
fi |
|
|
|
# Check rootdir ownership |
|
|
|
if [ "${currentuser}" != "$(stat -c %U "${rootdir}")" ] && [ "${currentuser}" != "$(stat -c %G "${rootdir}")" ]; then |
|
|
|
fn_print_fail_nl "Oops ! Permission denied on ${rootdir}" |
|
|
|
echo " * To check allowed user and group run ls -l ${rootdir}" |
|
|
|
exit 1 |
|
|
|
} |
|
|
|
|
|
|
|
fn_check_permissions(){ |
|
|
|
# Checking permission on rootdir |
|
|
|
# Check rootdir permissions |
|
|
|
if [ -n "${rootdir}" ]; then |
|
|
|
rootdirperm="$(stat -c %a "${rootdir}")" |
|
|
|
userrootdirperm="${rootdirperm:0:1}" |
|
|
|
grouprootdirperm="${rootdirperm:1:1}" |
|
|
|
if [ "${userrootdirperm}" != "7" ] && [ "${grouprootdirperm}" != "7" ]; then |
|
|
|
fn_print_fail_nl "Permission issues found in root directory" |
|
|
|
echo " * Neither the user or group has full control of \"${rootdir}\"" |
|
|
|
echo " * You might wanna run : chmod -R 755 \"${rootdir}\"" |
|
|
|
conclusionpermissionerror="1" |
|
|
|
fi |
|
|
|
fi |
|
|
|
|
|
|
|
# Checking permissions on functions |
|
|
|
# Check functions permissions |
|
|
|
funcpermfail="0" |
|
|
|
if [ -n "${functionsdir}" ]; then |
|
|
|
while read -r filename |
|
|
@ -50,12 +56,14 @@ if [ -n "${functionsdir}" ]; then |
|
|
|
|
|
|
|
if [ "${funcpermfail}" == "1" ]; then |
|
|
|
fn_print_fail_nl "Permission issues found in functions." |
|
|
|
echo " * Neither the user or group has full control of at least some scripts in \"${functionsdir}\"" |
|
|
|
echo " * You might wanna run : chmod -R 755 \"${functionsdir}\"" |
|
|
|
fi |
|
|
|
fi |
|
|
|
} |
|
|
|
|
|
|
|
fn_check_permissions_conclusion(){ |
|
|
|
# Exit if errors found |
|
|
|
if [ "${conclusionpermissionerror}" == "1" ]; then |
|
|
|
exit 1 |
|
|
|
fi |
|
|
|