Allow running bastille and subcomands with help flags as regular user

This commit is contained in:
Lars Engels
2023-03-16 20:58:11 +01:00
parent 6776427e5a
commit 64c3b6045e
33 changed files with 74 additions and 14 deletions

View File

@@ -32,17 +32,6 @@ PATH=${PATH}:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin
. /usr/local/share/bastille/common.sh . /usr/local/share/bastille/common.sh
## root check first.
bastille_root_check() {
if [ "$(id -u)" -ne 0 ]; then
## permission denied
error_notify "Bastille: Permission Denied"
error_exit "root / sudo / doas required"
fi
}
bastille_root_check
## check for config existance ## check for config existance
bastille_conf_check() { bastille_conf_check() {
if [ ! -r "/usr/local/etc/bastille/bastille.conf" ]; then if [ ! -r "/usr/local/etc/bastille/bastille.conf" ]; then

View File

@@ -42,6 +42,8 @@ help|-h|--help)
;; ;;
esac esac
bastille_root_check
#Validate if ZFS is enabled in rc.conf and bastille.conf. #Validate if ZFS is enabled in rc.conf and bastille.conf.
if [ "$(sysrc -n zfs_enable)" = "YES" ] && [ ! "${bastille_zfs_enable}" = "YES" ]; then if [ "$(sysrc -n zfs_enable)" = "YES" ] && [ ! "${bastille_zfs_enable}" = "YES" ]; then
warn "ZFS is enabled in rc.conf but not bastille.conf. Do you want to continue? (N|y)" warn "ZFS is enabled in rc.conf but not bastille.conf. Do you want to continue? (N|y)"

View File

@@ -46,6 +46,8 @@ if [ $# -ne 2 ]; then
usage usage
fi fi
bastille_root_check
NEWNAME="${1}" NEWNAME="${1}"
IP="${2}" IP="${2}"

View File

@@ -46,6 +46,8 @@ if [ $# -eq 0 ]; then
usage usage
fi fi
bastille_root_check
COUNT=0 COUNT=0
RETURN=0 RETURN=0

View File

@@ -33,6 +33,14 @@ COLOR_GREEN=
COLOR_YELLOW= COLOR_YELLOW=
COLOR_RESET= COLOR_RESET=
bastille_root_check() {
if [ "$(id -u)" -ne 0 ]; then
## permission denied
error_notify "Bastille: Permission Denied"
error_exit "root / sudo / doas required"
fi
}
enable_color() { enable_color() {
. /usr/local/share/bastille/colors.pre.sh . /usr/local/share/bastille/colors.pre.sh
} }

View File

@@ -55,6 +55,8 @@ if [ $# -eq 1 ] || [ $# -gt 3 ]; then
usage usage
fi fi
bastille_root_check
ACTION=$1 ACTION=$1
shift shift

View File

@@ -46,6 +46,8 @@ if [ $# -gt 1 ]; then
usage usage
fi fi
bastille_root_check
USER="${1}" USER="${1}"
validate_user() { validate_user() {

View File

@@ -46,6 +46,8 @@ if [ $# -ne 0 ]; then
usage usage
fi fi
bastille_root_check
convert_symlinks() { convert_symlinks() {
# Work with the symlinks, revert on first cp error # Work with the symlinks, revert on first cp error
if [ -d "${bastille_releasesdir}/${RELEASE}" ]; then if [ -d "${bastille_releasesdir}/${RELEASE}" ]; then

View File

@@ -54,6 +54,8 @@ if [ $# -ne 2 ]; then
usage usage
fi fi
bastille_root_check
case "${OPTION}" in case "${OPTION}" in
-q|--quiet) -q|--quiet)
OPTION="-a" OPTION="-a"

View File

@@ -588,6 +588,8 @@ help|-h|--help)
;; ;;
esac esac
bastille_root_check
if echo "$3" | grep '@'; then if echo "$3" | grep '@'; then
BASTILLE_JAIL_IP=$(echo "$3" | awk -F@ '{print $2}') BASTILLE_JAIL_IP=$(echo "$3" | awk -F@ '{print $2}')
BASTILLE_JAIL_INTERFACES=$( echo "$3" | awk -F@ '{print $1}') BASTILLE_JAIL_INTERFACES=$( echo "$3" | awk -F@ '{print $1}')

View File

@@ -210,6 +210,8 @@ if [ $# -gt 1 ] || [ $# -lt 1 ]; then
usage usage
fi fi
bastille_root_check
## check what should we clean ## check what should we clean
case "${TARGET}" in case "${TARGET}" in
*-CURRENT|*-CURRENT-I386|*-CURRENT-i386|*-current) *-CURRENT|*-CURRENT-I386|*-CURRENT-i386|*-current)

View File

@@ -48,6 +48,8 @@ elif [ $# -eq 1 ]; then
TARGET_FILENAME="${1}" TARGET_FILENAME="${1}"
fi fi
bastille_root_check
if [ -z "${EDITOR}" ]; then if [ -z "${EDITOR}" ]; then
EDITOR=vi EDITOR=vi
fi fi

View File

@@ -71,6 +71,8 @@ if [ $# -gt 5 ] || [ $# -lt 1 ]; then
usage usage
fi fi
bastille_root_check
zfs_enable_check() { zfs_enable_check() {
# Temporarily disable ZFS so we can create a standard backup archive # Temporarily disable ZFS so we can create a standard backup archive
if [ "${bastille_zfs_enable}" = "YES" ]; then if [ "${bastille_zfs_enable}" = "YES" ]; then

View File

@@ -46,6 +46,8 @@ if [ $# -ne 0 ]; then
usage usage
fi fi
bastille_root_check
for _jail in ${JAILS}; do for _jail in ${JAILS}; do
bastille_jail_path=$(/usr/sbin/jls -j "${_jail}" path) bastille_jail_path=$(/usr/sbin/jls -j "${_jail}" path)
if [ ! -x "${bastille_jail_path}/usr/local/bin/htop" ]; then if [ ! -x "${bastille_jail_path}/usr/local/bin/htop" ]; then

View File

@@ -59,6 +59,8 @@ if [ $# -gt 3 ] || [ $# -lt 1 ]; then
usage usage
fi fi
bastille_root_check
TARGET="${1}" TARGET="${1}"
OPT_FORCE= OPT_FORCE=
USER_IMPORT= USER_IMPORT=

View File

@@ -55,6 +55,8 @@ if [ $# -ne 2 ]; then
usage usage
fi fi
bastille_root_check
OPTION="${1}" OPTION="${1}"
VALUE="${2}" VALUE="${2}"

View File

@@ -35,6 +35,12 @@ usage() {
error_exit "Usage: bastille list [-j|-a] [release [-p]|template|(jail|container)|log|limit|(import|export|backup)]" error_exit "Usage: bastille list [-j|-a] [release [-p]|template|(jail|container)|log|limit|(import|export|backup)]"
} }
if [ "$1" = help -o "$1" = "-h" -o "$1" = "--help" ]; then
usage
fi
bastille_root_check
if [ $# -eq 0 ]; then if [ $# -eq 0 ]; then
/usr/sbin/jls -N /usr/sbin/jls -N
fi fi
@@ -47,9 +53,6 @@ fi
if [ $# -gt 0 ]; then if [ $# -gt 0 ]; then
# Handle special-case commands first. # Handle special-case commands first.
case "$1" in case "$1" in
help|-h|--help)
usage
;;
all|-a|--all) all|-a|--all)
if [ -d "${bastille_jailsdir}" ]; then if [ -d "${bastille_jailsdir}" ]; then
DEFAULT_VALUE="-" DEFAULT_VALUE="-"

View File

@@ -50,6 +50,8 @@ else
_fstab="$@" _fstab="$@"
fi fi
bastille_root_check
## assign needed variables ## assign needed variables
_hostpath=$(echo "${_fstab}" | awk '{print $1}') _hostpath=$(echo "${_fstab}" | awk '{print $1}')
_jailpath=$(echo "${_fstab}" | awk '{print $2}') _jailpath=$(echo "${_fstab}" | awk '{print $2}')

View File

@@ -45,6 +45,8 @@ if [ $# -lt 1 ]; then
usage usage
fi fi
bastille_root_check
errors=0 errors=0
for _jail in ${JAILS}; do for _jail in ${JAILS}; do

View File

@@ -46,6 +46,8 @@ if [ $# -lt 2 ]; then
usage usage
fi fi
bastille_root_check
TARGET="${1}" TARGET="${1}"
JAIL_NAME="" JAIL_NAME=""
JAIL_IP="" JAIL_IP=""

View File

@@ -56,6 +56,8 @@ if [ $# -ne 1 ]; then
usage usage
fi fi
bastille_root_check
NEWNAME="${1}" NEWNAME="${1}"
update_jailconf() { update_jailconf() {

View File

@@ -45,6 +45,8 @@ if [ $# -lt 1 -o $# -gt 2 ]; then
usage usage
fi fi
bastille_root_check
for _jail in ${JAILS}; do for _jail in ${JAILS}; do
info "[${_jail}]:" info "[${_jail}]:"
jexec -l "${_jail}" /usr/sbin/service "$@" jexec -l "${_jail}" /usr/sbin/service "$@"

View File

@@ -46,6 +46,8 @@ if [ $# -gt 1 ] || [ $# -lt 1 ]; then
usage usage
fi fi
bastille_root_check
TARGET="${1}" TARGET="${1}"
shift shift

View File

@@ -46,6 +46,8 @@ if [ $# -ne 0 ]; then
usage usage
fi fi
bastille_root_check
for _jail in ${JAILS}; do for _jail in ${JAILS}; do
## test if running ## test if running
if [ "$(/usr/sbin/jls name | awk "/^${_jail}$/")" ]; then if [ "$(/usr/sbin/jls name | awk "/^${_jail}$/")" ]; then

View File

@@ -45,6 +45,8 @@ if [ $# -lt 1 ]; then
usage usage
fi fi
bastille_root_check
for _jail in ${JAILS}; do for _jail in ${JAILS}; do
info "[${_jail}]:" info "[${_jail}]:"
jexec -l "${_jail}" /usr/sbin/sysrc "$@" jexec -l "${_jail}" /usr/sbin/sysrc "$@"

View File

@@ -54,6 +54,8 @@ if [ $# -lt 1 -o $# -gt 2 ]; then
usage usage
fi fi
bastille_root_check
ACTION="${1}" ACTION="${1}"
TAGS="${2}" TAGS="${2}"

View File

@@ -116,6 +116,8 @@ if [ $# -lt 1 ]; then
bastille_usage bastille_usage
fi fi
bastille_root_check
## global variables ## global variables
TEMPLATE="${1}" TEMPLATE="${1}"
bastille_template=${bastille_templatesdir}/${TEMPLATE} bastille_template=${bastille_templatesdir}/${TEMPLATE}

View File

@@ -45,6 +45,8 @@ if [ $# -ne 0 ]; then
usage usage
fi fi
bastille_root_check
for _jail in ${JAILS}; do for _jail in ${JAILS}; do
info "[${_jail}]:" info "[${_jail}]:"
jexec -l "${_jail}" /usr/bin/top jexec -l "${_jail}" /usr/bin/top

View File

@@ -46,6 +46,8 @@ if [ $# -ne 1 ]; then
usage usage
fi fi
bastille_root_check
MOUNT_PATH=$1 MOUNT_PATH=$1
for _jail in ${JAILS}; do for _jail in ${JAILS}; do

View File

@@ -46,6 +46,8 @@ if [ $# -gt 2 ] || [ $# -lt 1 ]; then
usage usage
fi fi
bastille_root_check
TARGET="${1}" TARGET="${1}"
OPTION="${2}" OPTION="${2}"

View File

@@ -46,6 +46,8 @@ if [ $# -gt 3 ] || [ $# -lt 2 ]; then
usage usage
fi fi
bastille_root_check
TARGET="$1" TARGET="$1"
NEWRELEASE="$2" NEWRELEASE="$2"
OPTION="$3" OPTION="$3"

View File

@@ -154,6 +154,8 @@ if [ $# -gt 1 ] || [ $# -lt 1 ]; then
bastille_usage bastille_usage
fi fi
bastille_root_check
case "$1" in case "$1" in
*-RELEASE|*-release|*-RC1|*-rc1|*-RC2|*-rc2) *-RELEASE|*-release|*-RC1|*-rc1|*-RC2|*-rc2)
RELEASE=$1 RELEASE=$1

View File

@@ -82,6 +82,8 @@ help|-h|--help)
;; ;;
esac esac
bastille_root_check
## check ZFS enabled ## check ZFS enabled
if [ ! "${bastille_zfs_enable}" = "YES" ]; then if [ ! "${bastille_zfs_enable}" = "YES" ]; then
error_exit "ZFS not enabled." error_exit "ZFS not enabled."