Blame SOURCES/shadow-4.9-getsubids.patch

2de3ab
diff -up shadow-4.9/man/getsubids.1.xml.getsubids shadow-4.9/man/getsubids.1.xml
2de3ab
--- shadow-4.9/man/getsubids.1.xml.getsubids	2021-11-18 16:27:33.951053120 +0100
2de3ab
+++ shadow-4.9/man/getsubids.1.xml	2021-11-18 16:27:33.951053120 +0100
2de3ab
@@ -0,0 +1,141 @@
2de3ab
+
2de3ab
+
2de3ab
+   Copyright (c) 2021 Iker Pedrosa
2de3ab
+   All rights reserved.
2de3ab
+
2de3ab
+   Redistribution and use in source and binary forms, with or without
2de3ab
+   modification, are permitted provided that the following conditions
2de3ab
+   are met:
2de3ab
+   1. Redistributions of source code must retain the above copyright
2de3ab
+      notice, this list of conditions and the following disclaimer.
2de3ab
+   2. Redistributions in binary form must reproduce the above copyright
2de3ab
+      notice, this list of conditions and the following disclaimer in the
2de3ab
+      documentation and/or other materials provided with the distribution.
2de3ab
+   3. The name of the copyright holders or contributors may not be used to
2de3ab
+      endorse or promote products derived from this software without
2de3ab
+      specific prior written permission.
2de3ab
+
2de3ab
+   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
2de3ab
+   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
2de3ab
+   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
2de3ab
+   PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT
2de3ab
+   HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
2de3ab
+   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
2de3ab
+   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
2de3ab
+   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
2de3ab
+   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
2de3ab
+   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
2de3ab
+   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2de3ab
+-->
2de3ab
+
2de3ab
+  "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
2de3ab
+
2de3ab
+]>
2de3ab
+
2de3ab
+<refentry id='getsubids.1'>
2de3ab
+  <refentryinfo>
2de3ab
+    <author>
2de3ab
+      <firstname>Iker</firstname>
2de3ab
+      <surname>Pedrosa</surname>
2de3ab
+      <contrib>Creation, 2021</contrib>
2de3ab
+    </author>
2de3ab
+  </refentryinfo>
2de3ab
+  <refmeta>
2de3ab
+    <refentrytitle>getsubids</refentrytitle>
2de3ab
+    <manvolnum>1</manvolnum>
2de3ab
+    <refmiscinfo class="sectdesc">User Commands</refmiscinfo>
2de3ab
+    <refmiscinfo class="source">shadow-utils</refmiscinfo>
2de3ab
+    <refmiscinfo class="version">&SHADOW_UTILS_VERSION;</refmiscinfo>
2de3ab
+  </refmeta>
2de3ab
+  <refnamediv id='name'>
2de3ab
+    <refname>getsubids</refname>
2de3ab
+    <refpurpose>get the subordinate id ranges for a user</refpurpose>
2de3ab
+  </refnamediv>
2de3ab
+
2de3ab
+  <refsynopsisdiv id='synopsis'>
2de3ab
+    <cmdsynopsis>
2de3ab
+      <command>getsubids</command>
2de3ab
+      <arg choice='opt'>
2de3ab
+        <replaceable>options</replaceable>
2de3ab
+      </arg>
2de3ab
+      <arg choice='plain'>
2de3ab
+        <replaceable>USER</replaceable>
2de3ab
+      </arg>
2de3ab
+    </cmdsynopsis>
2de3ab
+  </refsynopsisdiv>
2de3ab
+
2de3ab
+  <refsect1 id='description'>
2de3ab
+    <title>DESCRIPTION</title>
2de3ab
+    <para>
2de3ab
+      The <command>getsubids</command> command lists the subordinate user ID
2de3ab
+      ranges for a given user. The subordinate group IDs can be listed using
2de3ab
+      the <option>-g</option> option.
2de3ab
+    </para>
2de3ab
+  </refsect1>
2de3ab
+
2de3ab
+  <refsect1 id='options'>
2de3ab
+    <title>OPTIONS</title>
2de3ab
+    <para>
2de3ab
+      The options which apply to the <command>getsubids</command> command are:
2de3ab
+    </para>
2de3ab
+    <variablelist remap='IP'>
2de3ab
+      <varlistentry>
2de3ab
+        <term>
2de3ab
+          <option>-g</option>
2de3ab
+        </term>
2de3ab
+        <listitem>
2de3ab
+          <para>
2de3ab
+            List the subordinate group ID ranges.
2de3ab
+          </para>
2de3ab
+        </listitem>
2de3ab
+      </varlistentry>
2de3ab
+    </variablelist>
2de3ab
+  </refsect1>
2de3ab
+
2de3ab
+  <refsect1 id='example'>
2de3ab
+    <title>EXAMPLE</title>
2de3ab
+    <para>
2de3ab
+      For example, to obtain the subordinate UIDs of the testuser:
2de3ab
+    </para>
2de3ab
+    <para>
2de3ab
+<programlisting>
2de3ab
+$ getsubids testuser
2de3ab
+0: testuser 100000 65536
2de3ab
+</programlisting>
2de3ab
+    </para>
2de3ab
+    <para>
2de3ab
+      This command output provides (in order from left to right) the list
2de3ab
+      index, username, UID range start, and number of UIDs in range.
2de3ab
+    </para>
2de3ab
+  </refsect1>
2de3ab
+
2de3ab
+  <refsect1 id='see_also'>
2de3ab
+    <title>SEE ALSO</title>
2de3ab
+    <para>
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>login.defs</refentrytitle><manvolnum>5</manvolnum>
2de3ab
+      </citerefentry>,
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>newgidmap</refentrytitle><manvolnum>1</manvolnum>
2de3ab
+      </citerefentry>,
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>newuidmap</refentrytitle><manvolnum>1</manvolnum>
2de3ab
+      </citerefentry>,
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>subgid</refentrytitle><manvolnum>5</manvolnum>
2de3ab
+      </citerefentry>,
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>subuid</refentrytitle><manvolnum>5</manvolnum>
2de3ab
+      </citerefentry>,
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>useradd</refentrytitle><manvolnum>8</manvolnum>
2de3ab
+      </citerefentry>,
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>userdel</refentrytitle><manvolnum>8</manvolnum>
2de3ab
+      </citerefentry>.
2de3ab
+      <citerefentry>
2de3ab
+        <refentrytitle>usermod</refentrytitle><manvolnum>8</manvolnum>
2de3ab
+      </citerefentry>,
2de3ab
+    </para>
2de3ab
+  </refsect1>
2de3ab
+</refentry>
2de3ab
diff -up shadow-4.9/man/Makefile.am.getsubids shadow-4.9/man/Makefile.am
2de3ab
--- shadow-4.9/man/Makefile.am.getsubids	2021-07-22 23:55:35.000000000 +0200
2de3ab
+++ shadow-4.9/man/Makefile.am	2021-11-18 16:27:33.951053120 +0100
2de3ab
@@ -62,6 +62,7 @@ man_MANS += $(man_nopam)
2de3ab
 endif
2de3ab
 
2de3ab
 man_subids = \
2de3ab
+	man1/getsubids.1 \
2de3ab
 	man1/newgidmap.1 \
2de3ab
 	man1/newuidmap.1 \
2de3ab
 	man5/subgid.5 \
2de3ab
@@ -80,6 +81,7 @@ man_XMANS = \
2de3ab
 	expiry.1.xml \
2de3ab
 	faillog.5.xml \
2de3ab
 	faillog.8.xml \
2de3ab
+	getsubids.1.xml \
2de3ab
 	gpasswd.1.xml \
2de3ab
 	groupadd.8.xml \
2de3ab
 	groupdel.8.xml \
2de3ab
diff -up shadow-4.9/src/getsubids.c.getsubids shadow-4.9/src/getsubids.c
2de3ab
--- shadow-4.9/src/getsubids.c.getsubids	2021-11-18 16:27:33.951053120 +0100
2de3ab
+++ shadow-4.9/src/getsubids.c	2021-11-18 16:27:33.951053120 +0100
2de3ab
@@ -0,0 +1,46 @@
2de3ab
+#include <stdio.h>
2de3ab
+#include <string.h>
2de3ab
+#include <stdlib.h>
2de3ab
+#include "subid.h"
2de3ab
+#include "prototypes.h"
2de3ab
+
2de3ab
+const char *Prog;
2de3ab
+FILE *shadow_logfd = NULL;
2de3ab
+
2de3ab
+void usage(void)
2de3ab
+{
2de3ab
+	fprintf(stderr, "Usage: %s [-g] user\n", Prog);
2de3ab
+	fprintf(stderr, "    list subuid ranges for user\n");
2de3ab
+	fprintf(stderr, "    pass -g to list subgid ranges\n");
2de3ab
+	exit(EXIT_FAILURE);
2de3ab
+}
2de3ab
+
2de3ab
+int main(int argc, char *argv[])
2de3ab
+{
2de3ab
+	int i, count=0;
2de3ab
+	struct subid_range *ranges;
2de3ab
+	const char *owner;
2de3ab
+
2de3ab
+	Prog = Basename (argv[0]);
2de3ab
+	shadow_logfd = stderr;
2de3ab
+	if (argc < 2)
2de3ab
+		usage();
2de3ab
+	owner = argv[1];
2de3ab
+	if (argc == 3 && strcmp(argv[1], "-g") == 0) {
2de3ab
+		owner = argv[2];
2de3ab
+		count = get_subgid_ranges(owner, &ranges;;
2de3ab
+	} else if (argc == 2 && strcmp(argv[1], "-h") == 0) {
2de3ab
+		usage();
2de3ab
+	} else {
2de3ab
+		count = get_subuid_ranges(owner, &ranges;;
2de3ab
+	}
2de3ab
+	if (!ranges) {
2de3ab
+		fprintf(stderr, "Error fetching ranges\n");
2de3ab
+		exit(1);
2de3ab
+	}
2de3ab
+	for (i = 0; i < count; i++) {
2de3ab
+		printf("%d: %s %lu %lu\n", i, owner,
2de3ab
+			ranges[i].start, ranges[i].count);
2de3ab
+	}
2de3ab
+	return 0;
2de3ab
+}
2de3ab
diff -up shadow-4.9/src/list_subid_ranges.c.getsubids shadow-4.9/src/list_subid_ranges.c
2de3ab
diff -up shadow-4.9/src/Makefile.am.getsubids shadow-4.9/src/Makefile.am
2de3ab
--- shadow-4.9/src/Makefile.am.getsubids	2021-11-18 16:27:33.943053061 +0100
2de3ab
+++ shadow-4.9/src/Makefile.am	2021-11-18 16:28:03.647272392 +0100
2de3ab
@@ -157,8 +157,8 @@ if FCAPS
2de3ab
 	setcap cap_setgid+ep $(DESTDIR)$(ubindir)/newgidmap
2de3ab
 endif
2de3ab
 
2de3ab
-noinst_PROGRAMS += list_subid_ranges  \
2de3ab
-					get_subid_owners \
2de3ab
+bin_PROGRAMS    +=  getsubids
2de3ab
+noinst_PROGRAMS +=  get_subid_owners \
2de3ab
 					new_subid_range \
2de3ab
 					free_subid_range \
2de3ab
 					check_subid_range
2de3ab
@@ -174,13 +174,13 @@ MISCLIBS = \
2de3ab
 	$(LIBCRYPT) \
2de3ab
 	$(LIBTCB)
2de3ab
 
2de3ab
-list_subid_ranges_LDADD = \
2de3ab
+getsubids_LDADD = \
2de3ab
 	$(top_builddir)/lib/libshadow.la \
2de3ab
 	$(top_builddir)/libmisc/libmisc.la \
2de3ab
 	$(top_builddir)/libsubid/libsubid.la \
2de3ab
 	$(MISCLIBS) -ldl
2de3ab
 
2de3ab
-list_subid_ranges_CPPFLAGS = \
2de3ab
+getsubids_CPPFLAGS = \
2de3ab
 	-I$(top_srcdir)/lib \
2de3ab
 	-I$(top_srcdir)/libmisc \
2de3ab
 	-I$(top_srcdir)/libsubid