* [bug#74508] [PATCH 0/2] Improvements for mingetty-service-type @ 2024-11-24 14:28 Tomas Volf 2024-11-24 14:31 ` [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options Tomas Volf ` (2 more replies) 0 siblings, 3 replies; 9+ messages in thread From: Tomas Volf @ 2024-11-24 14:28 UTC (permalink / raw) To: 74508; +Cc: Tomas Volf, Ludovic Courtès, Maxim Cournoyer Some configuration options were missing and some accessors where misnamed. Ability to depend on arbitrary shepherd service is also added. Tomas Volf (2): services: mingetty: Add additional configuration options. services: mingetty: Support waiting on shepherd services. doc/guix.texi | 47 ++++++++++++++++++++++- gnu/services/base.scm | 86 ++++++++++++++++++++++++++++++++++--------- 2 files changed, 114 insertions(+), 19 deletions(-) -- 2.46.0 ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options. 2024-11-24 14:28 [bug#74508] [PATCH 0/2] Improvements for mingetty-service-type Tomas Volf @ 2024-11-24 14:31 ` Tomas Volf 2024-11-25 1:45 ` Maxim Cournoyer 2024-11-24 14:31 ` [bug#74508] [PATCH 2/2] services: mingetty: Support waiting on shepherd services Tomas Volf 2024-11-25 16:05 ` [bug#74508] [PATCH v2 1/3] services: mingetty: Add additional configuration options Tomas Volf 2 siblings, 1 reply; 9+ messages in thread From: Tomas Volf @ 2024-11-24 14:31 UTC (permalink / raw) To: 74508; +Cc: Tomas Volf, Ludovic Courtès, Maxim Cournoyer Not all aspects of mingetty were configurable, so this commit adds the additional configuration fields to support that. It also renames the accessors for all fields except `tty'. They were named just `mingetty-$FIELD', instead of `mingetty-configuration-$FIELD'. However the renaming *is* backwards compatible, since in the define-module's #:export argument the correct (`mingetty-configuration-$FIELD') were used already. Hence, until now, there was no way to access anything except the `tty' field. * gnu/services/base.scm (<mingetty-configuration>): Add delay, print-issue, print-hostname, nice, chdir, chroot fields. Rename accessors for auto-login, login-program, login-pause?, clear-on-logout?. (mingetty-shepherd-service): Use the new fields. (define-module)<#:export>: Export the new accessors. * doc/guix.texi (Base Services)<mingetty-configuration>: Document the additional field. Change-Id: I4557a82498805ade0b341feda9d33eccc305690f --- doc/guix.texi | 27 ++++++++++++++++++- gnu/services/base.scm | 62 ++++++++++++++++++++++++++++++++++++------- 2 files changed, 79 insertions(+), 10 deletions(-) diff --git a/doc/guix.texi b/doc/guix.texi index 1c39628ffa..d689711e80 100644 --- a/doc/guix.texi +++ b/doc/guix.texi @@ -19285,7 +19285,32 @@ Base Services will have to press a key before the log-in shell is launched. @item @code{clear-on-logout?} (default: @code{#t}) -When set to @code{#t}, the screen will be cleared after logout. +When set to @code{#t}, the screen will be cleared before showing the +login prompt. The field name is bit unfortunate, since it controls +clearing also before the initial login, not just after a logout. + +@item @code{delay} (default: @code{#f}) +When set to a number, sleep that many seconds after startup. + +@item @code{print-issue} (default: @code{#t}) +When set to @code{#t}, write out a new line and the content of +@file{/etc/issue}. Value of @code{'no-nl} can be used to suppress the +new line. + +@item @code{print-hostname} (default: @code{#t}) +When set to @code{#t}, print the host name before the login prompt. The +host name is printed up to the first dot. Can be set to @code{'long} to +print the full host name. + +@item @code{nice} (default: @code{#f}) +When set to a number, change the process priority using @code{nice}. + +@item @code{chdir} (default: @code{#f}) +When set to a string, change into that directory before calling the +login program. + +@item @code{chroot} (default: @code{#f}) +When set to a string, call @code{chroot} with that directory. @item @code{mingetty} (default: @var{mingetty}) The Mingetty package to use. diff --git a/gnu/services/base.scm b/gnu/services/base.scm index 6473e1a91a..b3d3553091 100644 --- a/gnu/services/base.scm +++ b/gnu/services/base.scm @@ -186,7 +186,12 @@ (define-module (gnu services base) mingetty-configuration-login-program mingetty-configuration-login-pause? mingetty-configuration-clear-on-logout? - mingetty-configuration-mingetty + mingetty-configuration-delay + mingetty-configuration-print-issue + mingetty-configuration-print-hostname + mingetty-configuration-nice + mingetty-configuration-chdir + mingetty-configuration-chroot mingetty-configuration? mingetty-service ; deprecated mingetty-service-type @@ -1242,20 +1247,33 @@ (define-record-type* <mingetty-configuration> mingetty-configuration? (mingetty mingetty-configuration-mingetty ;file-like (default mingetty)) - (tty mingetty-configuration-tty) ;string - (auto-login mingetty-auto-login ;string | #f + (tty mingetty-configuration-tty) ;string + (auto-login mingetty-configuration-auto-login ;string | #f (default #f)) - (login-program mingetty-login-program ;gexp + (login-program mingetty-configuration-login-program ;gexp (default #f)) - (login-pause? mingetty-login-pause? ;Boolean + (login-pause? mingetty-configuration-login-pause? ;Boolean (default #f)) - (clear-on-logout? mingetty-clear-on-logout? ;Boolean - (default #t))) + (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean + (default #t)) + (delay mingetty-configuration-delay ;Integer | #f + (default #f)) + (print-issue mingetty-configuration-print-issue ;Boolean | Symbol + (default #t)) + (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol + (default #t)) + (nice mingetty-configuration-nice ;Integer | #f + (default #f)) + (chdir mingetty-configuration-chdir ;String | #f + (default #f)) + (chroot mingetty-configuration-chroot ;String | #f + (default #f))) (define (mingetty-shepherd-service config) (match-record config <mingetty-configuration> - (mingetty tty auto-login login-program - login-pause? clear-on-logout?) + (mingetty tty auto-login login-program + login-pause? clear-on-logout? delay + print-issue print-hostname nice chdir chroot) (list (shepherd-service (documentation "Run mingetty on an tty.") @@ -1286,6 +1304,32 @@ (define (mingetty-shepherd-service config) #~()) #$@(if login-pause? #~("--loginpause") + #~()) + #$@(if delay + #~("--delay" #$(number->string delay)) + #~()) + #$@(match print-issue + (#t + #~()) + ('no-nl + #~("--nonewline")) + (#f + #~("--noissue"))) + #$@(match print-hostname + (#t + #~()) + ('long + #~("--long-hostname")) + (#f + #~("--nohostname"))) + #$@(if nice + #~("--nice" #$(number->string nice)) + #~()) + #$@(if chdir + #~("--chdir" #$chdir) + #~()) + #$@(if chroot + #~("--chroot" #$chroot) #~())))) (stop #~(make-kill-destructor)))))) -- 2.46.0 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options. 2024-11-24 14:31 ` [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options Tomas Volf @ 2024-11-25 1:45 ` Maxim Cournoyer 2024-11-25 15:37 ` Tomas Volf 0 siblings, 1 reply; 9+ messages in thread From: Maxim Cournoyer @ 2024-11-25 1:45 UTC (permalink / raw) To: Tomas Volf; +Cc: 74508, Ludovic Courtès Hello, Tomas Volf <~@wolfsden.cz> writes: > Not all aspects of mingetty were configurable, so this commit adds the > additional configuration fields to support that. > > It also renames the accessors for all fields except `tty'. They were named > just `mingetty-$FIELD', instead of `mingetty-configuration-$FIELD'. However > the renaming *is* backwards compatible, since in the define-module's #:export > argument the correct (`mingetty-configuration-$FIELD') were used already. > Hence, until now, there was no way to access anything except the `tty' field. Fun, good catch! I find it odd that Guile doesn't warn or error when exporting a symbol that isn't defined; I was bit by that recently myself. Personally I'd have effected that correction in a distinct commit, to keep your new functionality diff to its bare minimum (clearer/easier to review). > * gnu/services/base.scm (<mingetty-configuration>): Add delay, print-issue, > print-hostname, nice, chdir, chroot fields. Rename accessors for auto-login, > login-program, login-pause?, clear-on-logout?. Are all these expected to be functional on Guix, e.g., the 'chroot' option? > (mingetty-shepherd-service): Use the new fields. > (define-module)<#:export>: Export the new accessors. > * doc/guix.texi (Base Services)<mingetty-configuration>: Document the > additional field. > > Change-Id: I4557a82498805ade0b341feda9d33eccc305690f > --- > doc/guix.texi | 27 ++++++++++++++++++- > gnu/services/base.scm | 62 ++++++++++++++++++++++++++++++++++++------- > 2 files changed, 79 insertions(+), 10 deletions(-) > > diff --git a/doc/guix.texi b/doc/guix.texi > index 1c39628ffa..d689711e80 100644 > --- a/doc/guix.texi > +++ b/doc/guix.texi > @@ -19285,7 +19285,32 @@ Base Services > will have to press a key before the log-in shell is launched. > > @item @code{clear-on-logout?} (default: @code{#t}) > -When set to @code{#t}, the screen will be cleared after logout. > +When set to @code{#t}, the screen will be cleared before showing the > +login prompt. The field name is bit unfortunate, since it controls > +clearing also before the initial login, not just after a logout. > + > +@item @code{delay} (default: @code{#f}) > +When set to a number, sleep that many seconds after startup. > + > +@item @code{print-issue} (default: @code{#t}) > +When set to @code{#t}, write out a new line and the content of > +@file{/etc/issue}. Value of @code{'no-nl} can be used to suppress the > +new line. This sounds useful. Could it be used in place of a 'motd', such as in our hydra/berlin.scm conf (from the Guix maintenance repo), which is currently relying on PAM to work (and doesn't currently seem to do anything, at least on berlin, for unknown reason). > +@item @code{print-hostname} (default: @code{#t}) > +When set to @code{#t}, print the host name before the login prompt. The > +host name is printed up to the first dot. Can be set to @code{'long} to > +print the full host name. > + > +@item @code{nice} (default: @code{#f}) > +When set to a number, change the process priority using @code{nice}. > + > +@item @code{chdir} (default: @code{#f}) > +When set to a string, change into that directory before calling the > +login program. > + > +@item @code{chroot} (default: @code{#f}) > +When set to a string, call @code{chroot} with that directory. > > @item @code{mingetty} (default: @var{mingetty}) > The Mingetty package to use. > diff --git a/gnu/services/base.scm b/gnu/services/base.scm > index 6473e1a91a..b3d3553091 100644 > --- a/gnu/services/base.scm > +++ b/gnu/services/base.scm > @@ -186,7 +186,12 @@ (define-module (gnu services base) > mingetty-configuration-login-program > mingetty-configuration-login-pause? > mingetty-configuration-clear-on-logout? > - mingetty-configuration-mingetty Why is the above accessor removed? > + mingetty-configuration-delay > + mingetty-configuration-print-issue > + mingetty-configuration-print-hostname > + mingetty-configuration-nice > + mingetty-configuration-chdir > + mingetty-configuration-chroot > mingetty-configuration? > mingetty-service ; deprecated > mingetty-service-type > @@ -1242,20 +1247,33 @@ (define-record-type* <mingetty-configuration> > mingetty-configuration? > (mingetty mingetty-configuration-mingetty ;file-like > (default mingetty)) > - (tty mingetty-configuration-tty) ;string > - (auto-login mingetty-auto-login ;string | #f > + (tty mingetty-configuration-tty) ;string > + (auto-login mingetty-configuration-auto-login ;string | #f > (default #f)) > - (login-program mingetty-login-program ;gexp > + (login-program mingetty-configuration-login-program ;gexp > (default #f)) > - (login-pause? mingetty-login-pause? ;Boolean > + (login-pause? mingetty-configuration-login-pause? ;Boolean > (default #f)) > - (clear-on-logout? mingetty-clear-on-logout? ;Boolean > - (default #t))) > + (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean > + (default #t)) > + (delay mingetty-configuration-delay ;Integer | #f > + (default #f)) > + (print-issue mingetty-configuration-print-issue ;Boolean | Symbol > + (default #t)) > + (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol > + (default #t)) > + (nice mingetty-configuration-nice ;Integer | #f > + (default #f)) > + (chdir mingetty-configuration-chdir ;String | #f > + (default #f)) > + (chroot mingetty-configuration-chroot ;String | #f > + (default #f))) > > (define (mingetty-shepherd-service config) > (match-record config <mingetty-configuration> > - (mingetty tty auto-login login-program > - login-pause? clear-on-logout?) > + (mingetty tty auto-login login-program > + login-pause? clear-on-logout? delay > + print-issue print-hostname nice chdir chroot) > (list > (shepherd-service > (documentation "Run mingetty on an tty.") > @@ -1286,6 +1304,32 @@ (define (mingetty-shepherd-service config) > #~()) > #$@(if login-pause? > #~("--loginpause") > + #~()) > + #$@(if delay > + #~("--delay" #$(number->string delay)) > + #~()) > + #$@(match print-issue > + (#t > + #~()) > + ('no-nl > + #~("--nonewline")) > + (#f > + #~("--noissue"))) > + #$@(match print-hostname > + (#t > + #~()) > + ('long > + #~("--long-hostname")) > + (#f > + #~("--nohostname"))) > + #$@(if nice > + #~("--nice" #$(number->string nice)) > + #~()) > + #$@(if chdir > + #~("--chdir" #$chdir) > + #~()) > + #$@(if chroot > + #~("--chroot" #$chroot) > #~())))) > (stop #~(make-kill-destructor)))))) Neatly crafted. Could you please send a v2 with my small comments above addressed, such as splitting in two commits, and not removing the 'mingetty-configuration-mingetty' accessor? Other than that, LGTM. -- Thanks, Maxim ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options. 2024-11-25 1:45 ` Maxim Cournoyer @ 2024-11-25 15:37 ` Tomas Volf 0 siblings, 0 replies; 9+ messages in thread From: Tomas Volf @ 2024-11-25 15:37 UTC (permalink / raw) To: Maxim Cournoyer; +Cc: 74508, Ludovic Courtès [-- Attachment #1: Type: text/plain, Size: 10847 bytes --] Hi, thank you for the review of this patch as well. Comments below. Maxim Cournoyer <maxim.cournoyer@gmail.com> writes: > Hello, > > Tomas Volf <~@wolfsden.cz> writes: > >> Not all aspects of mingetty were configurable, so this commit adds the >> additional configuration fields to support that. >> >> It also renames the accessors for all fields except `tty'. They were named >> just `mingetty-$FIELD', instead of `mingetty-configuration-$FIELD'. However >> the renaming *is* backwards compatible, since in the define-module's #:export >> argument the correct (`mingetty-configuration-$FIELD') were used already. >> Hence, until now, there was no way to access anything except the `tty' field. > > Fun, good catch! I find it odd that Guile doesn't warn or error when > exporting a symbol that isn't defined; I was bit by that recently > myself. I assume there might be historical and/or technical reasons for that, but that is probably topic for guile-devel. :) I personally am bit torn, while I can imagine situations when some symbol is by design left unbound, I had no need for that yet. > Personally I'd have effected that correction in a distinct commit, to > keep your new functionality diff to its bare minimum (clearer/easier > to review). Yeah, I agree, will split it. > >> * gnu/services/base.scm (<mingetty-configuration>): Add delay, print-issue, >> print-hostname, nice, chdir, chroot fields. Rename accessors for auto-login, >> login-program, login-pause?, clear-on-logout?. > > Are all these expected to be functional on Guix, e.g., the 'chroot' > option? Sure, why not? I can for example imagine having Alpine Linux installed in chroot in /opt/alpine, and tty2 would login you into Alpine instead of GuixSD. Do I expect the `chroot' to be used often? No. But it *is* a valid argument to mingetty, so I think it makes sense to add them all and leave it to the user creativity whether it will be used or not. > >> (mingetty-shepherd-service): Use the new fields. >> (define-module)<#:export>: Export the new accessors. >> * doc/guix.texi (Base Services)<mingetty-configuration>: Document the >> additional field. >> >> Change-Id: I4557a82498805ade0b341feda9d33eccc305690f >> --- >> doc/guix.texi | 27 ++++++++++++++++++- >> gnu/services/base.scm | 62 ++++++++++++++++++++++++++++++++++++------- >> 2 files changed, 79 insertions(+), 10 deletions(-) >> >> diff --git a/doc/guix.texi b/doc/guix.texi >> index 1c39628ffa..d689711e80 100644 >> --- a/doc/guix.texi >> +++ b/doc/guix.texi >> @@ -19285,7 +19285,32 @@ Base Services >> will have to press a key before the log-in shell is launched. >> >> @item @code{clear-on-logout?} (default: @code{#t}) >> -When set to @code{#t}, the screen will be cleared after logout. >> +When set to @code{#t}, the screen will be cleared before showing the >> +login prompt. The field name is bit unfortunate, since it controls >> +clearing also before the initial login, not just after a logout. >> + >> +@item @code{delay} (default: @code{#f}) >> +When set to a number, sleep that many seconds after startup. >> + >> +@item @code{print-issue} (default: @code{#t}) >> +When set to @code{#t}, write out a new line and the content of >> +@file{/etc/issue}. Value of @code{'no-nl} can be used to suppress the >> +new line. > > This sounds useful. Could it be used in place of a 'motd', such as in > our hydra/berlin.scm conf (from the Guix maintenance repo), which is > currently relying on PAM to work I do not think so. Notice the default value (#t). The issue is printed by default. When you see a tty login prompt, it looks (by default) like this: --8<---------------cut here---------------start------------->8--- $ISSUE $HOST login: $USER Password: $PASSWORD $MOTD --8<---------------cut here---------------end--------------->8--- So in my QEMU test system the "logging screen" looks (roughly) like this: --8<---------------cut here---------------start------------->8--- GNU/Linux test-system x86_64 <--- /etc/issue login: tester (automatic login) GuixSD test VM. Welcome. <--- /gnu/store/...-motd $ --8<---------------cut here---------------end--------------->8--- > (and doesn't currently seem to do anything, at least on berlin, for > unknown reason). I think this is expected no? I would assume that most people log via SSH (only Ricardo has physical access?) and there is no `/etc/motd' file created by `frontend-services'. Consider adding something like this to the list of services returned by the `frontend-services' procedure: --8<---------------cut here---------------start------------->8--- (extra-special-file "/etc/motd" motd) --8<---------------cut here---------------end--------------->8--- That should make the message of the day visible even for SSH logins. > >> +@item @code{print-hostname} (default: @code{#t}) >> +When set to @code{#t}, print the host name before the login prompt. The >> +host name is printed up to the first dot. Can be set to @code{'long} to >> +print the full host name. >> + >> +@item @code{nice} (default: @code{#f}) >> +When set to a number, change the process priority using @code{nice}. >> + >> +@item @code{chdir} (default: @code{#f}) >> +When set to a string, change into that directory before calling the >> +login program. >> + >> +@item @code{chroot} (default: @code{#f}) >> +When set to a string, call @code{chroot} with that directory. >> >> @item @code{mingetty} (default: @var{mingetty}) >> The Mingetty package to use. >> diff --git a/gnu/services/base.scm b/gnu/services/base.scm >> index 6473e1a91a..b3d3553091 100644 >> --- a/gnu/services/base.scm >> +++ b/gnu/services/base.scm >> @@ -186,7 +186,12 @@ (define-module (gnu services base) >> mingetty-configuration-login-program >> mingetty-configuration-login-pause? >> mingetty-configuration-clear-on-logout? >> - mingetty-configuration-mingetty > > Why is the above accessor removed? Good catch, that was not intentional. > >> + mingetty-configuration-delay >> + mingetty-configuration-print-issue >> + mingetty-configuration-print-hostname >> + mingetty-configuration-nice >> + mingetty-configuration-chdir >> + mingetty-configuration-chroot >> mingetty-configuration? >> mingetty-service ; deprecated >> mingetty-service-type >> @@ -1242,20 +1247,33 @@ (define-record-type* <mingetty-configuration> >> mingetty-configuration? >> (mingetty mingetty-configuration-mingetty ;file-like >> (default mingetty)) >> - (tty mingetty-configuration-tty) ;string >> - (auto-login mingetty-auto-login ;string | #f >> + (tty mingetty-configuration-tty) ;string >> + (auto-login mingetty-configuration-auto-login ;string | #f >> (default #f)) >> - (login-program mingetty-login-program ;gexp >> + (login-program mingetty-configuration-login-program ;gexp >> (default #f)) >> - (login-pause? mingetty-login-pause? ;Boolean >> + (login-pause? mingetty-configuration-login-pause? ;Boolean >> (default #f)) >> - (clear-on-logout? mingetty-clear-on-logout? ;Boolean >> - (default #t))) >> + (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean >> + (default #t)) >> + (delay mingetty-configuration-delay ;Integer | #f >> + (default #f)) >> + (print-issue mingetty-configuration-print-issue ;Boolean | Symbol >> + (default #t)) >> + (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol >> + (default #t)) >> + (nice mingetty-configuration-nice ;Integer | #f >> + (default #f)) >> + (chdir mingetty-configuration-chdir ;String | #f >> + (default #f)) >> + (chroot mingetty-configuration-chroot ;String | #f >> + (default #f))) >> >> (define (mingetty-shepherd-service config) >> (match-record config <mingetty-configuration> >> - (mingetty tty auto-login login-program >> - login-pause? clear-on-logout?) >> + (mingetty tty auto-login login-program >> + login-pause? clear-on-logout? delay >> + print-issue print-hostname nice chdir chroot) >> (list >> (shepherd-service >> (documentation "Run mingetty on an tty.") >> @@ -1286,6 +1304,32 @@ (define (mingetty-shepherd-service config) >> #~()) >> #$@(if login-pause? >> #~("--loginpause") >> + #~()) >> + #$@(if delay >> + #~("--delay" #$(number->string delay)) >> + #~()) >> + #$@(match print-issue >> + (#t >> + #~()) >> + ('no-nl >> + #~("--nonewline")) >> + (#f >> + #~("--noissue"))) >> + #$@(match print-hostname >> + (#t >> + #~()) >> + ('long >> + #~("--long-hostname")) >> + (#f >> + #~("--nohostname"))) >> + #$@(if nice >> + #~("--nice" #$(number->string nice)) >> + #~()) >> + #$@(if chdir >> + #~("--chdir" #$chdir) >> + #~()) >> + #$@(if chroot >> + #~("--chroot" #$chroot) >> #~())))) >> (stop #~(make-kill-destructor)))))) > > Neatly crafted. Could you please send a v2 with my small comments above > addressed, such as splitting in two commits, and not removing the > 'mingetty-configuration-mingetty' accessor? Other than that, LGTM. Will polish the commit messages and send v2, thank you once more for the review. Have a nice day, Tomas -- There are only two hard things in Computer Science: cache invalidation, naming things and off-by-one errors. [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 853 bytes --] ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH 2/2] services: mingetty: Support waiting on shepherd services. 2024-11-24 14:28 [bug#74508] [PATCH 0/2] Improvements for mingetty-service-type Tomas Volf 2024-11-24 14:31 ` [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options Tomas Volf @ 2024-11-24 14:31 ` Tomas Volf 2024-11-25 1:49 ` Maxim Cournoyer 2024-11-25 16:05 ` [bug#74508] [PATCH v2 1/3] services: mingetty: Add additional configuration options Tomas Volf 2 siblings, 1 reply; 9+ messages in thread From: Tomas Volf @ 2024-11-24 14:31 UTC (permalink / raw) To: 74508; +Cc: Tomas Volf, Ludovic Courtès, Maxim Cournoyer For auto-login on systems with elogind, dbus-system needs to be started. This commit adds ability to express that ordering. * gnu/services/base.scm (<mingetty-configuration>): Add shepherd-requirement field. (mingetty-shepherd-service): Use it. * doc/guix.texi (Base Services)<mingetty-configuration>: Document it. Change-Id: Iedbdc4375180740379d561aa193d7c63350d2e7b --- doc/guix.texi | 20 ++++++++++++++ gnu/services/base.scm | 62 ++++++++++++++++++++++++------------------- 2 files changed, 54 insertions(+), 28 deletions(-) diff --git a/doc/guix.texi b/doc/guix.texi index d689711e80..e15cfeb39d 100644 --- a/doc/guix.texi +++ b/doc/guix.texi @@ -19312,6 +19312,26 @@ Base Services @item @code{chroot} (default: @code{#f}) When set to a string, call @code{chroot} with that directory. +@item @code{shepherd-requirement} +List of shepherd requirements. Unless you know what you are doing, it +is recommended to add to the default list instead of replacing. + +For example you can use this field when performing auto-login on a +system with elogind to wait on @code{'dbus-system}. + +@lisp +(modify-services %base-services + (mingetty-service-type config => + (mingetty-configuration + (inherit config) + ;; Automatically log in as "guest". + (auto-login "guest") + (shepherd-requirement + (cons 'dbus-system + (mingetty-configuration-shepherd-requirement + config)))))) +@end lisp + @item @code{mingetty} (default: @var{mingetty}) The Mingetty package to use. diff --git a/gnu/services/base.scm b/gnu/services/base.scm index b3d3553091..6681d5f8d4 100644 --- a/gnu/services/base.scm +++ b/gnu/services/base.scm @@ -192,6 +192,7 @@ (define-module (gnu services base) mingetty-configuration-nice mingetty-configuration-chdir mingetty-configuration-chroot + mingetty-configuration-shepherd-requirement mingetty-configuration? mingetty-service ; deprecated mingetty-service-type @@ -1245,44 +1246,49 @@ (define-deprecated (agetty-service config) (define-record-type* <mingetty-configuration> mingetty-configuration make-mingetty-configuration mingetty-configuration? - (mingetty mingetty-configuration-mingetty ;file-like - (default mingetty)) - (tty mingetty-configuration-tty) ;string - (auto-login mingetty-configuration-auto-login ;string | #f - (default #f)) - (login-program mingetty-configuration-login-program ;gexp - (default #f)) - (login-pause? mingetty-configuration-login-pause? ;Boolean - (default #f)) - (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean - (default #t)) - (delay mingetty-configuration-delay ;Integer | #f - (default #f)) - (print-issue mingetty-configuration-print-issue ;Boolean | Symbol - (default #t)) - (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol - (default #t)) - (nice mingetty-configuration-nice ;Integer | #f - (default #f)) - (chdir mingetty-configuration-chdir ;String | #f - (default #f)) - (chroot mingetty-configuration-chroot ;String | #f - (default #f))) + (mingetty mingetty-configuration-mingetty ;file-like + (default mingetty)) + (tty mingetty-configuration-tty) ;string + (auto-login mingetty-configuration-auto-login ;string | #f + (default #f)) + (login-program mingetty-configuration-login-program ;gexp + (default #f)) + (login-pause? mingetty-configuration-login-pause? ;Boolean + (default #f)) + (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean + (default #t)) + (delay mingetty-configuration-delay ;Integer | #f + (default #f)) + (print-issue mingetty-configuration-print-issue ;Boolean | Symbol + (default #t)) + (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol + (default #t)) + (nice mingetty-configuration-nice ;Integer | #f + (default #f)) + (chdir mingetty-configuration-chdir ;String | #f + (default #f)) + (chroot mingetty-configuration-chroot ;String | #f + (default #f)) + (shepherd-requirement mingetty-configuration-shepherd-requirement + ;; Since the login prompt shows the host name, wait + ;; for the 'host-name' service to be done. Also wait + ;; for udev essentially so that the tty text is not + ;; lost in the middle of kernel messages (XXX). + (default '(user-processes host-name udev + virtual-terminal)))) (define (mingetty-shepherd-service config) (match-record config <mingetty-configuration> (mingetty tty auto-login login-program login-pause? clear-on-logout? delay - print-issue print-hostname nice chdir chroot) + print-issue print-hostname nice chdir chroot + shepherd-requirement) (list (shepherd-service (documentation "Run mingetty on an tty.") (provision (list (symbol-append 'term- (string->symbol tty)))) - ;; Since the login prompt shows the host name, wait for the 'host-name' - ;; service to be done. Also wait for udev essentially so that the tty - ;; text is not lost in the middle of kernel messages (XXX). - (requirement '(user-processes host-name udev virtual-terminal)) + (requirement shepherd-requirement) (start #~(make-forkexec-constructor (list #$(file-append mingetty "/sbin/mingetty") -- 2.46.0 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH 2/2] services: mingetty: Support waiting on shepherd services. 2024-11-24 14:31 ` [bug#74508] [PATCH 2/2] services: mingetty: Support waiting on shepherd services Tomas Volf @ 2024-11-25 1:49 ` Maxim Cournoyer 0 siblings, 0 replies; 9+ messages in thread From: Maxim Cournoyer @ 2024-11-25 1:49 UTC (permalink / raw) To: Tomas Volf; +Cc: 74508, Ludovic Courtès Tomas Volf <~@wolfsden.cz> writes: > For auto-login on systems with elogind, dbus-system needs to be started. This > commit adds ability to express that ordering. > > * gnu/services/base.scm (<mingetty-configuration>): Add shepherd-requirement > field. > (mingetty-shepherd-service): Use it. > * doc/guix.texi (Base Services)<mingetty-configuration>: Document it. > > Change-Id: Iedbdc4375180740379d561aa193d7c63350d2e7b Reviewed-by: Maxim Cournoyer <maxim.cournoyer@gmail> -- Thanks, Maxim ^ permalink raw reply [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH v2 1/3] services: mingetty: Add additional configuration options. 2024-11-24 14:28 [bug#74508] [PATCH 0/2] Improvements for mingetty-service-type Tomas Volf 2024-11-24 14:31 ` [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options Tomas Volf 2024-11-24 14:31 ` [bug#74508] [PATCH 2/2] services: mingetty: Support waiting on shepherd services Tomas Volf @ 2024-11-25 16:05 ` Tomas Volf 2024-11-25 16:05 ` [bug#74508] [PATCH v2 2/3] services: mingetty: Rename misnamed accessors Tomas Volf 2024-11-25 16:05 ` [bug#74508] [PATCH v2 3/3] services: mingetty: Support waiting on shepherd services Tomas Volf 2 siblings, 2 replies; 9+ messages in thread From: Tomas Volf @ 2024-11-25 16:05 UTC (permalink / raw) To: 74508; +Cc: Tomas Volf, Ludovic Courtès, Maxim Cournoyer Not all aspects of mingetty were configurable, so this commit adds the additional configuration fields to support that. * gnu/services/base.scm (<mingetty-configuration>): Add delay, print-issue, print-hostname, nice, chdir, chroot fields. (mingetty-shepherd-service): Use the new fields. (define-module)<#:export>: Export the new accessors. * doc/guix.texi (Base Services)<mingetty-configuration>: Document the additional field. Change-Id: I4557a82498805ade0b341feda9d33eccc305690f --- v2: Split the renaming into separate commit (2/3). Do not delete the mingetty-configuration-mingetty accessor. doc/guix.texi | 27 ++++++++++++++++++++++- gnu/services/base.scm | 51 ++++++++++++++++++++++++++++++++++++++++--- 2 files changed, 74 insertions(+), 4 deletions(-) diff --git a/doc/guix.texi b/doc/guix.texi index 26488b41c8..c5f9481810 100644 --- a/doc/guix.texi +++ b/doc/guix.texi @@ -19348,7 +19348,32 @@ Base Services will have to press a key before the log-in shell is launched. @item @code{clear-on-logout?} (default: @code{#t}) -When set to @code{#t}, the screen will be cleared after logout. +When set to @code{#t}, the screen will be cleared before showing the +login prompt. The field name is bit unfortunate, since it controls +clearing also before the initial login, not just after a logout. + +@item @code{delay} (default: @code{#f}) +When set to a number, sleep that many seconds after startup. + +@item @code{print-issue} (default: @code{#t}) +When set to @code{#t}, write out a new line and the content of +@file{/etc/issue}. Value of @code{'no-nl} can be used to suppress the +new line. + +@item @code{print-hostname} (default: @code{#t}) +When set to @code{#t}, print the host name before the login prompt. The +host name is printed up to the first dot. Can be set to @code{'long} to +print the full host name. + +@item @code{nice} (default: @code{#f}) +When set to a number, change the process priority using @code{nice}. + +@item @code{chdir} (default: @code{#f}) +When set to a string, change into that directory before calling the +login program. + +@item @code{chroot} (default: @code{#f}) +When set to a string, call @code{chroot} with that directory. @item @code{mingetty} (default: @var{mingetty}) The Mingetty package to use. diff --git a/gnu/services/base.scm b/gnu/services/base.scm index 6473e1a91a..9712218bd5 100644 --- a/gnu/services/base.scm +++ b/gnu/services/base.scm @@ -187,6 +187,12 @@ (define-module (gnu services base) mingetty-configuration-login-pause? mingetty-configuration-clear-on-logout? mingetty-configuration-mingetty + mingetty-configuration-delay + mingetty-configuration-print-issue + mingetty-configuration-print-hostname + mingetty-configuration-nice + mingetty-configuration-chdir + mingetty-configuration-chroot mingetty-configuration? mingetty-service ; deprecated mingetty-service-type @@ -1250,12 +1256,25 @@ (define-record-type* <mingetty-configuration> (login-pause? mingetty-login-pause? ;Boolean (default #f)) (clear-on-logout? mingetty-clear-on-logout? ;Boolean - (default #t))) + (default #t)) + (delay mingetty-configuration-delay ;Integer | #f + (default #f)) + (print-issue mingetty-configuration-print-issue ;Boolean | Symbol + (default #t)) + (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol + (default #t)) + (nice mingetty-configuration-nice ;Integer | #f + (default #f)) + (chdir mingetty-configuration-chdir ;String | #f + (default #f)) + (chroot mingetty-configuration-chroot ;String | #f + (default #f))) (define (mingetty-shepherd-service config) (match-record config <mingetty-configuration> - (mingetty tty auto-login login-program - login-pause? clear-on-logout?) + ( mingetty tty auto-login login-program + login-pause? clear-on-logout? delay + print-issue print-hostname nice chdir chroot) (list (shepherd-service (documentation "Run mingetty on an tty.") @@ -1286,6 +1305,32 @@ (define (mingetty-shepherd-service config) #~()) #$@(if login-pause? #~("--loginpause") + #~()) + #$@(if delay + #~("--delay" #$(number->string delay)) + #~()) + #$@(match print-issue + (#t + #~()) + ('no-nl + #~("--nonewline")) + (#f + #~("--noissue"))) + #$@(match print-hostname + (#t + #~()) + ('long + #~("--long-hostname")) + (#f + #~("--nohostname"))) + #$@(if nice + #~("--nice" #$(number->string nice)) + #~()) + #$@(if chdir + #~("--chdir" #$chdir) + #~()) + #$@(if chroot + #~("--chroot" #$chroot) #~())))) (stop #~(make-kill-destructor)))))) -- 2.46.0 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH v2 2/3] services: mingetty: Rename misnamed accessors. 2024-11-25 16:05 ` [bug#74508] [PATCH v2 1/3] services: mingetty: Add additional configuration options Tomas Volf @ 2024-11-25 16:05 ` Tomas Volf 2024-11-25 16:05 ` [bug#74508] [PATCH v2 3/3] services: mingetty: Support waiting on shepherd services Tomas Volf 1 sibling, 0 replies; 9+ messages in thread From: Tomas Volf @ 2024-11-25 16:05 UTC (permalink / raw) To: 74508; +Cc: Tomas Volf Rename the accessors to ensure all start with `mingetty-configuration-' prefix. Some were named just `mingetty-$FIELD', instead of `mingetty-configuration-$FIELD'. The renaming *is* backwards compatible, since in the define-module's #:export argument the correct (`mingetty-configuration-$FIELD') were used already and thus the accessors were not accessible. * gnu/services/base.scm (<mingetty-configuration>): Rename accessors for auto-login, login-program, login-pause?, clear-on-logout?. Change-Id: I4557a82498805ade0b341feda9d33eccc305690f --- v2: Now is a separate commit. gnu/services/base.scm | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/gnu/services/base.scm b/gnu/services/base.scm index 9712218bd5..e123226da5 100644 --- a/gnu/services/base.scm +++ b/gnu/services/base.scm @@ -1248,14 +1248,14 @@ (define-record-type* <mingetty-configuration> mingetty-configuration? (mingetty mingetty-configuration-mingetty ;file-like (default mingetty)) - (tty mingetty-configuration-tty) ;string - (auto-login mingetty-auto-login ;string | #f + (tty mingetty-configuration-tty) ;string + (auto-login mingetty-configuration-auto-login ;string | #f (default #f)) - (login-program mingetty-login-program ;gexp + (login-program mingetty-configuration-login-program ;gexp (default #f)) - (login-pause? mingetty-login-pause? ;Boolean + (login-pause? mingetty-configuration-login-pause? ;Boolean (default #f)) - (clear-on-logout? mingetty-clear-on-logout? ;Boolean + (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean (default #t)) (delay mingetty-configuration-delay ;Integer | #f (default #f)) -- 2.46.0 ^ permalink raw reply related [flat|nested] 9+ messages in thread
* [bug#74508] [PATCH v2 3/3] services: mingetty: Support waiting on shepherd services. 2024-11-25 16:05 ` [bug#74508] [PATCH v2 1/3] services: mingetty: Add additional configuration options Tomas Volf 2024-11-25 16:05 ` [bug#74508] [PATCH v2 2/3] services: mingetty: Rename misnamed accessors Tomas Volf @ 2024-11-25 16:05 ` Tomas Volf 1 sibling, 0 replies; 9+ messages in thread From: Tomas Volf @ 2024-11-25 16:05 UTC (permalink / raw) To: 74508; +Cc: Tomas Volf, Ludovic Courtès, Maxim Cournoyer For auto-login on systems with elogind, dbus-system needs to be started. This commit adds ability to express that ordering. * gnu/services/base.scm (<mingetty-configuration>): Add shepherd-requirement field. (mingetty-shepherd-service): Use it. * doc/guix.texi (Base Services)<mingetty-configuration>: Document it. Change-Id: Iedbdc4375180740379d561aa193d7c63350d2e7b --- v2: Just slight formatting changes. doc/guix.texi | 20 ++++++++++++++ gnu/services/base.scm | 62 ++++++++++++++++++++++++------------------- 2 files changed, 54 insertions(+), 28 deletions(-) diff --git a/doc/guix.texi b/doc/guix.texi index c5f9481810..9a8daf52d9 100644 --- a/doc/guix.texi +++ b/doc/guix.texi @@ -19375,6 +19375,26 @@ Base Services @item @code{chroot} (default: @code{#f}) When set to a string, call @code{chroot} with that directory. +@item @code{shepherd-requirement} +List of shepherd requirements. Unless you know what you are doing, it +is recommended to add to the default list instead of replacing. + +For example you can use this field when performing auto-login on a +system with elogind to wait on @code{'dbus-system}. + +@lisp +(modify-services %base-services + (mingetty-service-type config => + (mingetty-configuration + (inherit config) + ;; Automatically log in as "guest". + (auto-login "guest") + (shepherd-requirement + (cons 'dbus-system + (mingetty-configuration-shepherd-requirement + config)))))) +@end lisp + @item @code{mingetty} (default: @var{mingetty}) The Mingetty package to use. diff --git a/gnu/services/base.scm b/gnu/services/base.scm index e123226da5..ecf0322890 100644 --- a/gnu/services/base.scm +++ b/gnu/services/base.scm @@ -193,6 +193,7 @@ (define-module (gnu services base) mingetty-configuration-nice mingetty-configuration-chdir mingetty-configuration-chroot + mingetty-configuration-shepherd-requirement mingetty-configuration? mingetty-service ; deprecated mingetty-service-type @@ -1246,44 +1247,49 @@ (define-deprecated (agetty-service config) (define-record-type* <mingetty-configuration> mingetty-configuration make-mingetty-configuration mingetty-configuration? - (mingetty mingetty-configuration-mingetty ;file-like - (default mingetty)) - (tty mingetty-configuration-tty) ;string - (auto-login mingetty-configuration-auto-login ;string | #f - (default #f)) - (login-program mingetty-configuration-login-program ;gexp - (default #f)) - (login-pause? mingetty-configuration-login-pause? ;Boolean - (default #f)) - (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean - (default #t)) - (delay mingetty-configuration-delay ;Integer | #f - (default #f)) - (print-issue mingetty-configuration-print-issue ;Boolean | Symbol - (default #t)) - (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol - (default #t)) - (nice mingetty-configuration-nice ;Integer | #f - (default #f)) - (chdir mingetty-configuration-chdir ;String | #f - (default #f)) - (chroot mingetty-configuration-chroot ;String | #f - (default #f))) + (mingetty mingetty-configuration-mingetty ;file-like + (default mingetty)) + (tty mingetty-configuration-tty) ;string + (auto-login mingetty-configuration-auto-login ;string | #f + (default #f)) + (login-program mingetty-configuration-login-program ;gexp + (default #f)) + (login-pause? mingetty-configuration-login-pause? ;Boolean + (default #f)) + (clear-on-logout? mingetty-configuration-clear-on-logout? ;Boolean + (default #t)) + (delay mingetty-configuration-delay ;Integer | #f + (default #f)) + (print-issue mingetty-configuration-print-issue ;Boolean | Symbol + (default #t)) + (print-hostname mingetty-configuration-print-hostname ;Boolean | Symbol + (default #t)) + (nice mingetty-configuration-nice ;Integer | #f + (default #f)) + (chdir mingetty-configuration-chdir ;String | #f + (default #f)) + (chroot mingetty-configuration-chroot ;String | #f + (default #f)) + (shepherd-requirement mingetty-configuration-shepherd-requirement + ;; Since the login prompt shows the host name, wait + ;; for the 'host-name' service to be done. Also wait + ;; for udev essentially so that the tty text is not + ;; lost in the middle of kernel messages (XXX). + (default '( user-processes host-name udev + virtual-terminal)))) (define (mingetty-shepherd-service config) (match-record config <mingetty-configuration> ( mingetty tty auto-login login-program login-pause? clear-on-logout? delay - print-issue print-hostname nice chdir chroot) + print-issue print-hostname nice chdir chroot + shepherd-requirement) (list (shepherd-service (documentation "Run mingetty on an tty.") (provision (list (symbol-append 'term- (string->symbol tty)))) - ;; Since the login prompt shows the host name, wait for the 'host-name' - ;; service to be done. Also wait for udev essentially so that the tty - ;; text is not lost in the middle of kernel messages (XXX). - (requirement '(user-processes host-name udev virtual-terminal)) + (requirement shepherd-requirement) (start #~(make-forkexec-constructor (list #$(file-append mingetty "/sbin/mingetty") -- 2.46.0 ^ permalink raw reply related [flat|nested] 9+ messages in thread
end of thread, other threads:[~2024-11-25 16:08 UTC | newest] Thread overview: 9+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-11-24 14:28 [bug#74508] [PATCH 0/2] Improvements for mingetty-service-type Tomas Volf 2024-11-24 14:31 ` [bug#74508] [PATCH 1/2] services: mingetty: Add additional configuration options Tomas Volf 2024-11-25 1:45 ` Maxim Cournoyer 2024-11-25 15:37 ` Tomas Volf 2024-11-24 14:31 ` [bug#74508] [PATCH 2/2] services: mingetty: Support waiting on shepherd services Tomas Volf 2024-11-25 1:49 ` Maxim Cournoyer 2024-11-25 16:05 ` [bug#74508] [PATCH v2 1/3] services: mingetty: Add additional configuration options Tomas Volf 2024-11-25 16:05 ` [bug#74508] [PATCH v2 2/3] services: mingetty: Rename misnamed accessors Tomas Volf 2024-11-25 16:05 ` [bug#74508] [PATCH v2 3/3] services: mingetty: Support waiting on shepherd services Tomas Volf
Code repositories for project(s) associated with this external index https://git.savannah.gnu.org/cgit/guix.git This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.