Page MenuHomeFreeBSD

Fix default login class for services started via command line; allow service class in /etc/login.conf to be overridden.
ClosedPublic

Authored by adrian on Sep 10 2015, 10:10 PM.
Tags
None
Referenced Files
F133228878: D3630.id8913.diff
Fri, Oct 24, 3:54 AM
Unknown Object (File)
Thu, Oct 23, 4:28 AM
Unknown Object (File)
Sat, Oct 18, 7:30 AM
Unknown Object (File)
Thu, Oct 16, 4:36 PM
Unknown Object (File)
Fri, Oct 3, 12:04 PM
Unknown Object (File)
Sep 19 2025, 7:47 AM
Unknown Object (File)
Sep 16 2025, 3:10 AM
Unknown Object (File)
Sep 3 2025, 6:26 PM
Subscribers

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

adrian retitled this revision from to Fix default login class for services started via command line; allow service class in /etc/login.conf to be overridden..
adrian updated this object.
adrian edited the test plan for this revision. (Show Details)
etc/rc.subr
771 ↗(On Diff #8659)

should we just call it ${name}_class instead of ${name}_login_class? it really doesn't have much to do with 'login'

Agreed that Hunk #1 (curfiles) is not subject to review.

Hunk #3 is completely unnecessary (assigning default value for _login_class).
Hunk #4 can be simplified to the following (again, Hunk #3 removed):

1060: # Prepend default limits
1061: _doit="limits -C ${_login_class:-daemon} $_doit"

Alternatively, if you think that future code may want to inherit the default, keep Hunk #3 but change it to:

: ${_login_class:=daemon}

And don't modify Hunk #4.

etc/rc.subr
947 ↗(On Diff #8659)

After some thought, I think the best solution is:

947: _prepend=\$${name}_prepend _login_class=\${${name}_login_class:-daemon}

Then, remove lines 948-952 below. With that, this patch would be ready to sail.

adrian edited edge metadata.

Address devin's feedback.

This revision was automatically updated to reflect the committed changes.