mirror of
https://github.com/hackacad/bastille.git
synced 2025-12-21 01:30:52 +01:00
Allow running bastille and subcomands with help flags as regular user
This commit is contained in:
@@ -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
|
||||||
|
|||||||
@@ -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)"
|
||||||
|
|||||||
@@ -46,6 +46,8 @@ if [ $# -ne 2 ]; then
|
|||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
bastille_root_check
|
||||||
|
|
||||||
NEWNAME="${1}"
|
NEWNAME="${1}"
|
||||||
IP="${2}"
|
IP="${2}"
|
||||||
|
|
||||||
|
|||||||
@@ -46,6 +46,8 @@ if [ $# -eq 0 ]; then
|
|||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
bastille_root_check
|
||||||
|
|
||||||
COUNT=0
|
COUNT=0
|
||||||
RETURN=0
|
RETURN=0
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -55,6 +55,8 @@ if [ $# -eq 1 ] || [ $# -gt 3 ]; then
|
|||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
bastille_root_check
|
||||||
|
|
||||||
ACTION=$1
|
ACTION=$1
|
||||||
shift
|
shift
|
||||||
|
|
||||||
|
|||||||
@@ -46,6 +46,8 @@ if [ $# -gt 1 ]; then
|
|||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
bastille_root_check
|
||||||
|
|
||||||
USER="${1}"
|
USER="${1}"
|
||||||
|
|
||||||
validate_user() {
|
validate_user() {
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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"
|
||||||
|
|||||||
@@ -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}')
|
||||||
|
|||||||
@@ -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)
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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=
|
||||||
|
|||||||
@@ -55,6 +55,8 @@ if [ $# -ne 2 ]; then
|
|||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
bastille_root_check
|
||||||
|
|
||||||
OPTION="${1}"
|
OPTION="${1}"
|
||||||
VALUE="${2}"
|
VALUE="${2}"
|
||||||
|
|
||||||
|
|||||||
@@ -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="-"
|
||||||
|
|||||||
@@ -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}')
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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=""
|
||||||
|
|||||||
@@ -56,6 +56,8 @@ if [ $# -ne 1 ]; then
|
|||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
bastille_root_check
|
||||||
|
|
||||||
NEWNAME="${1}"
|
NEWNAME="${1}"
|
||||||
|
|
||||||
update_jailconf() {
|
update_jailconf() {
|
||||||
|
|||||||
@@ -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 "$@"
|
||||||
|
|||||||
@@ -46,6 +46,8 @@ if [ $# -gt 1 ] || [ $# -lt 1 ]; then
|
|||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
bastille_root_check
|
||||||
|
|
||||||
TARGET="${1}"
|
TARGET="${1}"
|
||||||
shift
|
shift
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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 "$@"
|
||||||
|
|||||||
@@ -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}"
|
||||||
|
|
||||||
|
|||||||
@@ -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}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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}"
|
||||||
|
|
||||||
|
|||||||
@@ -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"
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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."
|
||||||
|
|||||||
Reference in New Issue
Block a user