|
|
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
|