aboutsummaryrefslogtreecommitdiffstats
path: root/init-sh/level5.sh
blob: f2b7a55d2cd1c7a532e2e4aaab0ede83e734a2b5 (plain)
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
95
96
#!/bin/bash

#
# Security level implementation...
# Writen by Vandoorselaere Yoann <yoann@mandrakesoft.com>
#

if [ -f /etc/security/msec/init-sh/lib.sh ]; then
    . /etc/security/msec/init-sh/lib.sh
fi

chattr +a /var/log/*

# All events logged on tty12
AddRules "*.* /dev/tty12" /etc/syslog.conf

# Prevent all kind of connection
AddRules "ALL:ALL:DENY" /etc/hosts.deny

# No login as root
AddRules "" /etc/securetty

# Suid check
AddRules "CHECK_SUID_ROOT=yes" /etc/security/msec/security.conf
AddRules "CHECK_SUID_GROUP=yes" /etc/security/msec/security.conf
AddRules "CHECK_WRITABLE=yes" /etc/security/msec/security.conf
AddRules "CHECK_UNOWNED=yes" /etc/security/msec/security.conf
AddRules "CHECK_PROMISC=yes" /etc/security/msec/security.conf
AddRules "TTY_WARN=yes" /etc/security/msec/security.conf
AddRules "SYSLOG_WARN=yes" /etc/security/msec/security.conf

# Check every 1 minutes for promisc problem 
AddRules "*/1 * * * *    root    nice --adjustment=+19 /etc/security/msec/cron-sh/promisc_check.sh" /etc/crontab
AddRules "0 0-23 * * *    root    nice --adjustment=+19 /etc/security/msec/cron-sh/file_check.sh" /etc/crontab


# Wanna a password ?
LiloUpdate;
/sbin/lilo

# Disable all server :
IFS="
"

for service in `chkconfig --list | awk '{print $1}'`; do
    if [ "${service}" == "xfs" ]; then
	if [ ${HAVE_X}==1 ]; then
	    continue;
	fi
    fi

    if [ "${service}" == "network" ]; then continue; fi
    if [ "${service}" == "keytable" ]; then continue; fi
    if [ "${service}" == "crond" ]; then continue; fi
    if [ "${service}" == "gpm" ]; then continue; fi
    if [ "${service}" == "syslog" ]; then continue; fi
    
    
    chkconfig --del "${service}"
done

# Permissions
AddRules "umask 077" /etc/profile 

# Path
if [ ${HAVE_X}==1 ]; then
    AddRules "PATH=$PATH:/usr/X11R6/bin" /etc/profile
fi

echo
echo "You are now running your system in security level 5,"
echo "All services are disabled : try the chkconfig to enable one..."
echo "If you're on a senssible machine, ( which is probably the case )"
echo "you should compile the server from the sources".
echo
echo "Good luck. :-)"
echo