]> git.ipfire.org Git - thirdparty/shadow.git/log
thirdparty/shadow.git
21 months agoRelease 4.14.2 824/head 4.14.2
Alejandro Colomar [Sun, 29 Oct 2023 23:14:15 +0000 (00:14 +0100)] 
Release 4.14.2

Link: <https://github.com/shadow-maint/shadow/pull/824>
Reviewed-by: Michael Vetter <jubalh@iodoru.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
21 months agoman: document --prefix option in chage, chpasswd and passwd
Michael Vetter [Fri, 20 Oct 2023 13:22:35 +0000 (15:22 +0200)] 
man: document --prefix option in chage, chpasswd and passwd

Support for `--prefix` was added in
https://github.com/shadow-maint/shadow/pull/714 and is available since
shadow 4.14.0.

Close https://github.com/shadow-maint/shadow/issues/822

Cherry-picked-from: 01f6258df744 ("man: document --prefix option in chage, chpasswd and passwd")
Link: <https://github.com/shadow-maint/shadow/pull/823>
Suggested-by: Michael Vetter <jubalh@iodoru.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
21 months agouseradd: Set proper SELinux labels for def_usrtemplate
Johannes Segitz [Tue, 26 Sep 2023 13:14:14 +0000 (15:14 +0200)] 
useradd: Set proper SELinux labels for def_usrtemplate

Fixes: 74c17c716 ("Add support for skeleton files from /usr/etc/skel")
Signed-off-by: Johannes Segitz <jsegitz@suse.com>
Cherry-picked-from: 48aa12af31c0b72872b411857d03a518a4200a3d
Link: <https://github.com/shadow-maint/shadow/pull/812>
Reviewed-by: Michael Vetter <jubalh@iodoru.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
21 months agoutmp: call prepare_utmp() even if utent is NULL
Iker Pedrosa [Fri, 15 Sep 2023 07:55:02 +0000 (09:55 +0200)] 
utmp: call prepare_utmp() even if utent is NULL

update_utmp() should also return 0 when success.

Fixes: 1f368e1c1838de9d476a36897d7c53394569de08 ("utmp: update
`update_utmp()")
Resolves: https://github.com/shadow-maint/shadow/issues/805

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
Cherry-picked-from: 5178f8c5afb612f6ddf5363823547e080e7f546b
Link: <https://github.com/shadow-maint/shadow/issues/805>
Link: <https://github.com/shadow-maint/shadow/pull/808>
Reviewed-by: Michael Vetter <jubalh@iodoru.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
21 months agolib/btrfs: avoid NULL-dereference
Christian Göttsche [Thu, 26 Jan 2023 20:03:56 +0000 (21:03 +0100)] 
lib/btrfs: avoid NULL-dereference

    btrfs.c:42:13: warning: use of NULL 'cmd' where non-null expected [CWE-476] [-Wanalyzer-null-argument]

Reviewed-by: Alejandro Colomar <alx@kernel.org>
Cherry-picked-from: 54ab542887994f8b6e5411469d6867e3a2e58800
Link: <https://github.com/shadow-maint/shadow/pull/770>
Reviewed-by: Michael Vetter <jubalh@iodoru.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
21 months agoReplace __{BEGIN,END}_DECLS with #ifdef __cplusplus
Heiko Becker [Fri, 18 Aug 2023 16:23:56 +0000 (18:23 +0200)] 
Replace __{BEGIN,END}_DECLS with #ifdef __cplusplus

Fixes the build with musl libc.

Cherry-picked-from: 890f911e17169e44b43fe98742540267093559ea
Link: <https://github.com/shadow-maint/shadow/pull/789>
Reviewed-by: Michael Vetter <jubalh@iodoru.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
22 months agoRelease 4.14.1 4.14.1
Alejandro Colomar [Mon, 25 Sep 2023 15:55:02 +0000 (17:55 +0200)] 
Release 4.14.1

The same thing, but this time, it's official.  :)

Link: <https://lists.sr.ht/~hallyn/shadow/%3Cphikwsgcwerp4anb4qpfkruwqqy4rqsmowv6pi23m5rqvhxw4i%40yuexyhynkim3%3E>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
22 months agoRelease 4.14.1-alx
Alejandro Colomar [Mon, 18 Sep 2023 12:50:02 +0000 (14:50 +0200)] 
Release 4.14.1-alx

Signed-off-by: Alejandro Colomar <alx@kernel.org>
22 months agolib: Merge libmisc into libshadow
Alejandro Colomar [Mon, 28 Aug 2023 10:54:22 +0000 (12:54 +0200)] 
lib: Merge libmisc into libshadow

The separation was unnecessary, and caused build problems.  Let's go
wild and obliterate the library.  The files are moved to libshadow.

Scripted change:

$ find libmisc/ -type f \
| grep '\.[chy]$' \
| xargs mv -t lib;

Plus updating the Makefile and other references.  While at it, I've
sorted the sources lists.

Link: <https://github.com/shadow-maint/shadow/pull/792>
Reported-by: David Seifert <soap@gentoo.org>
Cc: Sam James <sam@gentoo.org>
Cc: Christian Bricart <christian@bricart.de>
Cc: Michael Vetter <jubalh@iodoru.org>
Cc: Robert Förster <Dessa@gmake.de>
[ soap tested the Gentoo package ]
Tested-by: David Seifert <soap@gentoo.org>
Acked-by: David Seifert <soap@gentoo.org>
Acked-by: Serge Hallyn <serge@hallyn.com>
Acked-by: Iker Pedrosa <ipedrosa@redhat.com>
Acked-by: <lslebodn@fedoraproject.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
22 months agolib, libmisc: Move source files to lib (where their headers were)
Alejandro Colomar [Fri, 25 Aug 2023 09:29:00 +0000 (11:29 +0200)] 
lib, libmisc: Move source files to lib (where their headers were)

Scripted change:

$ find lib/ -type f \
| grep '\.h$' \
| sed 's,lib/,libmisc/,' \
| sed 's,\.h$,.c,' \
| xargs find 2>/dev/null \
| xargs mv -t lib/;

Plus updating the Makefiles.

Closes: <https://github.com/shadow-maint/shadow/issues/791>
Closes: <https://bugs.gentoo.org/912446>
Link: <https://github.com/shadow-maint/shadow/issues/763#issuecomment-1664383425>
Link: <https://github.com/shadow-maint/shadow/pull/776>
Link: <https://github.com/shadow-maint/shadow/commit/d0518cc250afeaceb772a7f50a900cfc9b3ab937>
Reported-by: Christian Bricart <christian@bricart.de>
Reported-by: Robert Marmorstein <robert@marmorstein.org>
Cc: Sam James <sam@gentoo.org>
[ jubalh tested the openSUSE package ]
Tested-by: Michael Vetter <jubalh@iodoru.org>
Acked-by: Michael Vetter <jubalh@iodoru.org>
[ Robert F. tested the Gentoo package ]
Tested-by: Robert Förster <Dessa@gmake.de>
Cc: David Seifert <soap@gentoo.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
23 months agorelease 4.14.0 4.14.0
Serge Hallyn [Wed, 16 Aug 2023 02:38:30 +0000 (21:38 -0500)] 
release 4.14.0

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months agopre-release 4.14.0-rc5 4.14.0-rc5
Serge Hallyn [Mon, 14 Aug 2023 16:51:36 +0000 (11:51 -0500)] 
pre-release 4.14.0-rc5

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months agoconfigure.ac: check for strlcpy
Serge Hallyn [Mon, 14 Aug 2023 13:27:30 +0000 (08:27 -0500)] 
configure.ac: check for strlcpy

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months agoRemove intree website
Michael Vetter [Mon, 14 Aug 2023 06:57:40 +0000 (08:57 +0200)] 
Remove intree website

AFAIK these files were not used in a while.
On 2023-04-27 we also archived the GitHub pages based repo:
https://github.com/shadow-maint/shadow-www

In https://github.com/shadow-maint/shadow/commit/1654f42194ba7804c99d5ac96346a1a19fb793d7 we mention the regular repo URL as our home page.

Also see:
https://github.com/shadow-maint/shadow/issues/114

23 months ago4.14.0-rc4 pre-release 4.14.0-rc4
Serge Hallyn [Sun, 13 Aug 2023 04:17:52 +0000 (23:17 -0500)] 
4.14.0-rc4 pre-release

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months agoReleases: add etc/shadow-maint to distfiles
Serge Hallyn [Fri, 11 Aug 2023 17:47:41 +0000 (12:47 -0500)] 
Releases: add etc/shadow-maint to distfiles

Closes #784

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months ago4.14.0-rc3 4.14.0-rc3
Serge Hallyn [Thu, 10 Aug 2023 14:33:07 +0000 (09:33 -0500)] 
4.14.0-rc3

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months agolibmisc: include freezero
Iker Pedrosa [Thu, 10 Aug 2023 07:46:38 +0000 (09:46 +0200)] 
libmisc: include freezero

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
23 months agolibmisc: add freezero source code
Iker Pedrosa [Thu, 10 Aug 2023 07:45:32 +0000 (09:45 +0200)] 
libmisc: add freezero source code

If shadow is built without libbsd support, then freezero() needs to be
provided from the project.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
23 months agolibmisc: add readpassphrase source code
Iker Pedrosa [Tue, 8 Aug 2023 14:01:41 +0000 (16:01 +0200)] 
libmisc: add readpassphrase source code

If shadow is built without libbsd support, then readpassphrase() needs
to be provided from the project.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
23 months agoconfigure: add `with-libbsd` option
Iker Pedrosa [Thu, 10 Aug 2023 07:15:04 +0000 (09:15 +0200)] 
configure: add `with-libbsd` option

It enables the build with libbsd support. By default it is enabled.

Resolves: https://github.com/shadow-maint/shadow/issues/779

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
23 months agoman: include `shadow-man.xsl` in tarball
Iker Pedrosa [Tue, 8 Aug 2023 10:52:21 +0000 (12:52 +0200)] 
man: include `shadow-man.xsl` in tarball

This will help generate man pages from tarball.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
23 months agoman: include `its.rules` in tarball
Iker Pedrosa [Tue, 8 Aug 2023 10:50:27 +0000 (12:50 +0200)] 
man: include `its.rules` in tarball

This will help generate the man pages from tarball.

Resolves: https://github.com/shadow-maint/shadow/issues/781

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
23 months agoautogen: enable lastlog build
Iker Pedrosa [Mon, 7 Aug 2023 08:12:04 +0000 (10:12 +0200)] 
autogen: enable lastlog build

Add "--enable-lastlog" to include lastlog man pages in tarball.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
23 months agoAdd wrapper for write(2)
Christian Göttsche [Tue, 28 Feb 2023 15:35:05 +0000 (16:35 +0100)] 
Add wrapper for write(2)

write(2) may not write the complete given buffer.  Add a wrapper to
avoid short writes.

23 months agotag 4.14.0-rc2 4.14.0-rc2
Serge Hallyn [Fri, 4 Aug 2023 21:24:54 +0000 (16:24 -0500)] 
tag 4.14.0-rc2

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months agoAdd new files to libmisc_la_SOURCES
Michael Vetter [Fri, 4 Aug 2023 12:26:50 +0000 (14:26 +0200)] 
Add new files to libmisc_la_SOURCES

Resolves https://github.com/shadow-maint/shadow/issues/763

23 months agoAdd a make dist CI test
Serge Hallyn [Fri, 4 Aug 2023 14:59:56 +0000 (09:59 -0500)] 
Add a make dist CI test

Add a CI test to check that make dist builds a usable tarball.

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months ago4.14.0-rc1 4.14.0-rc1
Serge Hallyn [Mon, 31 Jul 2023 14:39:12 +0000 (09:39 -0500)] 
4.14.0-rc1

Signed-off-by: Serge Hallyn <serge@hallyn.com>
23 months agoremove xmalloc.c from POTFILES.in
Serge Hallyn [Thu, 3 Aug 2023 13:24:44 +0000 (08:24 -0500)] 
remove xmalloc.c from POTFILES.in

Signed-off-by: Serge Hallyn <serge@hallyn.com>
2 years agologoutd: add missing <utmp.h> include
Iker Pedrosa [Fri, 21 Jul 2023 06:35:17 +0000 (08:35 +0200)] 
logoutd: add missing <utmp.h> include

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoCI: compile old utmp interface in Fedora
Iker Pedrosa [Fri, 21 Jul 2023 06:26:51 +0000 (08:26 +0200)] 
CI: compile old utmp interface in Fedora

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agosrc: add SELINUX library
Iker Pedrosa [Wed, 19 Jul 2023 11:00:17 +0000 (13:00 +0200)] 
src: add SELINUX library

With the recent changes both login and su compilation fail because there
are some missing dependencies from SELINUX library. Thus, add LIBSELINUX
to su and login for those cases where the library is used.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agolibmisc: conditionally compile `utmp.c` and `logind.c`
Iker Pedrosa [Wed, 19 Jul 2023 10:41:06 +0000 (12:41 +0200)] 
libmisc: conditionally compile `utmp.c` and `logind.c`

Depending on the configuration option selected.

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agolib: replace `USER_NAME_MAX_LENGTH` macro
Iker Pedrosa [Wed, 19 Jul 2023 10:05:09 +0000 (12:05 +0200)] 
lib: replace `USER_NAME_MAX_LENGTH` macro

Replace it by `sysconf(_SC_LOGIN_NAME_MAX)`, which is the maximum
username length supported by the kernel.

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agolibmisc: call `active_sessions_count()`
Iker Pedrosa [Wed, 19 Jul 2023 10:02:31 +0000 (12:02 +0200)] 
libmisc: call `active_sessions_count()`

Replace the utmp dependent code with the call to
`active_sessions_count()`.

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agolibmisc: implement `active_sessions_count()`
Iker Pedrosa [Wed, 19 Jul 2023 09:02:55 +0000 (11:02 +0200)] 
libmisc: implement `active_sessions_count()`

Implement `active_sessions_count()` in `utmp.c` and `logind.c`.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoutmp: update `update_utmp()`
Iker Pedrosa [Wed, 19 Jul 2023 07:42:35 +0000 (09:42 +0200)] 
utmp: update `update_utmp()`

Remove `utmp` structure as an argument and include its logic inside the
function. This will help remove any reference to utmp from login.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoutmp: move `update_utmp`
Iker Pedrosa [Tue, 18 Jul 2023 14:48:02 +0000 (16:48 +0200)] 
utmp: move `update_utmp`

The functionality from this function is related to utmp. Restrict access
to `setutmp()` to the same file.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoutmp: move `failtmp()`
Iker Pedrosa [Tue, 18 Jul 2023 14:36:35 +0000 (16:36 +0200)] 
utmp: move `failtmp()`

The functionality from this function is related to btmp.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agolibmisc: implement `get_session_host()`
Iker Pedrosa [Tue, 18 Jul 2023 13:56:46 +0000 (15:56 +0200)] 
libmisc: implement `get_session_host()`

Implement `get_session_host()` in `utmp.c` and `logind.c`.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoconfigure: new option `enable-logind`
Iker Pedrosa [Tue, 18 Jul 2023 09:33:02 +0000 (11:33 +0200)] 
configure: new option `enable-logind`

Create new configuration option `enable-logind` to select which session
support functionality to build, logind or utmp. By default the option is
logind.

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoshadow userdel: add the adaptation to the busybox ps in 01-kill_user_procs.sh
xiongshenglan [Wed, 19 Jul 2023 07:13:06 +0000 (15:13 +0800)] 
shadow userdel: add the adaptation to the busybox ps in 01-kill_user_procs.sh

In some embedded systems, users only use the ps
provided by the busybox. But the ps provided by
the busybox does not support the -eo option by
default. As a result, an error is reported when
the userdel is used. So add a judgment on ps.
If there is no ps -eo, traverse the process directly.

The error information is as follows:
 # userdel xsl
ps: invalid option -- 'e'

Signed-off-by: xiongshenglan <xiongshenglan@huawei.com>
2 years agochsh: warn if root sets a shell not listed in /etc/shells
Michael Vetter [Wed, 26 Jul 2023 08:13:53 +0000 (10:13 +0200)] 
chsh: warn if root sets a shell not listed in /etc/shells

Print a warning even for the root user if the provided shell isn't
listed in /etc/shells, but continue to execute the action.
In case of non root user exit.

See https://github.com/shadow-maint/shadow/issues/535

2 years agodoc: mention ci workflow file to learn about deps
Michael Vetter [Wed, 26 Jul 2023 09:24:29 +0000 (11:24 +0200)] 
doc: mention ci workflow file to learn about deps

Fix https://github.com/shadow-maint/shadow/issues/38

2 years agoman/po/Makefile: add a comment to shadow-man-pages.pot
Serge Hallyn [Sat, 15 Jul 2023 12:50:34 +0000 (07:50 -0500)] 
man/po/Makefile: add a comment to shadow-man-pages.pot

Add a comment at the top of that file explaining how to
regenerate it.

We should add a README, but I don't have time to draft one
right now.

Signed-off-by: Serge Hallyn <serge@hallyn.com>
2 years agonewgrp: fix potential string injection
Vegard Nossum [Fri, 21 Jul 2023 12:55:19 +0000 (14:55 +0200)] 
newgrp: fix potential string injection

Since newgrp is setuid-root, any write() system calls it does in order
to print error messages will be done as the root user.

Unprivileged users can get newgrp to print essentially arbitrary strings
to any open file in this way by passing those strings as argv[0] when
calling execve(). For example:

    $ setpid() { (exec -a $1$'\n:' newgrp '' 2>/proc/sys/kernel/ns_last_pid & wait) >/dev/null; }
    $ setpid 31000
    $ readlink /proc/self
    31001

This is not a vulnerability in newgrp; it is a bug in the Linux kernel.

However, this type of bug is not new [1] and it makes sense to try to
mitigate these types of bugs in userspace where possible.

[1]: https://lwn.net/Articles/476947/

Signed-off-by: Vegard Nossum <vegard.nossum@oracle.com>
2 years agolastlog: fix alignment of Latest header
Todd Zullinger [Tue, 18 Jul 2023 03:16:00 +0000 (23:16 -0400)] 
lastlog: fix alignment of Latest header

b1282224 (Add maximum padding to fit IPv6-Addresses, 2020-05-24) pads
the From field header using `maxIPv6Addrlen - 3`.  This leaves the
Latest field header misaligned.  Subtract 4 (the length of "From").

2 years agoconfigure: fix lastlog check
Iker Pedrosa [Mon, 17 Jul 2023 13:04:19 +0000 (15:04 +0200)] 
configure: fix lastlog check

Fixes: 1bdcfa8d3710bf0a3f180b590017df096d346ade ("lastlog: stop building by
default")

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agosubuid.5: reference newusers(8) rather than newusers(1)
Alan D. Salewski [Sat, 15 Jul 2023 20:36:06 +0000 (16:36 -0400)] 
subuid.5: reference newusers(8) rather than newusers(1)

Resolves: https://github.com/shadow-maint/shadow/issues/752

Signed-off-by: Alan D. Salewski <ads@salewski.email>
2 years agoCI: build lastlog in Fedora
Iker Pedrosa [Thu, 13 Jul 2023 13:33:07 +0000 (15:33 +0200)] 
CI: build lastlog in Fedora

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoman: conditionally build lastlog documentation
Iker Pedrosa [Thu, 13 Jul 2023 13:30:22 +0000 (15:30 +0200)] 
man: conditionally build lastlog documentation

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agousermod: conditionally build lastlog functionality
Iker Pedrosa [Thu, 13 Jul 2023 13:25:03 +0000 (15:25 +0200)] 
usermod: conditionally build lastlog functionality

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agouseradd: conditionally build lastlog functionality
Iker Pedrosa [Thu, 13 Jul 2023 13:24:37 +0000 (15:24 +0200)] 
useradd: conditionally build lastlog functionality

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agologin: conditionally build lastlog functionality
Iker Pedrosa [Thu, 13 Jul 2023 10:59:33 +0000 (12:59 +0200)] 
login: conditionally build lastlog functionality

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agolastlog: stop building by default
Iker Pedrosa [Thu, 13 Jul 2023 10:54:04 +0000 (12:54 +0200)] 
lastlog: stop building by default

Created a new configuration option `--enable-lastlog` to conditionally
build the lastlog binary. By default the option is disabled.

Resolves: https://github.com/shadow-maint/shadow/issues/674

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoCI: update debian repos
Iker Pedrosa [Fri, 14 Jul 2023 09:39:33 +0000 (11:39 +0200)] 
CI: update debian repos

Latest debian version changed the location and format for the repos
file.

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoFix yescrypt support
Bernd Kuhls [Sun, 9 Jul 2023 08:55:03 +0000 (10:55 +0200)] 
Fix yescrypt support

Fixes build error:
newusers.c: In function 'update_passwd':
newusers.c:433:21: error: 'sflg' undeclared (first use in this function); did you mean 'rflg'?

introduced by
https://github.com/shadow-maint/shadow/commit/5cd04d03f94622c12220d4a6352824af081b8531
which forgot to define sflg for these configure options:

--without-sha-crypt --without-bcrypt --with-yescrypt

2 years agochgpasswd: fix segfault in command-line options
Jeffrey Bencteux [Wed, 21 Jun 2023 13:12:43 +0000 (15:12 +0200)] 
chgpasswd: fix segfault in command-line options

Using the --sha-rounds option without first giving a crypt method via the --crypt-method option results in comparisons with a NULL pointer and thus make chgpasswd segfault:

$ chgpasswd -s 1
zsh: segmentation fault  chgpasswd -s 1

Current patch add a sanity check before these comparisons to ensure there is a defined encryption method.

2 years agogpasswd(1): Fix password leak
Alejandro Colomar [Sat, 10 Jun 2023 14:20:05 +0000 (16:20 +0200)] 
gpasswd(1): Fix password leak

How to trigger this password leak?
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

When gpasswd(1) asks for the new password, it asks twice (as is usual
for confirming the new password).  Each of those 2 password prompts
uses agetpass() to get the password.  If the second agetpass() fails,
the first password, which has been copied into the 'static' buffer
'pass' via STRFCPY(), wasn't being zeroed.

agetpass() is defined in <./libmisc/agetpass.c> (around line 91), and
can fail for any of the following reasons:

-  malloc(3) or readpassphrase(3) failure.

   These are going to be difficult to trigger.  Maybe getting the system
   to the limits of memory utilization at that exact point, so that the
   next malloc(3) gets ENOMEM, and possibly even the OOM is triggered.
   About readpassphrase(3), ENFILE and EINTR seem the only plausible
   ones, and EINTR probably requires privilege or being the same user;
   but I wouldn't discard ENFILE so easily, if a process starts opening
   files.

-  The password is longer than PASS_MAX.

   The is plausible with physical access.  However, at that point, a
   keylogger will be a much simpler attack.

And, the attacker must be able to know when the second password is being
introduced, which is not going to be easy.

How to read the password after the leak?
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Provoking the leak yourself at the right point by entering a very long
password is easy, and inspecting the process stack at that point should
be doable.  Try to find some consistent patterns.

Then, search for those patterns in free memory, right after the victim
leaks their password.

Once you get the leak, a program should read all the free memory
searching for patterns that gpasswd(1) leaves nearby the leaked
password.

On 6/10/23 03:14, Seth Arnold wrote:
> An attacker process wouldn't be able to use malloc(3) for this task.
> There's a handful of tools available for userspace to allocate memory:
>
> -  brk / sbrk
> -  mmap MAP_ANONYMOUS
> -  mmap /dev/zero
> -  mmap some other file
> -  shm_open
> -  shmget
>
> Most of these return only pages of zeros to a process.  Using mmap of an
> existing file, you can get some of the contents of the file demand-loaded
> into the memory space on the first use.
>
> The MAP_UNINITIALIZED flag only works if the kernel was compiled with
> CONFIG_MMAP_ALLOW_UNINITIALIZED.  This is rare.
>
> malloc(3) doesn't zero memory, to our collective frustration, but all the
> garbage in the allocations is from previous allocations in the current
> process.  It isn't leftover from other processes.
>
> The avenues available for reading the memory:
> -  /dev/mem and /dev/kmem (requires root, not available with Secure Boot)
> -  /proc/pid/mem (requires ptrace privileges, mediated by YAMA)
> -  ptrace (requires ptrace privileges, mediated by YAMA)
> -  causing memory to be swapped to disk, and then inspecting the swap
>
> These all require a certain amount of privileges.

How to fix it?
~~~~~~~~~~~~~~

memzero(), which internally calls explicit_bzero(3), or whatever
alternative the system provides with a slightly different name, will
make sure that the buffer is zeroed in memory, and optimizations are not
allowed to impede this zeroing.

This is not really 100% effective, since compilers may place copies of
the string somewhere hidden in the stack.  Those copies won't get zeroed
by explicit_bzero(3).  However, that's arguably a compiler bug, since
compilers should make everything possible to avoid optimizing strings
that are later passed to explicit_bzero(3).  But we all know that
sometimes it's impossible to have perfect knowledge in the compiler, so
this is plausible.  Nevertheless, there's nothing we can do against such
issues, except minimizing the time such passwords are stored in plain
text.

Security concerns
~~~~~~~~~~~~~~~~~

We believe this isn't easy to exploit.  Nevertheless, and since the fix
is trivial, this fix should probably be applied soon, and backported to
all supported distributions, to prevent someone else having more
imagination than us to find a way.

Affected versions
~~~~~~~~~~~~~~~~~

All.  Bug introduced in shadow 19990709.  That's the second commit in
the git history.

Fixes: 45c6603cc86c ("[svn-upgrade] Integrating new upstream version, shadow (19990709)")
Reported-by: Alejandro Colomar <alx@kernel.org>
Cc: Serge Hallyn <serge@hallyn.com>
Cc: Iker Pedrosa <ipedrosa@redhat.com>
Cc: Seth Arnold <seth.arnold@canonical.com>
Cc: Christian Brauner <christian@brauner.io>
Cc: Balint Reczey <rbalint@debian.org>
Cc: Sam James <sam@gentoo.org>
Cc: David Runge <dvzrv@archlinux.org>
Cc: Andreas Jaeger <aj@suse.de>
Cc: <~hallyn/shadow@lists.sr.ht>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agosrc/useradd.c: create_mail(): Cosmetic
Alejandro Colomar [Wed, 7 Jun 2023 21:56:30 +0000 (23:56 +0200)] 
src/useradd.c: create_mail(): Cosmetic

-  Invert conditional to reduce indentation.
-  Reduce use of whitespace and newlines while unindenting.
-  Reorder variable declarations.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agosrc/useradd.c: create_home(): Cosmetic
Alejandro Colomar [Wed, 7 Jun 2023 21:56:29 +0000 (23:56 +0200)] 
src/useradd.c: create_home(): Cosmetic

-  Invert conditional to reduce indentation.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agosrc/useradd.c: create_home(): Cosmetic
Alejandro Colomar [Wed, 7 Jun 2023 21:56:28 +0000 (23:56 +0200)] 
src/useradd.c: create_home(): Cosmetic

-  Invert conditional to reduce indentation.
-  Rewrite while loop calling strtok(3) as a for loop.  This allows
   doing more simplification inside the loop (see next commit).

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agosrc/useradd.c: create_home(): Cosmetic
Alejandro Colomar [Wed, 7 Jun 2023 21:56:27 +0000 (23:56 +0200)] 
src/useradd.c: create_home(): Cosmetic

-  Fix indentation.  It was very broken.
-  Move variable declaration to the top of the block in which it's used.
-  Reduce use of whitespace and newlines.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agosrc/useradd.c: close_group_files(): Cosmetic
Alejandro Colomar [Wed, 7 Jun 2023 21:56:26 +0000 (23:56 +0200)] 
src/useradd.c: close_group_files(): Cosmetic

-  Invert conditional, to reduce indentation.
-  Reduce use of whitespace and newlines while unindenting.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agosrc/useradd.c: check_uid_range(): Cosmetic
Alejandro Colomar [Wed, 7 Jun 2023 21:56:25 +0000 (23:56 +0200)] 
src/useradd.c: check_uid_range(): Cosmetic

-  Merge nested conditionals into a single if, to reduce indentation.
-  Indent (1 SP) nested preprocessor conditionals.
-  Reduce use of whitespace and newlines while unindenting.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agobuild: link passwd, chpasswd and chage against libdl
Jaroslav Jindrak [Fri, 5 May 2023 18:29:58 +0000 (20:29 +0200)] 
build: link passwd, chpasswd and chage against libdl

2 years agoconfigure: check whether fgetpwent_r is available before marking xprefix_getpwnam_r...
Jaroslav Jindrak [Thu, 4 May 2023 20:41:02 +0000 (22:41 +0200)] 
configure: check whether fgetpwent_r is available before marking xprefix_getpwnam_r as reentrant

2 years agopasswd: fall back to non-PAM code when prefix is used
Jaroslav Jindrak [Wed, 3 May 2023 20:38:28 +0000 (22:38 +0200)] 
passwd: fall back to non-PAM code when prefix is used

Prefix does not make sense when we use PAM, so when the option
is used behave as if --with-libpam=no was used to configure the
project.

2 years agochpasswd: fall back to non-PAM code when prefix is used
Jaroslav Jindrak [Wed, 3 May 2023 16:59:50 +0000 (18:59 +0200)] 
chpasswd: fall back to non-PAM code when prefix is used

The prefix option does not make sense in that scenario and the
encryption options already do this.

2 years agochpasswd: add --prefix/-P options
Jaroslav Jindrak [Fri, 28 Apr 2023 18:30:18 +0000 (20:30 +0200)] 
chpasswd: add --prefix/-P options

2 years agochage: add --prefix/-P options
Jaroslav Jindrak [Fri, 21 Apr 2023 20:24:36 +0000 (22:24 +0200)] 
chage: add --prefix/-P options

2 years agopasswd: Respect --prefix/-P options
Jaroslav Jindrak [Fri, 21 Apr 2023 18:50:41 +0000 (20:50 +0200)] 
passwd: Respect --prefix/-P options

Add prefix_getpwnam_r() and xprefix_getpwnam() and make passwd
use prefix-aware functions when handling the database.

2 years agoprefix: add prefix support
Michael Vetter [Mon, 17 Apr 2023 13:39:47 +0000 (15:39 +0200)] 
prefix: add prefix support

2 years agostrtoday: remove unnecessary cast
Iker Pedrosa [Wed, 7 Jun 2023 12:58:34 +0000 (14:58 +0200)] 
strtoday: remove unnecessary cast

Resolves: https://github.com/shadow-maint/shadow/issues/704

Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoUse temporary variable
Alejandro Colomar [Sat, 27 May 2023 13:56:08 +0000 (15:56 +0200)] 
Use temporary variable

-  Use the temporary variable more, as it helps readability: it removes
   a derefecence, which itself allows removing some parentheses.

-  Use a shorter name, which is more common with temporaries, and so
   there's less to read.

-  Assign to *ranges at the end of the function.  It's the same, but
   with the other changes, I think this makes it slightly clearer.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agorealloc(NULL, ...) is equivalent to malloc(...)
Alejandro Colomar [Sat, 27 May 2023 13:35:13 +0000 (15:35 +0200)] 
realloc(NULL, ...) is equivalent to malloc(...)

Don't have a branch for when the old pointer is NULL.  realloc(3) can
handle that case just fine.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoSimplify allocation APIs
Alejandro Colomar [Wed, 5 Apr 2023 19:17:38 +0000 (21:17 +0200)] 
Simplify allocation APIs

If we consider simple objects as arrays of size 1, we can considerably
simplify these APIs, merging the *ARRAY and the non-array variants.

That will produce more readable code, since lines will be shorter (by
not having ARRAY in the macro names, as all macros will consistently
handle arrays), and the allocated size will be also more explicit.

The syntax will now be of the form:

    p = MALLOC(42, foo_t);  // allocate 42 elements of type foo_t.
    p = MALLOC(1, bar_t);   // allocate 1 element of type foo_t.

The _array() allocation functions should _never_ be called directly, and
instead these macros should be used.

The non-array functions (e.g., malloc(3)) still have their place, but
are limited to allocating structures with flexible array members.  For
any other uses, the macros should be used.

Thus, we don't use any array or ARRAY variants in any code any more, and
they are only used as implementation details of these macros.

Link: <https://software.codidact.com/posts/285898/288023#answer-288023>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoDrop alloca(3)
Christian Göttsche [Tue, 28 Feb 2023 14:50:20 +0000 (15:50 +0100)] 
Drop alloca(3)

alloca(3) fails silently if not enough memory can be allocated on the
stack.  Use checked dynamic allocation instead.

Also drop unnecessary manual NUL assignment, ensured by snprintf(3).

Co-developed-by: Alejandro Colomar <alx@kernel.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agousermod: fix off-by-one issues
Christian Göttsche [Thu, 2 Mar 2023 15:18:45 +0000 (16:18 +0100)] 
usermod: fix off-by-one issues

Allocate enough memory for the strings, two slashes and the NUL
terminator.

Reported-by: Alejandro Colomar <alx@kernel.org>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agolibmisc/csrand.c: Update comments
Alejandro Colomar [Sat, 3 Jun 2023 17:25:00 +0000 (19:25 +0200)] 
libmisc/csrand.c: Update comments

Those comments were written when this function used 64 bits (and
temporary variables of 128 bits).  Now it uses 32 bits, with temporaries
of 64 bits, so some values have changed.

Fixes: 2a61122b5e8f ("Unoptimize the higher part of the domain of csrand_uniform()")
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agolib/nss.c: Fix use of invalid p
Alejandro Colomar [Wed, 31 May 2023 10:24:14 +0000 (12:24 +0200)] 
lib/nss.c: Fix use of invalid p

getline(3) might have succeeded in a previous iteration, in which case
p points to an offset that is not valid.  Make p NULL at the end of the
loop, to make sure it doesn't hold old stuff.

Link: <https://github.com/shadow-maint/shadow/pull/737#issuecomment-1568948769>
Reported-by: Serge Hallyn <serge@hallyn.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agolib/nss.c: Fix use of uninitialized p
Alejandro Colomar [Wed, 31 May 2023 10:19:33 +0000 (12:19 +0200)] 
lib/nss.c: Fix use of uninitialized p

getline(3) might have never succeeded, in which case p is uninitialized
when used in strtok_r(3).

Link: <https://github.com/shadow-maint/shadow/pull/737#discussion_r1206007358>
Cc: Serge Hallyn <serge@hallyn.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoCentralize error handling
Alejandro Colomar [Fri, 26 May 2023 10:16:13 +0000 (12:16 +0200)] 
Centralize error handling

This makes the function fit in less screens.  This is to avoid consuming
more natural resources than we have available, and everyone knows the
supply of new-lines on a screen is not a renewable source[1].

Some transformations have been done thanks to free(NULL) being an alias
for loopity_loop(), as defined three comits ago.  The real definition of
free(3) that everyone has been hiding is this:

void
free(void *p)
{
if (p == NULL)
loopity_loop();
else
real_free(p);
}

Link: [1] <https://www.kernel.org/doc/html/v6.3/process/coding-style.html#placing-braces-and-spaces>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoSecond verse, it gets worse; it gets no better than this
Alejandro Colomar [Fri, 26 May 2023 09:34:10 +0000 (11:34 +0200)] 
Second verse, it gets worse; it gets no better than this

Just in case it's not obious:

strlen("") < 8
isalpha('\0') == false
isdigit('\0') == false
isspace('\0') == false

Link: <https://github.com/shadow-maint/shadow/pull/737>
Easter-egg: 8492dee6632e ("subids: support nsswitch")
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoROFL: Rolling on the floor looping
Alejandro Colomar [Thu, 25 May 2023 20:24:30 +0000 (22:24 +0200)] 
ROFL: Rolling on the floor looping

Please tell me this was an easter egg :P

 #define go_banana() ({ goto nowhere; nowhere: 0-0; })

Closes: <https://github.com/shadow-maint/shadow/issues/736>
Easter-egg: 8492dee6632e ("subids: support nsswitch")
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoThis ain't no loop
Alejandro Colomar [Thu, 25 May 2023 20:13:36 +0000 (22:13 +0200)] 
This ain't no loop

This was to a loop, as "1234" is to computer security.

No really; a loop that ends in a (forward) goto, and has no continue in it.

Still want a loop?  Take two:

 #define loopity_loop() do { for (;;) { break; } continue; } while (0-0)

Closes: <https://github.com/shadow-maint/shadow/issues/736>
Easter-egg: 8492dee6632e ("subids: support nsswitch")
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agonewusers: Improve error message
Iker Pedrosa [Wed, 31 May 2023 07:38:12 +0000 (09:38 +0200)] 
newusers: Improve error message

Fixes: b422e3c31691: Check if crypt_method null before dereferencing
Signed-off-by: Iker Pedrosa <ipedrosa@redhat.com>
2 years agoch(g)passwd: Check selinux permissions upon startup
Martin Kletzander [Fri, 3 Mar 2023 10:46:33 +0000 (11:46 +0100)] 
ch(g)passwd: Check selinux permissions upon startup

The permission also need to be checked before process_root_flag() since
that can chroot into non-selinux environment (unavailable selinux mount
point for example).

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
2 years agoCheck if crypt_method null before dereferencing
Skyler Ferrante [Tue, 30 May 2023 19:00:12 +0000 (15:00 -0400)] 
Check if crypt_method null before dereferencing

Make sure crypto_method set before sha-rounds. Only affects newusers.

2 years agoxgetXXbyYY: Simplify elifs
Alejandro Colomar [Sat, 27 May 2023 01:26:52 +0000 (03:26 +0200)] 
xgetXXbyYY: Simplify elifs

-  Use SIZE_MAX rather than (size_t)-1, to improve readability.

-  Move the only branch that breaks to the first place, so that we
   remove an else.  This reduces nesting while parsing the code.

-  Now that we only have a 2-branch conditional where both branches
   assign to the same variable, rewrite it as a ternary, to shorten.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoxgetXXbyYY: Centralize error handling
Alejandro Colomar [Sat, 27 May 2023 01:24:49 +0000 (03:24 +0200)] 
xgetXXbyYY: Centralize error handling

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoxgetXXbyYY: tfix
Alejandro Colomar [Sat, 27 May 2023 01:19:26 +0000 (03:19 +0200)] 
xgetXXbyYY: tfix

It seems obvious that it was a typo.

Link: <https://github.com/shadow-maint/shadow/pull/729#discussion_r1207551013>
Fixes: e73a2194b3d2 ("xgetXXbyYY: Handle DUP_FUNCTION failure")
Cc: Samanta Navarro <ferivoz@riseup.net>
Cc: Serge Hallyn <serge@hallyn.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agoxgetXXbyYY: Avoid duplicated error handling block
Samanta Navarro [Mon, 15 May 2023 11:59:23 +0000 (11:59 +0000)] 
xgetXXbyYY: Avoid duplicated error handling block

The error handling is performed after the loop. By just calling break it
is possible to reuse the error handling if status is not ERANGE.

Signed-off-by: Samanta Navarro <ferivoz@riseup.net>
2 years agoxgetXXbyYY: Handle DUP_FUNCTION failure
Samanta Navarro [Mon, 15 May 2023 11:58:04 +0000 (11:58 +0000)] 
xgetXXbyYY: Handle DUP_FUNCTION failure

A failure of DUP_FUNCTION is already handled for non-reentrant
function wrapper. Perform the check for reentrant version as well.

Signed-off-by: Samanta Navarro <ferivoz@riseup.net>
2 years agosub_[ug]id_{add,remove}: fix return values
Serge Hallyn [Fri, 26 May 2023 03:00:36 +0000 (22:00 -0500)] 
sub_[ug]id_{add,remove}: fix return values

On failure, these are meant to return 0 with errno set.  But if
an nss module is loaded, they were returning -ERRNO instead.

Signed-off-by: Serge Hallyn <serge@hallyn.com>
2 years agousermod: Small optimization using memmove for password unlock
Martin Kletzander [Fri, 3 Mar 2023 10:57:23 +0000 (11:57 +0100)] 
usermod: Small optimization using memmove for password unlock

Signed-off-by: Martin Kletzander <mkletzan@redhat.com>
2 years agoReorder logic to improve comprehensibility
Alejandro Colomar [Sun, 5 Feb 2023 00:29:06 +0000 (01:29 +0100)] 
Reorder logic to improve comprehensibility

-  Don't else after return or fail_exit().
-  Prefer == over != (negated logic is more complex to think about it).
-  Reduce nesting when reasonable.

Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agonewusers: Fail early
Alejandro Colomar [Sat, 4 Feb 2023 19:54:43 +0000 (20:54 +0100)] 
newusers: Fail early

There's no reason to report all errors.  Bail out at the first one,
which is simpler.

Suggested-by: Serge Hallyn <serge@hallyn.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>
2 years agonewusers: Add missing error handling
Alejandro Colomar [Sat, 4 Feb 2023 19:52:54 +0000 (20:52 +0100)] 
newusers: Add missing error handling

Some errors were being reported in stderr, but then they weren't really
being treated as errors.

If mkdir(2) for EEXIST, it's possible that the sysadmin pre-created the
user dir; don't fail.  However, let's keep a log line, for having some
notice that it happened.

Also, run chmod(2) if mkdir(2) failed for EEXIST (so transform the
'else if' into an 'if').

Cc: Serge Hallyn <serge@hallyn.com>
Signed-off-by: Alejandro Colomar <alx@kernel.org>