2014-08-26 17:33:55 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
# Lynis
|
|
|
|
# ------------------
|
|
|
|
#
|
2016-03-13 16:00:39 +01:00
|
|
|
# Copyright 2007-2013, Michael Boelen
|
|
|
|
# Copyright 2013-2016, CISOfy
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
# Read profile/template
|
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
2016-04-07 16:25:11 +02:00
|
|
|
Display --indent 2 --text "- Checking profiles..."
|
|
|
|
|
|
|
|
for PROFILE in ${PROFILES}; do
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Reading profile/configuration ${PROFILE}"
|
2016-04-19 12:38:00 +02:00
|
|
|
FIND=`egrep "^config:|^[a-z-].*=" ${PROFILE} | sed 's/ /!space!/g'`
|
2016-04-07 16:25:11 +02:00
|
|
|
for I in ${FIND}; do
|
2016-04-19 12:38:00 +02:00
|
|
|
if ContainsString "config:" "${I}"; then
|
2016-04-13 11:49:11 +02:00
|
|
|
# Old style configuration
|
|
|
|
OPTION=`echo ${I} | cut -d ':' -f2`
|
|
|
|
VALUE=`echo ${I} | cut -d ':' -f3 | sed 's/!space!/ /g'`
|
|
|
|
else
|
|
|
|
OPTION=`echo ${I} | cut -d '=' -f1`
|
|
|
|
VALUE=`echo ${I} | cut -d '=' -f2 | sed 's/!space!/ /g'`
|
|
|
|
fi
|
2016-04-19 12:38:00 +02:00
|
|
|
Debug "Profile option set: ${OPTION} (with value ${VALUE})"
|
2016-04-07 16:25:11 +02:00
|
|
|
|
|
|
|
case ${OPTION} in
|
|
|
|
|
|
|
|
# Define which compliance standards are enabled
|
2016-04-26 14:05:56 +02:00
|
|
|
compliance_standards | check-compliance)
|
2016-04-07 16:25:11 +02:00
|
|
|
COMPLIANCE_STANDARDS_ENABLED=`echo ${VALUE} | tr ',' ' '`
|
|
|
|
for I in ${COMPLIANCE_STANDARDS_ENABLED}; do
|
|
|
|
case $I in
|
|
|
|
cis) COMPLIANCE_ENABLE_CIS=1 ; Debug "Compliance scanning for CIS Benchmarks is enabled" ;;
|
|
|
|
hipaa) COMPLIANCE_ENABLE_HIPAA=1 ; Debug "Compliance scanning for HIPAA is enabled" ;;
|
|
|
|
iso27001) COMPLIANCE_ENABLE_ISO27001=1 ; Debug "Compliance scanning for ISO27001 is enabled" ;;
|
|
|
|
pci-dss) COMPLIANCE_ENABLE_PCI_DSS=1 ; Debug "Compliance scanning for PCI DSS is enabled" ;;
|
2016-04-19 17:43:33 +02:00
|
|
|
*) LogText "Result: Unknown compliance standard configured" ;;
|
2016-04-07 16:25:11 +02:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Maximum number of WAITing connections
|
|
|
|
connections_max_wait_state)
|
|
|
|
OPTIONS_CONN_MAX_WAIT_STATE="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Append something to URL for control information
|
|
|
|
control_url_append)
|
|
|
|
CONTROL_URL_APPEND="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Prepend an URL before control information link
|
|
|
|
control_url_prepend)
|
|
|
|
CONTROL_URL_PREPEND="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Protocol to use for control information link
|
|
|
|
control_url_protocol)
|
|
|
|
CONTROL_URL_PROTOCOL="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Append something to URL for control information (only applies to CUST-*)
|
|
|
|
custom_url_append)
|
|
|
|
CUSTOM_URL_APPEND="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Prepend an URL before control information link (only applies to CUST-*)
|
|
|
|
custom_url_prepend)
|
|
|
|
CUSTOM_URL_PREPEND="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Protocol to use for control information link
|
|
|
|
custom_url_protocol)
|
|
|
|
CUSTOM_URL_PROTOCOL="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Do not check security repository in sources.list (Debian/Ubuntu)
|
|
|
|
debian_skip_security_repository)
|
2016-04-26 14:05:56 +02:00
|
|
|
OPTION_DEBIAN_SKIP_SECURITY_REPOSITORY="${VALUE}"
|
2016-04-07 16:25:11 +02:00
|
|
|
;;
|
|
|
|
debug)
|
2016-04-26 14:05:56 +02:00
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|true|yes)"` && DEBUG=1
|
|
|
|
Debug "Debug mode set to ${DEBUG}"
|
2016-04-07 16:25:11 +02:00
|
|
|
;;
|
2016-04-25 10:18:09 +02:00
|
|
|
|
2016-04-26 13:51:54 +02:00
|
|
|
# Development mode (--developer)
|
|
|
|
developer-mode)
|
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|true|yes)"` && DEVELOPER_MODE=1
|
|
|
|
Debug "Developer mode set to ${DEVELOPER_MODE}"
|
|
|
|
;;
|
|
|
|
|
2016-04-25 10:18:09 +02:00
|
|
|
# Show non-zero exit code when errors are found
|
|
|
|
error-on-warnings)
|
2016-04-26 14:05:56 +02:00
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|true|yes)"` && ERROR_ON_WARNINGS=1
|
|
|
|
Debug "Exit with different code on warnings is set to ${ERROR_ON_WARNINGS}"
|
2016-04-25 10:18:09 +02:00
|
|
|
;;
|
2016-04-07 16:25:11 +02:00
|
|
|
|
|
|
|
# Skip FreeBSD port audit
|
|
|
|
freebsd_skip_portaudit)
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Option set: Skip FreeBSD portaudit"
|
2016-04-07 16:25:11 +02:00
|
|
|
OPTION_FREEBSD_SKIP_PORTAUDIT="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Lynis Enterprise: group name
|
|
|
|
group)
|
|
|
|
GROUP_NAME="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Lynis Enterprise license key
|
2016-04-26 14:05:56 +02:00
|
|
|
license_key | license-key)
|
2016-04-07 16:25:11 +02:00
|
|
|
LICENSE_KEY="${VALUE}"
|
2016-04-19 17:43:33 +02:00
|
|
|
Report "license_key=${LICENSE_KEY}"
|
2016-04-07 16:25:11 +02:00
|
|
|
;;
|
|
|
|
|
|
|
|
# Do (not) log tests if they have an different operating system
|
|
|
|
log_tests_incorrect_os)
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Option set: No logging for incorrect OS"
|
2016-04-07 16:25:11 +02:00
|
|
|
if [ "${VALUE}" = "no" ]; then LOG_INCORRECT_OS=0; else LOG_INCORRECT_OS=1; fi
|
|
|
|
;;
|
|
|
|
|
|
|
|
# What type of machine we are scanning (eg. desktop, server, server with storage)
|
|
|
|
machine_role)
|
|
|
|
MACHINE_ROLE="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Define if any found NTP daemon instance is configured as a server or client
|
|
|
|
ntpd_role)
|
|
|
|
NTPD_ROLE="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# How much seconds to wait between tests
|
2016-04-26 14:05:56 +02:00
|
|
|
pause_between_tests | pause-between-tests)
|
2016-04-07 16:25:11 +02:00
|
|
|
TEST_PAUSE_TIME="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
2016-04-13 11:49:11 +02:00
|
|
|
# Plugin
|
|
|
|
plugin)
|
|
|
|
LogText "Plugin ${VALUE} enabled according profile ${PROFILE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Plugin directory
|
2016-04-26 14:05:56 +02:00
|
|
|
plugindir | plugin-dir)
|
2016-04-13 12:07:46 +02:00
|
|
|
if [ "${PLUGINDIR}" = "" ]; then
|
|
|
|
PLUGINDIR="${VALUE}"
|
|
|
|
else
|
|
|
|
LogText "Plugin directory was already set to ${PLUGINDIR} before (most likely as a program argument), not overwriting"
|
|
|
|
fi
|
2016-04-13 11:49:11 +02:00
|
|
|
;;
|
|
|
|
|
2016-04-07 16:25:11 +02:00
|
|
|
# Profile name
|
|
|
|
profile_name)
|
|
|
|
PROFILE_NAME="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
2016-04-19 12:03:48 +02:00
|
|
|
# Quick (no waiting for keypresses)
|
|
|
|
quick)
|
2016-04-19 18:01:48 +02:00
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|yes)"` && QUICKMODE=1
|
2016-04-19 12:03:48 +02:00
|
|
|
Debug "Quickmode set to ${QUICKMODE}"
|
|
|
|
;;
|
|
|
|
|
2016-04-26 14:05:56 +02:00
|
|
|
# Inline tips about tool (default enabled)
|
|
|
|
show_tool_tips | show-tool-tips)
|
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|false|no)"` && SHOW_TOOL_TIPS=0
|
|
|
|
Debug "Show tool tips set to ${SHOW_TOOL_TIPS}"
|
2016-04-07 16:25:11 +02:00
|
|
|
;;
|
|
|
|
|
2016-04-25 11:10:23 +02:00
|
|
|
# Show warnings only
|
|
|
|
show-warnings-only)
|
2016-04-25 11:51:37 +02:00
|
|
|
QUIET=1
|
|
|
|
QUICKMODE=1
|
2016-04-26 14:05:56 +02:00
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|true|yes)"` && SHOW_WARNINGS_ONLY=1
|
2016-04-25 11:10:23 +02:00
|
|
|
Debug "Show warnings only set to ${SHOW_WARNINGS_ONLY}"
|
|
|
|
;;
|
|
|
|
|
2016-04-25 16:00:10 +02:00
|
|
|
# Skip plugins
|
|
|
|
skip-plugins)
|
2016-04-26 14:05:56 +02:00
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|true|yes)"` && RUN_PLUGINS=0
|
2016-04-25 16:00:10 +02:00
|
|
|
Debug "Run plugins is set to ${RUN_PLUGINS}"
|
|
|
|
;;
|
|
|
|
|
2016-04-19 12:38:00 +02:00
|
|
|
# Which tests to skip (skip-test=ABCD-1234 or skip-test=ABCD-1234:subtest)
|
|
|
|
skip-test)
|
2016-04-25 15:49:00 +02:00
|
|
|
STRING=`echo ${VALUE} | tr '[:upper:]' '[:lower:]'`
|
|
|
|
SKIP_TESTS="${SKIP_TESTS} ${STRING}"
|
2016-04-19 12:38:00 +02:00
|
|
|
;;
|
|
|
|
|
2016-04-07 16:25:11 +02:00
|
|
|
# Tests to always skip (useful for false positives or problematic tests)
|
|
|
|
test_skip_always)
|
|
|
|
TEST_SKIP_ALWAYS="${VALUE}"
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Tests to be skipped: ${VALUE}"
|
2016-04-07 16:25:11 +02:00
|
|
|
;;
|
|
|
|
|
|
|
|
# Do not check the latest version on the internet
|
2016-04-26 14:05:56 +02:00
|
|
|
skip_upgrade_test | skip-upgrade-test)
|
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|true|yes)"` && SKIP_UPGRADE_TEST=1
|
|
|
|
Debug "Skip upgrade test set to ${SKIP_UPGRADE_TEST}"
|
2016-04-07 16:25:11 +02:00
|
|
|
;;
|
|
|
|
|
|
|
|
# Define what kind of scan we are performing
|
2016-04-26 14:05:56 +02:00
|
|
|
test_scan_mode | test-scan-mode)
|
2016-04-07 16:25:11 +02:00
|
|
|
if [ "${VALUE}" = "light" ]; then SCAN_TEST_LIGHT="YES"; SCAN_TEST_MEDIUM="NO"; SCAN_TEST_HEAVY="NO"; fi
|
|
|
|
if [ "${VALUE}" = "normal" ]; then SCAN_TEST_LIGHT="YES"; SCAN_TEST_MEDIUM="YES"; SCAN_TEST_HEAVY="NO"; fi
|
|
|
|
if [ "${VALUE}" = "full" ]; then SCAN_TEST_LIGHT="YES"; SCAN_TEST_MEDIUM="YES"; SCAN_TEST_HEAVY="YES"; fi
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Server IP or hostname
|
|
|
|
update_server_address)
|
|
|
|
UPDATE_SERVER_ADDRESS="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Protocol (http, https)
|
|
|
|
update_server_protocol)
|
|
|
|
UPDATE_SERVER_PROTOCOL="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# File path to tarball on server
|
|
|
|
update_latest_version_download)
|
|
|
|
UPDATE_LATEST_VERSION_DOWNLOAD="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# File path to information file
|
|
|
|
update_latest_version_info)
|
|
|
|
UPDATE_LATEST_VERSION_INFO="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Local directory where lynis directory will be placed
|
|
|
|
update_local_directory)
|
|
|
|
UPDATE_LOCAL_DIRECTORY="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Local file to maintain current version
|
|
|
|
update_local_version_info)
|
|
|
|
UPDATE_LOCAL_VERSION_INFO="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Compression of uploads (enabled by default)
|
2016-04-26 14:05:56 +02:00
|
|
|
upload_compressed | compressed-uploads)
|
2016-04-07 16:25:11 +02:00
|
|
|
if [ "${VALUE}" = "0" ]; then COMPRESSED_UPLOADS=0; fi
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Options during upload of data
|
2016-04-26 14:05:56 +02:00
|
|
|
upload_options | upload-options)
|
2016-04-07 16:25:11 +02:00
|
|
|
UPLOAD_OPTIONS="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Proxy settings
|
2016-04-26 14:05:56 +02:00
|
|
|
upload_proxy_port | proxy-port)
|
2016-04-07 16:25:11 +02:00
|
|
|
UPLOAD_PROXY_PORT="${VALUE}"
|
|
|
|
;;
|
2016-04-26 14:05:56 +02:00
|
|
|
upload_proxy_protocol | proxy-protocol)
|
2016-04-07 16:25:11 +02:00
|
|
|
UPLOAD_PROXY_PROTOCOL="${VALUE}"
|
|
|
|
;;
|
2016-04-26 14:05:56 +02:00
|
|
|
upload_proxy_server | proxy-server)
|
2016-04-07 16:25:11 +02:00
|
|
|
UPLOAD_PROXY_SERVER="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
|
|
|
# Receiving system (IP address or hostname)
|
2016-04-26 14:05:56 +02:00
|
|
|
upload_server | upload-server)
|
2016-04-07 16:25:11 +02:00
|
|
|
UPLOAD_SERVER="${VALUE}"
|
|
|
|
;;
|
|
|
|
|
2016-04-19 19:47:50 +02:00
|
|
|
# Verbose output (--verbose)
|
|
|
|
verbose)
|
2016-04-26 14:05:56 +02:00
|
|
|
FIND=`echo "${VALUE}" | egrep "^(1|true|yes)"` && VERBOSE=1
|
2016-04-19 19:47:50 +02:00
|
|
|
Debug "Verbose set to ${VERBOSE}"
|
|
|
|
;;
|
|
|
|
|
2016-04-07 16:25:11 +02:00
|
|
|
# Catch all bad options and bail out
|
|
|
|
*)
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Unknown option ${OPTION} (with value: ${VALUE})"
|
2016-04-13 11:49:11 +02:00
|
|
|
echo "Fatal error: found errors in profile ${PROFILE}"
|
2016-04-07 16:25:11 +02:00
|
|
|
echo "Unknown option '${OPTION}' found (with value: ${VALUE})"
|
|
|
|
ExitFatal
|
|
|
|
;;
|
|
|
|
|
|
|
|
esac
|
|
|
|
|
|
|
|
done
|
2014-08-26 17:33:55 +02:00
|
|
|
done
|
|
|
|
#
|
|
|
|
#################################################################################
|
2016-04-19 12:38:00 +02:00
|
|
|
#
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Skip tests: ${SKIP_TESTS}"
|
2016-04-19 12:38:00 +02:00
|
|
|
#
|
|
|
|
#################################################################################
|
2014-08-26 17:33:55 +02:00
|
|
|
#
|
|
|
|
# Add group name to report
|
|
|
|
if [ ! "${GROUP_NAME}" = "" ]; then
|
2016-04-19 17:43:33 +02:00
|
|
|
Report "group=${GROUP_NAME}"
|
2014-08-26 17:33:55 +02:00
|
|
|
fi
|
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
# Set default values (only if not configured in profile)
|
|
|
|
|
|
|
|
if [ "${MACHINE_ROLE}" = "" ]; then
|
|
|
|
MACHINE_ROLE="server"
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Set option to default value: MACHINE_ROLE --> ${MACHINE_ROLE}"
|
2014-08-26 17:33:55 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ "${NTPD_ROLE}" = "" ]; then
|
|
|
|
NTPD_ROLE="client"
|
2016-04-19 17:43:33 +02:00
|
|
|
LogText "Set option to default value: NTPD_ROLE --> ${NTPD_ROLE}"
|
2014-08-26 17:33:55 +02:00
|
|
|
fi
|
|
|
|
|
|
|
|
#
|
|
|
|
#################################################################################
|
|
|
|
#
|
|
|
|
|
|
|
|
logtextbreak
|
|
|
|
|
|
|
|
#================================================================================
|
2015-12-22 16:02:32 +01:00
|
|
|
# Lynis - Copyright 2007-2016, Michael Boelen - CISOfy, https://cisofy.com
|