summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@cvs.openbsd.org>2011-06-20 21:53:54 +0000
committerIngo Schwarze <schwarze@cvs.openbsd.org>2011-06-20 21:53:54 +0000
commitd88c1c928a6a94d813d5b48f5cb0bf27d6091026 (patch)
tree61e9197cdb03ca54c411b29b2bdf4eb0e9731e28
parent22c7435dce6420fd94c18995b8529e940e17d682 (diff)
Restore changelist(5) wildcard support that we inadvertently killed
by the recent security(8) rewrite. While here: 1) Skip relative paths in changelist(5), and complain about them. 2) Skip file names ending in a tilde ('~') unless the tilde is explicitly specified in the changelist(5). That is, trailing wildcards will not match trailing tildes, as suggested by matthew@. Bug reported by both mk@ and matthew@. OK Andrew Fresh, also tested by and "move forward" mk@
-rw-r--r--libexec/security/security37
1 files changed, 27 insertions, 10 deletions
diff --git a/libexec/security/security b/libexec/security/security
index 935bbc984a5..4e0842082dd 100644
--- a/libexec/security/security
+++ b/libexec/security/security
@@ -1,6 +1,6 @@
#!/usr/bin/perl -T
-# $OpenBSD: security,v 1.14 2011/05/25 21:16:29 schwarze Exp $
+# $OpenBSD: security,v 1.15 2011/06/20 21:53:53 schwarze Exp $
#
# Copyright (c) 2011 Ingo Schwarze <schwarze@openbsd.org>
# Copyright (c) 2011 Andrew Fresh <andrew@afresh1.com>
@@ -819,20 +819,37 @@ sub check_changelist {
-s $filename or return;
nag !(open my $fh, '<', $filename), "open: $filename: $!" and return;
+ my @relative;
while (<$fh>) {
+ next if /^(?:#|\s*$)/;
chomp;
- next if /^(?:#|\/etc\/master.passwd|$)/;
- next if -d $_;
-
- if (s/^\+//) {
- $check_title = "======\n$_ MD5 checksums\n======";
- backup_md5 $_;
- } else {
- $check_title = "======\n$_ diffs (-OLD +NEW)\n======";
- backup_if_changed $_;
+ my $plus = s/^\+//;
+ unless (/^\//) {
+ push @relative, $_;
+ next;
+ }
+ my $tilda = /~$/;
+
+ foreach (glob) {
+ next if $_ eq '/etc/master.passwd';
+ next if /~$/ && !$tilda;
+ next if -d $_;
+
+ if ($plus) {
+ $check_title =
+ "======\n$_ MD5 checksums\n======";
+ backup_md5 $_;
+ } else {
+ $check_title =
+ "======\n$_ diffs (-OLD +NEW)\n======";
+ backup_if_changed $_;
+ }
}
}
close $fh;
+
+ $check_title = "Skipped relative paths in changelist(5):";
+ nag 1, $_ foreach @relative;
}
# Make backups of the labels for any mounted disks