mirror of https://github.com/CISOfy/lynis.git
165 lines
5.9 KiB
Bash
165 lines
5.9 KiB
Bash
#!/bin/sh
|
|
|
|
#################################################################################
|
|
#
|
|
# Lynis
|
|
# ------------------
|
|
#
|
|
# Copyright 2007-2013, Michael Boelen
|
|
# Copyright 2013-2016, CISOfy
|
|
#
|
|
# Website : https://cisofy.com
|
|
# Blog : http://linux-audit.com
|
|
# GitHub : https://github.com/CISOfy/lynis
|
|
#
|
|
# 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.
|
|
#
|
|
######################################################################
|
|
#
|
|
# Helper program to share details
|
|
#
|
|
######################################################################
|
|
#
|
|
# How to use:
|
|
# ------------
|
|
# Run: lynis show <option>
|
|
#
|
|
######################################################################
|
|
|
|
COMMANDS="audit show update"
|
|
OPTIONS="--auditor\n--check-all (-c)\n--config\n--cronjob (--cron)\n--debug\n--developer\n--help (-h)\n--info\n--license-key --log-file\n--manpage_(--man)\n--no-colors --no-log\n--pentest\n--profile\n--plugins-dir\n--quiet (-q)\n--quick (-Q)\n--report-file\n--reverse-colors\n--tests\n--tests-category\n--upload\n--verbose\n--version (-V)\n--view-categories"
|
|
|
|
SHOW_ARGS="commands help license man options pidfile plugindir profiles release releasedate tests version"
|
|
SHOW_HELP="lynis show ${BROWN}commands${NORMAL} (all available commands)
|
|
lynis show ${BROWN}help${NORMAL} (detailed information about arguments)
|
|
lynis show ${BROWN}license${NORMAL} (license details)
|
|
lynis show ${BROWN}man${NORMAL} (show help)
|
|
lynis show ${BROWN}options${NORMAL} (available flags and options)
|
|
lynis show ${BROWN}pidfile${NORMAL} (active file to stored process ID)
|
|
lynis show ${BROWN}plugindir${NORMAL} (directory with plugins)
|
|
lynis show ${BROWN}profiles${NORMAL} (discovered profiles)
|
|
lynis show ${BROWN}release${NORMAL} (version)
|
|
lynis show ${BROWN}releasedate${NORMAL} (date of release)
|
|
lynis show ${BROWN}tests skipped${NORMAL} (which tests to skip according profile)
|
|
lynis show ${BROWN}version${NORMAL} (${PROGRAM_NAME} version)"
|
|
|
|
AUDIT_ARGS="( dockerfile | system )"
|
|
AUDIT_HELP="
|
|
audit ${CYAN}dockerfile${NORMAL}
|
|
|
|
Perform audit on a Docker build file
|
|
${GRAY}Usage:${NORMAL} lynis audit dockerfile ${BROWN}<file>${NORMAL}
|
|
|
|
|
|
audit ${CYAN}system${NORMAL}
|
|
|
|
Perform system audit
|
|
${DARKGRAY}Usage:${NORMAL} lynis audit system
|
|
"
|
|
|
|
UPDATE_ARGS="info release"
|
|
|
|
SHOW_TESTS_ARGS="skipped"
|
|
|
|
COMMANDS_AUDIT_SYSTEM_USAGE="Usage: lynis audit system"
|
|
COMMANDS_AUDIT_SYSTEM_FUNCTION="Function: performs a security audit of the system"
|
|
|
|
if [ $# -gt 0 ]; then
|
|
case $1 in
|
|
"commands")
|
|
if [ $# -eq 1 ]; then
|
|
echo "\n${WHITE}Commands:${NORMAL}"
|
|
for I in ${COMMANDS}; do
|
|
echo "lynis ${CYAN}${I}${NORMAL}"
|
|
done
|
|
echo ""
|
|
else
|
|
shift
|
|
if [ $# -eq 1 ]; then
|
|
case $1 in
|
|
"audit") printf "${AUDIT_HELP}" ;;
|
|
"show") echo "${SHOW_HELP}" ;;
|
|
*) echo "Unknown argument for 'commands'"
|
|
esac
|
|
else
|
|
shift
|
|
case $1 in
|
|
"dockerfile")
|
|
echo "Usage: lynis audit dockerfile <file>"
|
|
;;
|
|
"system")
|
|
printf "${COMMANDS_AUDIT_SYSTEM_USAGE}\n${COMMANDS_AUDIT_SYSTEM_FUNCTION}\n"
|
|
;;
|
|
*)
|
|
echo "Unknown argument for 'commands'"
|
|
;;
|
|
esac
|
|
fi
|
|
fi
|
|
;;
|
|
"help")
|
|
if [ $# -eq 1 ]; then
|
|
echo "${WHITE}Commands${NORMAL}:"
|
|
for I in ${COMMANDS}; do
|
|
echo "lynis ${CYAN}${I}${NORMAL}"
|
|
done
|
|
echo ""
|
|
echo "${WHITE}Options${NORMAL}:\n${BLUE}${OPTIONS}${NORMAL}"
|
|
else
|
|
shift
|
|
case $1 in
|
|
"audit") echo "${AUDIT_HELP}" ;;
|
|
"show") echo "${SHOW_ARGS}" ;;
|
|
"update") echo "${UPDATE_ARGS}" ;;
|
|
"?") echo "${SHOW_ARGS}" ;;
|
|
*) echo "Invalid argument provided for lynis show help" ;;
|
|
esac
|
|
fi
|
|
;;
|
|
|
|
"license") echo "${PROGRAM_LICENSE}" ;;
|
|
"man") echo "Use ./lynis --man or man lynis" ;;
|
|
"options") echo "${OPTIONS}" ;;
|
|
"pidfile") echo "${PIDFILE}" ;;
|
|
"profile" | "profiles") for I in ${PROFILES}; do echo ${I}; done ;;
|
|
"plugindir") echo "${PLUGINDIR}" ;;
|
|
"release" | "version") echo "${PROGRAM_VERSION}" ;;
|
|
"releasedate") echo "${PROGRAM_RELEASE_DATE}" ;;
|
|
"tests")
|
|
if [ $# -gt 0 ]; then
|
|
shift
|
|
case $1 in
|
|
"skipped") echo "${SKIP_TESTS}" ;;
|
|
*) printf "Invalid argument provided to lynis show tests\n\n"
|
|
printf "Suggestions:\n"
|
|
for I in ${SHOW_TESTS_ARGS}; do
|
|
echo "lynis show tests ${I}"
|
|
done
|
|
;;
|
|
esac
|
|
else
|
|
echo "Need more arguments"
|
|
fi
|
|
;;
|
|
"?") echo "${SHOW_ARGS}" ;;
|
|
*) echo "Unknown option" ;;
|
|
esac
|
|
else
|
|
printf "\n ${WHITE}Provide an additional argument${NORMAL}\n\n"
|
|
for I in ${SHOW_ARGS}; do
|
|
echo " lynis show ${BROWN}${I}${NORMAL}"
|
|
done
|
|
printf "\n"
|
|
fi
|
|
|
|
|
|
ExitClean
|
|
|
|
# More additions:
|
|
# - categories
|
|
# - workdir
|
|
|
|
# The End
|