2014-08-26 17:33:55 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
# Lynis
|
|
|
|
# ------------------
|
|
|
|
#
|
2016-03-13 16:00:39 +01:00
|
|
|
# Copyright 2007-2013, Michael Boelen
|
2021-01-07 15:22:19 +01:00
|
|
|
# Copyright 2007-2021, CISOfy
|
2016-03-13 16:00:39 +01:00
|
|
|
#
|
|
|
|
# Website : https://cisofy.com
|
|
|
|
# Blog : http://linux-audit.com
|
|
|
|
# GitHub : https://github.com/CISOfy/lynis
|
2014-08-26 17:33:55 +02:00
|
|
|
#
|
|
|
|
# Lynis comes with ABSOLUTELY NO WARRANTY. This is free software, and you are
|
|
|
|
# welcome to redistribute it under the terms of the GNU General Public License.
|
|
|
|
# See LICENSE file for usage of this software.
|
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
# File permissions
|
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
2020-10-22 00:13:42 +02:00
|
|
|
InsertSection "${SECTION_FILE_PERMISSIONS}"
|
2014-08-26 17:33:55 +02:00
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
# Test : FILE-7524
|
|
|
|
# Description : Perform file permissions check
|
2016-07-24 17:22:00 +02:00
|
|
|
Register --test-no FILE-7524 --weight L --network NO --category security --description "Perform file permissions check"
|
2014-08-26 17:33:55 +02:00
|
|
|
if [ ${SKIPTEST} -eq 0 ]; then
|
2014-09-15 12:01:09 +02:00
|
|
|
Display --indent 2 --text "- Starting file permissions check"
|
2015-12-21 21:17:15 +01:00
|
|
|
LogText "Test: Checking file permissions"
|
2019-08-17 16:49:11 +02:00
|
|
|
FOUND=0
|
2016-04-13 19:50:15 +02:00
|
|
|
for PROFILE in ${PROFILES}; do
|
|
|
|
LogText "Using profile ${PROFILE} for baseline."
|
2023-04-23 23:38:21 +02:00
|
|
|
FILES=$(${GREPBINARY} -E '^permfile=|^permdir=' ${PROFILE} | ${CUTBINARY} -d= -f2 | ${CUTBINARY} -d: -f1)
|
2019-08-17 16:49:11 +02:00
|
|
|
for F in ${FILES}; do
|
|
|
|
LogText "Test: checking file/directory ${F}"
|
|
|
|
if [ -f "${F}" ]; then
|
|
|
|
PERMS=$(${GREPBINARY} '^permfile=' ${PROFILE} | ${GREPBINARY} "=${F}:" | ${CUTBINARY} -d: -f2)
|
|
|
|
if HasCorrectFilePermissions "${F}" "${PERMS}"; then
|
|
|
|
Display --indent 4 --text "File: ${F}" --result "${STATUS_OK}" --color GREEN
|
|
|
|
else
|
|
|
|
Display --indent 4 --text "File: ${F}" --result "${STATUS_SUGGESTION}" --color YELLOW
|
|
|
|
FOUND=1
|
|
|
|
fi
|
|
|
|
elif [ -d "${F}" ]; then
|
|
|
|
PERMS=$(${GREPBINARY} '^permdir=' ${PROFILE} | ${GREPBINARY} "=${F}:" | ${CUTBINARY} -d: -f2)
|
|
|
|
if HasCorrectFilePermissions "${F}" "${PERMS}"; then
|
|
|
|
Display --indent 4 --text "Directory: ${F}" --result "${STATUS_OK}" --color GREEN
|
|
|
|
else
|
|
|
|
Display --indent 4 --text "Directory: ${F}" --result "${STATUS_SUGGESTION}" --color YELLOW
|
|
|
|
FOUND=1
|
|
|
|
fi
|
2016-09-10 16:12:44 +02:00
|
|
|
else
|
2019-08-17 16:49:11 +02:00
|
|
|
if IsVerbose; then Display --indent 4 --text "${F}" --result "${STATUS_NOT_FOUND}" --color WHITE; fi
|
|
|
|
LogText "Skipping file/directory ${F} as it does not exist on this system"
|
2016-09-10 16:12:44 +02:00
|
|
|
fi
|
2016-04-13 19:50:15 +02:00
|
|
|
done
|
2014-08-26 17:33:55 +02:00
|
|
|
done
|
2019-08-17 16:49:11 +02:00
|
|
|
if [ ${FOUND} -eq 1 ]; then
|
|
|
|
ReportSuggestion "${TEST_NO}" "Consider restricting file permissions" "See screen output or log file" "text:Use chmod to change file permissions"
|
|
|
|
fi
|
2014-09-15 12:01:09 +02:00
|
|
|
fi
|
2014-08-26 17:33:55 +02:00
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
|
2016-04-28 12:31:57 +02:00
|
|
|
WaitForKeyPress
|
2014-08-26 17:33:55 +02:00
|
|
|
|
|
|
|
#
|
|
|
|
#================================================================================
|
2021-01-07 15:22:19 +01:00
|
|
|
# Lynis - Copyright 2007-2021, CISOfy - https://cisofy.com
|