[debhelper-devel] [debhelper] 01/01: Revert "Remove dh_suidregister"

Niels Thykier nthykier at moszumanska.debian.org
Sat Jan 16 13:32:54 UTC 2016


This is an automated email from the git hooks/post-receive script.

nthykier pushed a commit to branch master
in repository debhelper.

commit 8375d1a19a58f5579ed4762ebf98c53c325590f1
Author: Niels Thykier <niels at thykier.net>
Date:   Sat Jan 16 13:31:38 2016 +0000

    Revert "Remove dh_suidregister"
    
    This reverts commit 79a7701dc13dfdcbff1df8e191a87586a7abcd62.
    Lintian's report on dh_suidregister is unreliable and misses some
    instances.
---
 autoscripts/postinst-suid |   8 +++
 autoscripts/postrm-suid   |   4 ++
 dh_suidregister           | 134 ++++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 146 insertions(+)

diff --git a/autoscripts/postinst-suid b/autoscripts/postinst-suid
new file mode 100644
index 0000000..db4bc6d
--- /dev/null
+++ b/autoscripts/postinst-suid
@@ -0,0 +1,8 @@
+if [ "$1" = "configure" ]; then
+	if which suidregister >/dev/null 2>&1 && [ -e /etc/suid.conf ]; then
+	        suidregister -s #PACKAGE# /#FILE# #OWNER# #GROUP# #PERMS#
+	elif [ -e /#FILE# ]; then
+	        chown #OWNER#:#GROUP# /#FILE#
+	        chmod #PERMS# /#FILE#
+	fi
+fi
diff --git a/autoscripts/postrm-suid b/autoscripts/postrm-suid
new file mode 100644
index 0000000..a4cfecf
--- /dev/null
+++ b/autoscripts/postrm-suid
@@ -0,0 +1,4 @@
+if [ "$1" = remove ] && [ -e /etc/suid.conf ] && \
+   which suidunregister >/dev/null 2>&1; then
+        suidunregister -s #PACKAGE# /#FILE#
+fi
diff --git a/dh_suidregister b/dh_suidregister
new file mode 100755
index 0000000..73fadae
--- /dev/null
+++ b/dh_suidregister
@@ -0,0 +1,134 @@
+#!/usr/bin/perl
+
+=head1 NAME
+
+dh_suidregister - suid registration program (deprecated)
+
+=head1 SYNOPSIS
+
+Do not run!
+
+=head1 DESCRIPTION
+
+This program used to register suid and sgid files with L<suidregister(1)>,
+but with the introduction of L<dpkg-statoverride(8)>, registration of files
+in this way is unnecessary, and even harmful, so this program is deprecated
+and should not be used.
+
+=head1 CONVERTING TO STATOVERRIDE
+
+Converting a package that uses this program to use the new statoverride
+mechanism is easy. Just remove the call to B<dh_suidregister> from
+F<debian/rules>, and add a versioned conflicts into your F<control> file, as
+follows:
+
+  Conflicts: suidmanager (<< 0.50)
+
+The conflicts is only necessary if your package used to register things
+with suidmanager; if it did not, you can just remove the call to this
+program from your rules file.
+
+=cut
+
+use strict;
+use warnings;
+use Debian::Debhelper::Dh_Lib;
+init();
+
+my $notused=1;
+
+foreach my $package (@{$dh{DOPACKAGES}}) {
+	my $tmp=tmpdir($package);
+	my $suid=pkgfile($package,"suid");
+	my $tostrip='';
+
+	my @files;
+	if ($suid) {
+		@files=filearray($suid, $tmp);
+	}
+
+	if (($package eq $dh{FIRSTPACKAGE} || $dh{PARAMS_ALL}) && @ARGV) {
+		push @files, @ARGV;
+	}
+
+	if (! @files && ! $suid) {
+		# No files specified (and no empty debian/suid file), so
+		# guess what files to process.
+		@files=split(/\n/,`find $tmp -type f -perm /6000`);
+
+		# Strip the debian working directory off of the filenames.
+		$tostrip="$tmp/";
+	}
+	else {
+		# We will strip leading /'s, so the user can feed this
+		# program either absolute filenames, or relative filenames,
+		# and it will do the right thing either way.
+		$tostrip="/";
+	}
+
+	# Register files with suidregister.
+	foreach my $file (@files) {
+		# Strip leading $tostrip from $file.
+		$file=~s/^$tostrip//;
+
+		# Create the sed string that will be used to
+		# fill in the blanks in the autoscript files.
+		# Fill with the owner, group, and perms of the file.
+		my ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size,$atime,$mtime,$ctime,$blksize,$blocks) = stat("$tmp/$file");
+		# Now come up with the user and group names for the uid and
+		# gid.
+		my $user=getpwuid($uid);
+		if (! defined $user) {
+			warning("$file has odd uid $uid, not in /etc/passwd");
+			$user=$uid;
+		}
+		my $group=getgrgid($gid);
+		if (! defined $group) {
+			warning("$file has odd gid $gid not in /etc/group");
+			$group=$gid;
+		}
+		# Note that I have to print mode in octal, stripping file
+		# type.
+		my $sedstr=sprintf("s:#FILE#:$file:;s/#PACKAGE#/$package/;s/#OWNER#/$user/;s/#GROUP#/$group/;s/#PERMS#/%#o/",
+                                   $mode & 07777);
+		autoscript($package,"postinst","postinst-suid",$sedstr);
+		autoscript($package,"postrm","postrm-suid","$sedstr");
+	}
+
+	# Remove suid bits from files. This is delayed to this point, because
+	# of a situation with hard linked files if it is done earlier.
+	# See changelog for 2.0.77.
+	foreach my $file (@files) {
+		if ( -e "$tmp/$file") {
+			doit("chmod","a-s","$tmp/$file");
+		}
+	}
+
+	if (@files) {
+		warning("This program should no longer be used. Please read the dh_suidregister(1) man page.");
+		$notused=0;
+	}
+}
+
+# Although they called it, it's not going to do anything.
+if ($notused) {
+	warning("This program is obsolete, does nothing, and may be safely removed from your rules file.");
+}
+
+=head1 SEE ALSO
+
+L<debhelper(7)>
+
+This program is a part of debhelper.
+
+=head1 AUTHOR
+
+Joey Hess <joeyh at debian.org>
+
+=cut
+
+# Local Variables:
+# indent-tabs-mode: t
+# tab-width: 4
+# cperl-indent-level: 4
+# End:

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/debhelper/debhelper.git




More information about the debhelper-devel mailing list