-
Notifications
You must be signed in to change notification settings - Fork 1
/
00_integrity.sh
executable file
·90 lines (77 loc) · 2.24 KB
/
00_integrity.sh
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
#!/usr/bin/env bash
# -------------------------------- #
# Copyright (C) 2008 Red Hat, Inc.
# Written by Dan Kopecek <[email protected]>
# Adapted for SCE by Martin Preisler <[email protected]>
RET=$XCCDF_RESULT_PASS
# For now we are storing these hardcoded in here,
# but we would like to pass them as XCCDF bound variables in the future!
CMDPATH="/bin:/sbin:/root/bin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin"
RPMVERIFY="/usr/bin/rpmverify"
COREPKG="coreutils"
DIRECTORY_LIST="/bin
/sbin
/lib
/usr/bin
/usr/sbin
/usr/lib
/usr/libexec
/tmp
/proc
/var"
function check_dirs () {
while read dir; do
if [[ ! -d "${dir}" ]]; then
echo "Directory \"${dir}\" does not exist!"
RET=${XCCDF_RESULT_FAIL}
fi
done <<EOF
${DIRECTORY_LIST}
EOF
}
function check_cmds () {
OUTPUT="$(${RPMVERIFY} --noscript --nomtime -f "${COREPKG}" 2> /dev/null)"
if (( $? != 0 )); then
if [[ -n "$(echo -e "${OUTPUT}" | sed -n 's|^[.A-Z0-9]\{8\}[[:space:]]\{1,\}[^c][[:space:]]\{1,\}.*$|&|p')" ]]; then
echo "Verify failed for package \"${COREPKG}\"!"
RET=$XCCDF_RESULT_FAIL
fi
fi
while read path; do
if [[ "$(stat -c '%A' "${path}" | cut -c 1)" != "l" ]]; then
COMMANDNAME="$(basename "${path}")"
COMMANDPATH="$(dirname "${path}")"
COMMANDPATHS="$(echo "${CMDPATH}" | tr ':' ' ' | sed -e "s|[[:space:]]${COMMANDPATH}||g" -e "s|^${COMMANDPATH}[[:space:]]||g")"
unset DUPLICATES
I=0
while read duplicate; do
if [[ -n "${duplicate}" ]]; then
if [[ "$(stat -c '%A' "${duplicate}" | cut -c 1)" != "l" ]]; then
DUPLICATES[$I]="${duplicate}"
I=$(($I + 1))
else
DEST="$(readlink -e "${duplicate}" 2> /dev/null)"
if [[ "${DEST}" != "${path}" ]]; then
DUPLICATES[$I]="${duplicate}"
I=$(($I + 1))
fi
fi
fi
done <<EOF
`find ${COMMANDPATHS} -maxdepth 1 -mindepth 1 -name "${COMMANDNAME}" 2> /dev/null`
EOF
if (( $I > 0 )); then
echo "Command \"${COMMANDNAME}\" (${path}) has duplicates in these locations: ${DUPLICATES[*]}!"
RET=$XCCDF_RESULT_FAIL
fi
fi
done <<EOF
`rpm -ql "${COREPKG}" | grep bin/`
EOF
}
# --- Main ----------------------- #
PATH="${CMDPATH}"
check_dirs
check_cmds
exit $RET
# --- EOF ------------------------ #