diff options
| author | Tim Vanderhoek <hoek@FreeBSD.org> | 2000-05-13 12:58:18 +0000 |
|---|---|---|
| committer | Tim Vanderhoek <hoek@FreeBSD.org> | 2000-05-13 12:58:18 +0000 |
| commit | 21014cca6425a4cd00c67c06bd8370e16d5435c7 (patch) | |
| tree | e2e2110d60a899e62c7923114c8af36c1a32f10b | |
| parent | 214d1c55f7439bb1e199aa51447a3bfffeb42904 (diff) | |
Notes
| -rw-r--r-- | usr.sbin/pkg_install/delete/main.c | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/usr.sbin/pkg_install/delete/main.c b/usr.sbin/pkg_install/delete/main.c index a1c5ba493529..4a75d118a8ef 100644 --- a/usr.sbin/pkg_install/delete/main.c +++ b/usr.sbin/pkg_install/delete/main.c @@ -24,6 +24,8 @@ static const char rcsid[] = * */ +#include <sys/types.h> +#include <sys/stat.h> #include <err.h> #include "lib.h" #include "delete.h" @@ -42,6 +44,8 @@ main(int argc, char **argv) int ch, error; char **pkgs, **start; char *pkgs_split; + char *tmp; + struct stat stat_s; pkgs = start = argv; while ((ch = getopt(argc, argv, Options)) != -1) @@ -107,8 +111,14 @@ main(int argc, char **argv) if (pkgs == start) warnx("missing package name(s)"), usage(); *pkgs = NULL; - if (!Fake && getuid() != 0) - errx(1, "you must be root to delete packages"); + tmp = getenv(PKG_DBDIR) ? getenv(PKG_DBDIR) : DEF_LOG_DIR; + (void) stat(tmp, &stat_s); + if (!Fake && getuid() && geteuid() != stat_s.st_uid) { + if (!Force) + errx(1, "you do not own %s, use -f to force", tmp); + else + warnx("you do not own %s (proceeding anyways)", tmp); + } if ((error = pkg_perform(start)) != 0) { if (Verbose) warnx("%d package deletion(s) failed", error); |
