Adding a get_uid_by_path to function.sh used by fixperms to crrect files and directories. I don't know if hte method is correct.. NEED CHECKING

This commit is contained in:
Steven Mondji-Lerider 2013-08-07 14:56:47 +00:00
parent 127c3d85c8
commit 79f56b4913
2 changed files with 26 additions and 7 deletions

View File

@ -1,4 +1,5 @@
#!/bin/bash -e #!/bin/bash -e
set -x
# #
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
# AlternC - Web Hosting System # AlternC - Web Hosting System
@ -105,7 +106,7 @@ doone() {
# Set the file readable only for the AlternC User # Set the file readable only for the AlternC User
mkdir -p "$REP" mkdir -p "$REP"
chown -R alterncpanel:$GID "$REP" chown -R $GID:$GID "$REP"
chmod 2770 -R "$REP" chmod 2770 -R "$REP"
# Delete existings ACL # Delete existings ACL
@ -125,20 +126,21 @@ fixdir() {
echo "Setting rights and ownership for user $LOGIN having gid $GID" echo "Setting rights and ownership for user $LOGIN having gid $GID"
fi fi
REP="$sub_dir" REP="$sub_dir"
#
REP_ID="$(get_uid_by_path "$REP")"
# Clean the line, then add a ligne indicating current working directory # Clean the line, then add a ligne indicating current working directory
printf '\r%*s' "${COLUMNS:-$(tput cols)}" '' printf '\r%*s' "${COLUMNS:-$(tput cols)}" ''
printf "\r%${COLUMNS}s" "AlternC fixperms.sh -> working on $REP" printf "\r%${COLUMNS}s" "AlternC fixperms.sh -> working on $REP"
# Set the file readable only for the AlternC User # Set the file readable only for the AlternC User
mkdir -p "$REP" mkdir -p "$REP"
chown -R alterncpanel:$GID "$REP" chown -R $REP_ID:$REP_ID "$REP"
chmod 2770 -R "$REP" chmod 2770 -R "$REP"
# Delete existings ACL # Delete existings ACL
# Set the defaults acl on all the files # Set the defaults acl on all the files
setfacl -b -k -n -R -m d:g:alterncpanel:rwx -m d:u::rwx -m d:g::rwx -m d:u:$GID:rwx -m d:g:$GID:rwx -m d:o::--- -m d:mask:rwx\ setfacl -b -k -n -R -m d:g:alterncpanel:rwx -m d:u::rwx -m d:g::rwx -m d:u:$REP_ID:rwx -m d:g:$REP_ID:rwx -m d:o::--- -m d:mask:rwx\
-Rm g:alterncpanel:rwx -m u:$GID:rwx -m g:$GID:rwx -m mask:rwx\ -Rm g:alterncpanel:rwx -m u:$REP_ID:rwx -m g:$REP_ID:rwx -m mask:rwx\
"$REP" "$REP"
echo -e "\nDone" echo -e "\nDone"
} }
@ -148,9 +150,10 @@ fixfile() {
/usr/bin/setfacl -bk "$file" /usr/bin/setfacl -bk "$file"
echo "gid: $GID" echo "gid: $GID"
echo "file: $file" echo "file: $file"
chown alterncpanel:$GID "$file" chown $GID:$GID "$file"
chmod 0770 "$file" chmod 0770 "$file"
/usr/bin/setfacl -m u:$GID:rw- -m g:$GID:rw- -m g:alterncpanel:rw- -m u:$GID:rw- -m g:$GID:rw- "$file" REP_ID="$(get_uid_by_path "$file")"
/usr/bin/setfacl -m u:$REP_ID:rw- -m g:$REP_ID:rw- -m g:alterncpanel:rw- -m u:$REP_ID:rw- -m g:$REP_ID:rw- "$file"
echo file ownership and ACLs changed echo file ownership and ACLs changed
} }

View File

@ -48,6 +48,22 @@ print_domain_letter() {
fi fi
} }
get_uid_by_path() {
local path="$1"
local sizepath=${#path}
local lastcar=${ALTERNC_HTML: -1}
if [ "$lastcar" != "/" ]
then
ALTERNC_HTML=$ALTERNC_HTML"/"
fi
local sizebasepath=${#ALTERNC_HTML}
local basepath=${path:0:($sizebasepath +2)}
local uid=`ls -n $basepath | head -n 2|tail -n 1| awk '{print $3}'`
echo $uid
}
# Return the html path for a account name # Return the html path for a account name
get_html_path_by_name() { get_html_path_by_name() {
local name="$1" local name="$1"