File: set_perms.sh

package info (click to toggle)
horde3 3.0.4-4sarge7
  • links: PTS
  • area: main
  • in suites: sarge
  • size: 15,980 kB
  • ctags: 16,295
  • sloc: php: 68,726; xml: 2,382; sql: 498; makefile: 74; sh: 63; pascal: 6
file content (94 lines) | stat: -rw-r--r-- 1,921 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#!/bin/sh
#
# set_perms.sh - Jon Parise <jon@csh.rit.edu>
#
# $Horde: horde/scripts/set_perms.sh,v 1.7 2001/04/15 01:55:32 chuck Exp $

# "Dangerous" PHP scripts
#
DANGEROUS_FILES="test.php"

# Default non-web server user who will own the tree.
#
OWNER=root

# Introductory text
#
cat << EOF

This script will set the permissions on your Horde
tree so that the files will be accessible by the web
server.

You can cancel this script at any time using Ctrl-C.

EOF

# Verify that we're at the top of the Horde tree.
#
pwd
echo
echo -n "Is this directory the top of your Horde installation? [y,N] "
read RESPONSE 
if [ "$RESPONSE" != "y" -a "$RESPONSE" != "Y" ]; then
    echo
    echo -n "Enter your Horde directory: "
    read DIR  
	if [ "x$DIR" = "x" ]; then
		echo "Exiting..."
		exit
	else
    	cd $DIR
	fi
fi
echo

# Get the web server's group.
#
echo -n "Under what group does the web process run? [nobody] "
read WEB_GROUP
if [ "x$WEB_GROUP" = "x" ]; then
    WEB_GROUP="nobody" 
fi

# Ask before proceeding.
#
echo
echo -n "Proceed with changing ownership and permissions? [y,N] "
read RESPONSE 
if [ "$RESPONSE" != 'y' -a "$RESPONSE" != 'Y' ]; then
    echo "Exiting..."
    exit
fi

# Set the user and group ownership recursively.
#
echo
echo -n "Setting ownership recursively... "
chown -R $OWNER .
chgrp -R $WEB_GROUP .
echo "done."

# Set the permissions on files (0640) and directories (0750).
#
echo -n "Setting permissions recursively... "
find . -type f -exec chmod 0640 {} \;
find . -type d -exec chmod 0750 {} \;
echo "done."

# Disable any "dangerous" PHP scripts in the distribution (0000).
#
echo -n "Disabling potentially \"dangerous\" PHP scripts... "
for FILE in $DANGEROUS_FILES; do
	if [ -f $FILE ]; then
		chmod 0000 $FILE
	fi
done
echo "done."

# Say good-bye.
#
echo
echo "If you received any errors, you may not have sufficient access"
echo "to change file ownership and permissions."
echo