summaryrefslogtreecommitdiff
path: root/usr.sbin/pkg_add/OpenBSD/ArcCheck.pm
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/pkg_add/OpenBSD/ArcCheck.pm')
-rw-r--r--usr.sbin/pkg_add/OpenBSD/ArcCheck.pm15
1 files changed, 14 insertions, 1 deletions
diff --git a/usr.sbin/pkg_add/OpenBSD/ArcCheck.pm b/usr.sbin/pkg_add/OpenBSD/ArcCheck.pm
index 4bbbac5ad14..631ad74403a 100644
--- a/usr.sbin/pkg_add/OpenBSD/ArcCheck.pm
+++ b/usr.sbin/pkg_add/OpenBSD/ArcCheck.pm
@@ -1,5 +1,5 @@
# ex:ts=8 sw=4:
-# $OpenBSD: ArcCheck.pm,v 1.25 2014/04/22 18:22:20 espie Exp $
+# $OpenBSD: ArcCheck.pm,v 1.26 2014/08/10 10:01:03 espie Exp $
#
# Copyright (c) 2005-2006 Marc Espie <espie@openbsd.org>
#
@@ -98,6 +98,15 @@ sub prepare_long
} else {
$entry = $self->prepare($item->name);
}
+ if ($< && $entry->{uid} == $<) {
+ $entry->{uname} = $item->{owner} // "root";
+ delete $entry->{uid};
+ }
+ if ($( && $entry->{gid} == $() {
+ $entry->{gname} = $item->{group} // "bin";
+ delete $entry->{gid};
+ }
+ $entry->recheck_owner;
if (!defined $entry->{uname}) {
$self->fatal("No user name for #1 (uid #2)",
$item->name, $entry->{uid});
@@ -106,6 +115,10 @@ sub prepare_long
$self->fatal("No group name for #1 (uid #2)",
$item->name, $entry->{gid});
}
+ # disallow writable files/dirs without explicit annotation
+ if (!defined $item->{mode}) {
+ $entry->{mode} &= ~(S_IWUSR|S_IWGRP|S_IWOTH);
+ }
# if we're going to set the group or owner, sguid bits won't
# survive the extraction
if (defined $item->{group} || defined $item->{owner}) {