1
0
mirror of https://github.com/moparisthebest/pacman synced 2024-11-12 04:15:06 -05:00

Drop --usesudo option and add some checks related to ASROOT

Drop the --usesudo option and use it by default if running as a non-root
user. Check the usage of the --asroot option and do not allow it to be used
as a normal user. A few other small fixes, including a typo in $confdir.

Signed-off-by: Dan McGee <dan@archlinux.org>
This commit is contained in:
Dan McGee 2007-06-01 13:43:41 -04:00
parent 6f183cb984
commit fb10e0c797
2 changed files with 37 additions and 33 deletions

View File

@ -101,11 +101,11 @@ Install missing dependencies using \fBpacman\fP. When missing build-time or
run-time dependencies are found, \fBpacman\fP will try to resolve them. If run-time dependencies are found, \fBpacman\fP will try to resolve them. If
successful, the missing packages will be downloaded and installed. successful, the missing packages will be downloaded and installed.
.TP .TP
.B \-S, --usesudo .B \--asroot
Use \fBsudo\fP to perform all operations that require \fBpacman\fP. This is This option allows you to run \fBmakepkg\fP as root. You should not normally
useful for \fB--install\fP, \fB--rmdeps\fP, and \fB--syncdeps\fP. If you are run \fBmakepkg\fP as root unless you know what you are doing. For any
building packages as a non-root user as recommended, this option should be used operations that require \fBpacman\fP, \fBsudo\fP is normally used; this switch
if using any option that calls \fBpacman\fP. will call \fBpacman\fP directly.
.TP .TP
.B \--noconfirm .B \--noconfirm
(Passed to \fBpacman\fP) Prevent \fBpacman\fP from waiting for user input (Passed to \fBpacman\fP) Prevent \fBpacman\fP from waiting for user input

View File

@ -43,7 +43,6 @@ CLEANUP=0
CLEANCACHE=0 CLEANCACHE=0
DEP_BIN=0 DEP_BIN=0
DEP_SRC=0 DEP_SRC=0
SUDO=0
FORCE=0 FORCE=0
INFAKEROOT=0 INFAKEROOT=0
GENINTEG=0 GENINTEG=0
@ -241,10 +240,6 @@ handledeps() {
if [ "$DEP_SRC" = "0" -a "$DEP_BIN" = "0" ]; then if [ "$DEP_SRC" = "0" -a "$DEP_BIN" = "0" ]; then
return $R_DEPS_MISSING return $R_DEPS_MISSING
elif [ "$SUDO" = 0 -a $EUID -gt 0 ]; then
warning "$(gettext "Cannot auto-install missing dependencies as a normal user without sudo!")"
plain "$(gettext "Run makepkg as root or with -S to resolve dependencies automatically.")"
return $R_DEPS_MISSING
fi fi
if [ "$DEP_BIN" = "1" ]; then if [ "$DEP_BIN" = "1" ]; then
@ -252,7 +247,7 @@ handledeps() {
msg "$(gettext "Installing missing dependencies...")" msg "$(gettext "Installing missing dependencies...")"
local ret=0 local ret=0
if [ "$SUDO" = 1 ]; then if [ "$ASROOT" = 0 ]; then
sudo pacman $PACMAN_OPTS -S $striplist || ret=$? sudo pacman $PACMAN_OPTS -S $striplist || ret=$?
else else
pacman $PACMAN_OPTS -S $striplist || ret=$? pacman $PACMAN_OPTS -S $striplist || ret=$?
@ -335,7 +330,6 @@ resolvedeps() {
# fix flyspray bug #5923 # fix flyspray bug #5923
removedeps() { removedeps() {
[ "$RMDEPS" = "0" ] && return [ "$RMDEPS" = "0" ] && return
[ "$SUDO" = "0" -a $EUID -gt 0 ] && return
# runtimedeps and buildtimedeps are set when resolving deps # runtimedeps and buildtimedeps are set when resolving deps
local deplist="$runtimedeps $buildtimedeps" local deplist="$runtimedeps $buildtimedeps"
@ -349,7 +343,7 @@ removedeps() {
done done
msg "Removing installed dependencies..." msg "Removing installed dependencies..."
if [ "$SUDO" = "1" ]; then if [ "$ASROOT" = "0" ]; then
sudo pacman $PACMAN_OPTS -Rs $striplist sudo pacman $PACMAN_OPTS -Rs $striplist
else else
pacman $PACMAN_OPTS -Rs $striplist pacman $PACMAN_OPTS -Rs $striplist
@ -654,12 +648,13 @@ create_srcpackage() {
} }
installpackage() { installpackage() {
if [ "$INSTALL" = "1" -a "$SUDO" = "1" ]; then [ "$INSTALL" = "0" ] && return
msg "$(gettext "Installing package with pacman -U...")" msg "$(gettext "Installing package with pacman -U...")"
if [ "$ASROOT" = "0" ]; then
sudo pacman $PACMAN_OPTS -U $PKGDEST/${pkgname}-${pkgver}-${pkgrel}-${CARCH}${PKGEXT} sudo pacman $PACMAN_OPTS -U $PKGDEST/${pkgname}-${pkgver}-${pkgrel}-${CARCH}${PKGEXT}
exit $? exit $?
elif [ "$INSTALL" = "1" -a "$EUID" = "0" -a "$INFAKEROOT" != "1" ]; then else
msg "$(gettext "Installing package with pacman -U...")"
pacman $PACMAN_OPTS -U $PKGDEST/${pkgname}-${pkgver}-${pkgrel}-${CARCH}${PKGEXT} pacman $PACMAN_OPTS -U $PKGDEST/${pkgname}-${pkgver}-${pkgrel}-${CARCH}${PKGEXT}
exit $? exit $?
fi fi
@ -688,7 +683,7 @@ usage() {
# fix flyspray feature request #2978 # fix flyspray feature request #2978
echo "$(gettext " -R, --repackage Repackage contents of pkg/ without building")" echo "$(gettext " -R, --repackage Repackage contents of pkg/ without building")"
echo "$(gettext " -s, --syncdeps Install missing dependencies with pacman")" echo "$(gettext " -s, --syncdeps Install missing dependencies with pacman")"
echo "$(gettext " -S, --usesudo When calling pacman, use sudo")" echo "$(gettext " --asroot Allow makepkg to run as root user")"
echo "$(gettext " --source Do not build package; generate a source-only tarball")" echo "$(gettext " --source Do not build package; generate a source-only tarball")"
echo echo
echo "$(gettext "These options can be passed to pacman:")" echo "$(gettext "These options can be passed to pacman:")"
@ -717,7 +712,7 @@ _SRCDEST=${SRCDEST}
# Source makepkg.conf; fail if it is not found # Source makepkg.conf; fail if it is not found
if [ -r "$confdir/makepkg.conf" ]; then if [ -r "$confdir/makepkg.conf" ]; then
source "$condir/makepkg.conf" source "$confdir/makepkg.conf"
else else
error "$(gettext "%s not found. cannot continue")" "$confdir/makepkg.conf" error "$(gettext "%s not found. cannot continue")" "$confdir/makepkg.conf"
exit 1 # $E_CONFIG_ERROR # TODO: error codes exit 1 # $E_CONFIG_ERROR # TODO: error codes
@ -755,7 +750,6 @@ while [ "$#" -ne "0" ]; do
--clean) CLEANUP=1 ;; --clean) CLEANUP=1 ;;
--cleancache) CLEANCACHE=1 ;; --cleancache) CLEANCACHE=1 ;;
--syncdeps) DEP_BIN=1 ;; --syncdeps) DEP_BIN=1 ;;
--usesudo) SUDO=1 ;;
--builddeps) DEP_SRC=1 ;; --builddeps) DEP_SRC=1 ;;
--nodeps) NODEPS=1 ;; --nodeps) NODEPS=1 ;;
--noextract) NOEXTRACT=1 ;; --noextract) NOEXTRACT=1 ;;
@ -799,7 +793,6 @@ while [ "$#" -ne "0" ]; do
r) RMDEPS=1 ;; r) RMDEPS=1 ;;
R) REPKG=1 ;; R) REPKG=1 ;;
s) DEP_BIN=1 ;; s) DEP_BIN=1 ;;
S) SUDO=1 ;;
h) h)
usage usage
exit 0 exit 0
@ -826,12 +819,6 @@ while [ "$#" -ne "0" ]; do
shift shift
done done
# check for sudo
if [ "$SUDO" = "1" -a ! "$(type -p sudo)" ]; then
error "$(gettext "Cannot find the sudo binary! Is sudo installed?")"
exit 1
fi
if [ "$CLEANCACHE" = "1" ]; then if [ "$CLEANCACHE" = "1" ]; then
#fix flyspray feature request #5223 #fix flyspray feature request #5223
if [ -n "$SRCDEST" -a "$SRCDEST" != "$startdir" ]; then if [ -n "$SRCDEST" -a "$SRCDEST" != "$startdir" ]; then
@ -868,25 +855,27 @@ if [ -z $BUILDSCRIPT ]; then
fi fi
if [ "$INFAKEROOT" = "0" ]; then if [ "$INFAKEROOT" = "0" ]; then
if [ $EUID -eq 0 -a $ASROOT -eq 0 ]; then if [ $EUID -eq 0 -a "$ASROOT" = "0" ]; then
# Warn those who like to live dangerously. # Warn those who like to live dangerously.
error "$(gettext "Running makepkg as root is a BAD idea and can cause")" error "$(gettext "Running makepkg as root is a BAD idea and can cause")"
plain "$(gettext "permanent, catastrophic damage to your system. If you")" plain "$(gettext "permanent, catastrophic damage to your system. If you")"
plain "$(gettext "wish to run as root, please use the --asroot option.")" plain "$(gettext "wish to run as root, please use the --asroot option.")"
plain "" exit 1 # $E_USER_ABORT
elif [ $EUID -gt 0 -a "$ASROOT" = "1" ]; then
# Warn those who try to use the --asroot option when they are not root
error "$(gettext "The --asroot option is meant for the root user only.")"
plain "$(gettext "Please rerun makepkg without the --asroot flag.")"
exit 1 # $E_USER_ABORT exit 1 # $E_USER_ABORT
elif [ "$(check_buildenv fakeroot)" = "y" ]; then elif [ "$(check_buildenv fakeroot)" = "y" ]; then
if [ ! $(type -p fakeroot) ]; then if [ ! $(type -p fakeroot) ]; then
error "$(gettext "fakeroot must be installed if using the 'fakeroot' option")" error "$(gettext "fakeroot must be installed if using the 'fakeroot' option")"
plain "$(gettext "in the BUILDENV array in makepkg.conf.")" plain "$(gettext "in the BUILDENV array in makepkg.conf.")"
plain ""
exit 1 exit 1
fi fi
else else
warning "$(gettext "Running makepkg as an unprivileged user will result in non-root")" warning "$(gettext "Running makepkg as an unprivileged user will result in non-root")"
plain "$(gettext "ownership of the packaged files. Try using the fakeroot environment by")" plain "$(gettext "ownership of the packaged files. Try using the fakeroot environment by")"
plain "$(gettext "placing 'fakeroot' in the BUILDENV array in makepkg.conf.")" plain "$(gettext "placing 'fakeroot' in the BUILDENV array in makepkg.conf.")"
plain ""
sleep 1 sleep 1
fi fi
else else
@ -896,6 +885,17 @@ else
fi fi
fi fi
# check for sudo if we will need it during makepkg execution
if [ "$ASROOT" = "0" -a \( "$DEP_BIN" = "1" -o "$DEP_SRC" = "1" \
-o "$RMDEPS" = "1" -o "$INSTALL" = "1" \) ]; then
if [ ! "$(type -p sudo)" ]; then
error "$(gettext "Cannot find the sudo binary! Is sudo installed?")"
plain "$(gettext "Missing dependencies cannot be installed or removed as a normal user")"
plain "$(gettext "without sudo; install and configure sudo to auto-resolve dependencies.")"
exit 1
fi
fi
unset pkgname pkgver pkgrel pkgdesc url license groups provides md5sums force unset pkgname pkgver pkgrel pkgdesc url license groups provides md5sums force
unset replaces depends conflicts backup source install build makedepends unset replaces depends conflicts backup source install build makedepends
unset options noextract unset options noextract
@ -974,6 +974,10 @@ fi
date=$(date) date=$(date)
msg "$(gettext "Making package: %s")" "$pkgname $pkgver-$pkgrel ($date)" msg "$(gettext "Making package: %s")" "$pkgname $pkgver-$pkgrel ($date)"
if [ $EUID -eq 0 ]; then
warning "$(gettext "Running makepkg as root...")"
fi
# if we are creating a source-only package, go no further # if we are creating a source-only package, go no further
if [ "$SOURCEONLY" = "1" ]; then if [ "$SOURCEONLY" = "1" ]; then
if [ -f "$PKGDEST/${pkgname}-${pkgver}-${pkgrel}${SRCEXT}" \ if [ -f "$PKGDEST/${pkgname}-${pkgver}-${pkgrel}${SRCEXT}" \
@ -1199,7 +1203,7 @@ else
fi fi
done done
if [ "$EUID" = "0" ]; then if [ $EUID -eq 0 ]; then
# chown all source files to root.root # chown all source files to root.root
chown -R root.root "$srcdir" chown -R root.root "$srcdir"
fi fi