File: selinux.test

package info (click to toggle)
yasat 848-1
  • links: PTS
  • area: main
  • in suites: buster, stretch
  • size: 1,052 kB
  • ctags: 9
  • sloc: sh: 6,127; makefile: 47
file content (81 lines) | stat: -rwxr-xr-x 3,769 bytes parent folder | download | duplicates (3)
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
#!/bin/sh
################################################################################
#                                                                              #
#   Copyright (C) 2008-2015 LABBE Corentin <clabbe.montjoie@gmail.com>
#
#    YASAT is free software: you can redistribute it and/or modify
#    it under the terms of the GNU General Public License as published by
#    the Free Software Foundation, either version 3 of the License, or
#    (at your option) any later version.
#
#    YASAT is distributed in the hope that it will be useful,
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#    GNU General Public License for more details.
#
#    You should have received a copy of the GNU General Public License
#    along with YASAT.  If not, see <http://www.gnu.org/licenses/>.
#                                                                              #
################################################################################


Title "Check SELinux status"

if [ ! -e "$SCAN_ROOT/etc/selinux" -o ! -e "$SCAN_ROOT/etc/selinux/config" ] ; then
	TESTNAME='Check SELinux'
	Compliance --result 'NOTTESTED' --plugin selinux --nsag 2.4.2 --nsag 2.4.2.1 --nsag 2.4.3.1 --nsag 2.4.3.2 --nsag 2.4.4 --nsag 2.4.5 --cce 3977-6 --cce 3999-0 --cce 4254-9 --cce 4148-3 --cce 3668-1 --cce 4129-3 --cce 14991-4
	return 0;
fi

TESTNAME='YASAT_TEST_SELINUX_ENABLED NSAG=2.4.2 CCEID=3977-6 Check if SELinux is enabled'
FindValueOfEqual $SCAN_ROOT/etc/selinux/config SELINUX JUSTTEST
if [ -z "$RESULTAT" ] ;then
	Compliance --result NOK --plugin selinux --nsag 2.4.2 --cce '3977-6' --cce '3999-0'
	Display --indent 2 --text "SELinux" --result DISABLED --color RED
else
	if [ "$RESULTAT" = 'disabled' ] ; then
		Compliance --result NOK --plugin selinux --nsag 2.4.2 --cce '3977-6' --cce '3999-0'
		Display --indent 2 --text "SELinux" --result DISABLED --color RED
	else
		Compliance --result OK --plugin selinux --nsag 2.4.2 --cce '3977-6'
		Display --indent 2 --text "SELinux" --result ENABLED --color GREEN
		TESTNAME='YASAT_TEST_SELINUX_ENFORCING NSAG=2.4.2 CCEID=3999-0 Check if SELinux is enforced'
		if [ "$RESULTAT" = 'enforcing' ] ; then
			Display --indent 2 --text "SELinux" --result ENFORCING --color GREEN
			Compliance --result OK --plugin selinux --nsag 2.4.2 --cce '3999-0'
		else
			Display --indent 2 --text "SELinux" --result PERMISSIVE --color ORANGE
			Compliance --result NOK --plugin selinux --nsag 2.4.2 --cce '3999-0'
		fi
	fi
fi

TESTNAME='YASAT_TEST_SELINUX_MODE NSAG=2.4.2 Check if SELinux is in targeted mode'
FindValueOfEqual $SCAN_ROOT/etc/selinux/config SELINUXTYPE JUSTTEST
if [ ! -z "$RESULTAT" ] ;then
	Display --indent 2 --text "SELinux Mode" --result $RESULTAT --color GREEN
fi

TESTNAME='YASAT_TEST_SELINUX_CURRENT_ENABLE NSAG=2.4.2.1 Check if SELinux is currently enabled'
if [ "$SCAN_ROOT" = '/' ] ; then
	Display --indent 2 --text "SELinux current mode" --result TODO --color BLUE
	Compliance --result 'NOTIMPL' --plugin selinux --nsag 2.4.2.1
else
	Display --indent 2 --text "SELinux current mode" --result SKIP --color BLUE
	Compliance --result 'NOTTESTED' --plugin selinux --nsag 2.4.2.1
fi

TESTNAME='Disable and Remove SETroubleshoot if Possible'
Compliance --result 'NOTIMPL' --plugin selinux --nsag 2.4.3.1 --cce 4254-9 --cce 4148-3

TESTNAME='Disable MCS Translation Service (mcstrans) if Possible'
Compliance --result 'NOTIMPL' --plugin selinux --nsag 2.4.3.2 --cce 3668-1 --cce 4129-3

TESTNAME='Check for Unconfined Daemons'
Compliance --result 'NOTIMPL' --plugin selinux --nsag 2.4.4

TESTNAME='Check for Unlabeled Device Files'
Compliance --result 'NOTIMPL' --plugin selinux --nsag 2.4.5 --cce 14991-4

return 0;