Bug 256728

Summary: rc.subr: ${name}_user uses "su -m" that invokes root shell instead of /bin/sh
Product: Base System Reporter: Eugene Grosbein <eugen>
Component: confAssignee: freebsd-rc (Nobody) <rc>
Status: Open ---    
Severity: Affects Some People CC: 0mp, ports-bugs
Priority: ---    
Version: Unspecified   
Hardware: Any   
OS: Any   

Description Eugene Grosbein freebsd_committer 2021-06-20 10:02:32 UTC
The port net/p2p/transmission-daemon is an example of service that utilizes <name>_user rc.conf setting. Also, it supports writing debugging logs to pre-opened (redirected to a file) STDERR by means of environment variable TR_DEBUG_FD=2 but our framework uses "su -m" for such services executing root shell that defaults to stock csh (contrib/tcsh) that closes its file descriptor 2 at start.

Note there is some kind of work-around if we do not use login classes and/or limits for the service, then add to /etc/rc.conf


So "chroot -u transmission /" is used to substitute user instead of "su -m" and chroot(8) is documented not to use root shell but SHELL=/bin/sh. And /bin/sh keeps redirected STDERR open in such case.