* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
@ 2024-10-20 10:12 Dariqq
2024-11-06 13:52 ` bug#73903: (no subject) Jakob Honal via Bug reports for GNU Guix
` (2 more replies)
0 siblings, 3 replies; 12+ messages in thread
From: Dariqq @ 2024-10-20 10:12 UTC (permalink / raw)
To: 73903
When using guix home to manage shepherd services on a foreign
distribution the shepherd package is also added to the home-profile.
This then makes the home profile provide 'halt', 'shutdown' and 'reboot'
(and their manpages) masking the system ones.
Trying to run one of these then results in an error:
reboot: error: /var/run/shepherd/socket: No such file or directory
instead of e.g. rebooting the system.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: (no subject)
2024-10-20 10:12 bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Dariqq
@ 2024-11-06 13:52 ` Jakob Honal via Bug reports for GNU Guix
2024-11-10 11:51 ` bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Ludovic Courtès
2024-12-16 21:33 ` bug#73903: [PATCH 0/2] Add shepherd-for-home and make it default Dariqq
2 siblings, 0 replies; 12+ messages in thread
From: Jakob Honal via Bug reports for GNU Guix @ 2024-11-06 13:52 UTC (permalink / raw)
To: 73903
[-- Attachment #1: Type: text/html, Size: 155 bytes --]
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
2024-10-20 10:12 bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Dariqq
2024-11-06 13:52 ` bug#73903: (no subject) Jakob Honal via Bug reports for GNU Guix
@ 2024-11-10 11:51 ` Ludovic Courtès
2024-11-10 15:57 ` Dariqq
2024-12-16 21:33 ` bug#73903: [PATCH 0/2] Add shepherd-for-home and make it default Dariqq
2 siblings, 1 reply; 12+ messages in thread
From: Ludovic Courtès @ 2024-11-10 11:51 UTC (permalink / raw)
To: Dariqq; +Cc: 73903
Hi,
Dariqq <dariqq@posteo.net> skribis:
> When using guix home to manage shepherd services on a foreign
> distribution the shepherd package is also added to the home-profile.
>
> This then makes the home profile provide 'halt', 'shutdown' and
> 'reboot' (and their manpages) masking the system ones.
Oh, indeed. I’m not sure how to address that though. Ideas?
Ludo’.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
2024-11-10 11:51 ` bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Ludovic Courtès
@ 2024-11-10 15:57 ` Dariqq
2024-11-20 10:46 ` Ludovic Courtès
0 siblings, 1 reply; 12+ messages in thread
From: Dariqq @ 2024-11-10 15:57 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: 73903
Hi Ludo,
On 10.11.24 12:51, Ludovic Courtès wrote:
> Hi,
>
> Dariqq <dariqq@posteo.net> skribis:
>
>> When using guix home to manage shepherd services on a foreign
>> distribution the shepherd package is also added to the home-profile.
>>
>> This then makes the home profile provide 'halt', 'shutdown' and
>> 'reboot' (and their manpages) masking the system ones.
>
> Oh, indeed. I’m not sure how to address that though. Ideas?
>
Not sure if this is something that should be addressed by shepherd or
the default shepherd package used for guix home.
Initially I had the idea to add a configure flag to shepherd to disable
"building" and installing these 5 files (which is why I reported against
shepherd). I threw something together that works but I am not really
happy with it because imo such an option should disable *all*
things that are not required when only using it for user level
services and not just the entrypoints. That would be a lot more work though.
Another (simpler solution) would be to just solve the problem in guix by
using a shepherd variant that deletes sbin and share/man/man8.
Wdyt?
> Ludo’.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
2024-11-10 15:57 ` Dariqq
@ 2024-11-20 10:46 ` Ludovic Courtès
2024-11-21 16:21 ` Dariqq
0 siblings, 1 reply; 12+ messages in thread
From: Ludovic Courtès @ 2024-11-20 10:46 UTC (permalink / raw)
To: Dariqq; +Cc: 73903
Hi,
Dariqq <dariqq@posteo.net> skribis:
> On 10.11.24 12:51, Ludovic Courtès wrote:
>> Hi,
>> Dariqq <dariqq@posteo.net> skribis:
>>
>>> When using guix home to manage shepherd services on a foreign
>>> distribution the shepherd package is also added to the home-profile.
>>>
>>> This then makes the home profile provide 'halt', 'shutdown' and
>>> 'reboot' (and their manpages) masking the system ones.
>> Oh, indeed. I’m not sure how to address that though. Ideas?
>>
> Not sure if this is something that should be addressed by shepherd or
> the default shepherd package used for guix home.
[...]
> Another (simpler solution) would be to just solve the problem in guix
> by using a shepherd variant that deletes sbin and share/man/man8.
Yes, this sounds like a reasonable solution to me.
Ludo’.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
2024-11-20 10:46 ` Ludovic Courtès
@ 2024-11-21 16:21 ` Dariqq
2024-11-26 15:55 ` Ludovic Courtès
0 siblings, 1 reply; 12+ messages in thread
From: Dariqq @ 2024-11-21 16:21 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: 73903
Hi,
On 20.11.24 11:46, Ludovic Courtès wrote:
>
>> Another (simpler solution) would be to just solve the problem in guix
>> by using a shepherd variant that deletes sbin and share/man/man8.
>
> Yes, this sounds like a reasonable solution to me.
>
> Ludo’.
How should this work? should this be a (public?) procedure? Should it
rebuild shepherd or just copy the output with trivial-build-system?
I just thought of a more elegant solution, but this would be a lot
harder to implement properly:
- Move the sbin stuff into a seperate output
- Home shepherd service only adds the main output to the profile and
shepherd-root-service both
- Will need adjustments some packages that currently reference
shutdown/reboot ( -> lots of rebuilds because logind) and the same
change for the shepherd packages in the shepherd module.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
2024-11-21 16:21 ` Dariqq
@ 2024-11-26 15:55 ` Ludovic Courtès
2024-11-26 18:49 ` Dariqq
0 siblings, 1 reply; 12+ messages in thread
From: Ludovic Courtès @ 2024-11-26 15:55 UTC (permalink / raw)
To: Dariqq; +Cc: 73903
Hi,
Dariqq <dariqq@posteo.net> skribis:
> On 20.11.24 11:46, Ludovic Courtès wrote:
>
>>
>>> Another (simpler solution) would be to just solve the problem in guix
>>> by using a shepherd variant that deletes sbin and share/man/man8.
>> Yes, this sounds like a reasonable solution to me.
>> Ludo’.
>
> How should this work? should this be a (public?) procedure? Should it
> rebuild shepherd or just copy the output with trivial-build-system?
My understanding of this proposal is that there would be a
“shepherd-foreign” package, which is like “shepherd” but without
‘reboot’ and ‘halt’.
That package could be implemented with ‘trivial-build-system’ or
‘copy-build-system’ indeed, and it would symlink all of ‘shepherd’,
except its ‘sbin’ directory.
> I just thought of a more elegant solution, but this would be a lot
> harder to implement properly:
>
> - Move the sbin stuff into a seperate output
> - Home shepherd service only adds the main output to the profile and
> shepherd-root-service both
> - Will need adjustments some packages that currently reference
> shutdown/reboot ( -> lots of rebuilds because logind) and the same
> change for the shepherd packages in the shepherd module.
The advantage is that no extra step would be needed when using a foreign
distro. But yeah, it’s relatively intrusive, and not my favorite
solution, FWIW. Dunno.
WDYT?
Ludo’.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
2024-11-26 15:55 ` Ludovic Courtès
@ 2024-11-26 18:49 ` Dariqq
2024-12-12 10:50 ` Ludovic Courtès
0 siblings, 1 reply; 12+ messages in thread
From: Dariqq @ 2024-11-26 18:49 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: 73903
Hi,
On 26.11.24 16:55, Ludovic Courtès wrote:
> Hi,
>
> Dariqq <dariqq@posteo.net> skribis:
>
>>
>> How should this work? should this be a (public?) procedure? Should it
>> rebuild shepherd or just copy the output with trivial-build-system?
>
> My understanding of this proposal is that there would be a
> “shepherd-foreign” package, which is like “shepherd” but without
> ‘reboot’ and ‘halt’.
>
> That package could be implemented with ‘trivial-build-system’ or
> ‘copy-build-system’ indeed, and it would symlink all of ‘shepherd’,
> except its ‘sbin’ directory.
>
Imo it would make sense to have the sbinless shepherd be the default
shepherd for home-shepherd s.t. the home environment never provides
shutdown/halt by default. Those are commands are for the system to take
care of (whether that is the shepherd coming from root-shepherd or the
init from the foreign system).
On my foreign distro setup i am currently using this (apologies if the
formatting turns out weird):
--8<---------------cut here---------------start------------->8---
(define shepherd-for-home
(package
(inherit shepherd)
(name "shepherd-for-home")
(source #f)
(build-system trivial-build-system)
(arguments
(list
#:modules '((guix build union)
(guix build utils))
#:builder
#~(begin
(use-modules (guix build union)
(guix build utils))
(union-build #$output
(list #$(this-package-input "shepherd"))
#:create-all-directories? #t)
(delete-file-recursively (string-append #$output "/sbin"))
(delete-file-recursively (string-append #$output
"/share/man/man8")))))
(native-inputs '())
(inputs (list shepherd))))
--8<---------------cut here---------------end--------------->8---
If we don't want to care about the manpages then the
(#:create-all-directories? #t) can be omitted in union-build.
>> I just thought of a more elegant solution, but this would be a lot
>> harder to implement properly:
>>
>> - Move the sbin stuff into a seperate output
>> - Home shepherd service only adds the main output to the profile and
>> shepherd-root-service both
>> - Will need adjustments some packages that currently reference
>> shutdown/reboot ( -> lots of rebuilds because logind) and the same
>> change for the shepherd packages in the shepherd module.
>
> The advantage is that no extra step would be needed when using a foreign
> distro. But yeah, it’s relatively intrusive, and not my favorite
> solution, FWIW. Dunno.
>
If this would be possible without rebuilding I'd really like it because
it makes clear what part of the shepherd something depends on (service
manager stuff vs generic init stuff) and avoids an extra package that is
just shepherd minus sbindir. But the 3300 dependants of logind makes
this really unattractive.
> WDYT?
>
> Ludo’.
Dariqq
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution
2024-11-26 18:49 ` Dariqq
@ 2024-12-12 10:50 ` Ludovic Courtès
0 siblings, 0 replies; 12+ messages in thread
From: Ludovic Courtès @ 2024-12-12 10:50 UTC (permalink / raw)
To: Dariqq; +Cc: 73903
Hi Dariqq,
Dariqq <dariqq@posteo.net> skribis:
> Imo it would make sense to have the sbinless shepherd be the default
> shepherd for home-shepherd s.t. the home environment never provides
> shutdown/halt by default. Those are commands are for the system to take
> care of (whether that is the shepherd coming from root-shepherd or the
> init from the foreign system).
I agree.
> On my foreign distro setup i am currently using this (apologies if the
> formatting turns out weird):
>
> (define shepherd-for-home
> (package
> (inherit shepherd)
> (name "shepherd-for-home")
> (source #f)
> (build-system trivial-build-system)
> (arguments
> (list
> #:modules '((guix build union)
> (guix build utils))
> #:builder
> #~(begin
> (use-modules (guix build union)
> (guix build utils))
> (union-build #$output
> (list #$(this-package-input "shepherd"))
> #:create-all-directories? #t)
> (delete-file-recursively (string-append #$output "/sbin"))
> (delete-file-recursively (string-append #$output
> "/share/man/man8")))))
> (native-inputs '())
> (inputs (list shepherd))))
Perfect!
Would you like to submit a patch adding this package (probably with the
‘hidden?’ property), followed by a patch making it the default for Home?
Thanks,
Ludo’.
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [PATCH 0/2] Add shepherd-for-home and make it default
2024-10-20 10:12 bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Dariqq
2024-11-06 13:52 ` bug#73903: (no subject) Jakob Honal via Bug reports for GNU Guix
2024-11-10 11:51 ` bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Ludovic Courtès
@ 2024-12-16 21:33 ` Dariqq
2024-12-16 21:33 ` bug#73903: [PATCH 1/2] gnu: Add shepherd-for-home Dariqq
2024-12-16 21:33 ` bug#73903: [PATCH 2/2] gnu: home: Use shepherd-for-home as the default shepherd Dariqq
2 siblings, 2 replies; 12+ messages in thread
From: Dariqq @ 2024-12-16 21:33 UTC (permalink / raw)
To: 73903; +Cc: Dariqq
Hello,
This adds a variant of shepherd without sbin and makes it the default for home services. The reason is that when using guix home with shepherd services on a foreign distribution the default shepherd package masks commands like halt, shutdown and reboot which are usually provided by the initsystem.
Per the discussion in https://issues.guix.gnu.org/73903 the package is hidden and just symlinks all the relevant files from the base shepberd to the new output.
I successfully reconfigured my home environment and confirmed that halt/reboot are now provided by my system profile.
Dariqq (2):
gnu: Add shepherd-for-home.
gnu: home: Use shepherd-for-home as the default shepherd.
gnu/home/services/shepherd.scm | 2 +-
gnu/packages/admin.scm | 27 +++++++++++++++++++++++++++
2 files changed, 28 insertions(+), 1 deletion(-)
base-commit: c3290cee6add60b7e56f5f919d9498d78542790a
--
2.46.0
^ permalink raw reply [flat|nested] 12+ messages in thread
* bug#73903: [PATCH 1/2] gnu: Add shepherd-for-home.
2024-12-16 21:33 ` bug#73903: [PATCH 0/2] Add shepherd-for-home and make it default Dariqq
@ 2024-12-16 21:33 ` Dariqq
2024-12-16 21:33 ` bug#73903: [PATCH 2/2] gnu: home: Use shepherd-for-home as the default shepherd Dariqq
1 sibling, 0 replies; 12+ messages in thread
From: Dariqq @ 2024-12-16 21:33 UTC (permalink / raw)
To: 73903; +Cc: Dariqq, Sharlatan Hellseher
* gnu/packages/admin.scm (shepherd-for-home): New variable.
Change-Id: If66c7e7b688de239ca862326b51592b43ba22c25
---
gnu/packages/admin.scm | 27 +++++++++++++++++++++++++++
1 file changed, 27 insertions(+)
diff --git a/gnu/packages/admin.scm b/gnu/packages/admin.scm
index 77d02baa4e..08ac3d582a 100644
--- a/gnu/packages/admin.scm
+++ b/gnu/packages/admin.scm
@@ -428,6 +428,33 @@ (define-public shepherd-1.0
(define-public shepherd shepherd-0.10)
+;; A variant of shepherd without sbin to not mask
+;; halt and reboot on foreign distributions
+(define-public shepherd-for-home
+ (let ((base shepherd-1.0))
+ (hidden-package
+ (package/inherit base
+ (name "shepherd-for-home")
+ (source #f)
+ (build-system trivial-build-system)
+ (arguments
+ (list
+ #:modules '((guix build union)
+ (guix build utils))
+ #:builder
+ #~(begin
+ (use-modules (guix build union)
+ (guix build utils))
+ (union-build #$output
+ (list #$(this-package-input "shepherd"))
+ #:create-all-directories? #t)
+ (delete-file-recursively
+ (string-append #$output "/sbin"))
+ (delete-file-recursively
+ (string-append #$output "/share/man/man8")))))
+ (native-inputs '())
+ (inputs (list base))))))
+
(define-public guile2.2-shepherd
(package
(inherit shepherd-0.10)
--
2.46.0
^ permalink raw reply related [flat|nested] 12+ messages in thread
* bug#73903: [PATCH 2/2] gnu: home: Use shepherd-for-home as the default shepherd.
2024-12-16 21:33 ` bug#73903: [PATCH 0/2] Add shepherd-for-home and make it default Dariqq
2024-12-16 21:33 ` bug#73903: [PATCH 1/2] gnu: Add shepherd-for-home Dariqq
@ 2024-12-16 21:33 ` Dariqq
1 sibling, 0 replies; 12+ messages in thread
From: Dariqq @ 2024-12-16 21:33 UTC (permalink / raw)
To: 73903; +Cc: Dariqq
* gnu/home/services/shepherd.scm (home-shepherd-configuration): Change default
value of shepherd field to shepherd-for-home
Change-Id: I3773403bb1fcdcbe2acb1bbcbfaa009f4d31ace4
---
gnu/home/services/shepherd.scm | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/gnu/home/services/shepherd.scm b/gnu/home/services/shepherd.scm
index 37ad1489d6..c9bf819803 100644
--- a/gnu/home/services/shepherd.scm
+++ b/gnu/home/services/shepherd.scm
@@ -55,7 +55,7 @@ (define-record-type* <home-shepherd-configuration>
home-shepherd-configuration make-home-shepherd-configuration
home-shepherd-configuration?
(shepherd home-shepherd-configuration-shepherd
- (default shepherd-1.0)) ;package
+ (default shepherd-for-home)) ;package
(auto-start? home-shepherd-configuration-auto-start?
(default #t))
(daemonize? home-shepherd-configuration-daemonize?
--
2.46.0
^ permalink raw reply related [flat|nested] 12+ messages in thread
end of thread, other threads:[~2024-12-16 21:34 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-10-20 10:12 bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Dariqq
2024-11-06 13:52 ` bug#73903: (no subject) Jakob Honal via Bug reports for GNU Guix
2024-11-10 11:51 ` bug#73903: [shepherd]: Guix Home's shepherd masks shutdown/reboot on foreign distribution Ludovic Courtès
2024-11-10 15:57 ` Dariqq
2024-11-20 10:46 ` Ludovic Courtès
2024-11-21 16:21 ` Dariqq
2024-11-26 15:55 ` Ludovic Courtès
2024-11-26 18:49 ` Dariqq
2024-12-12 10:50 ` Ludovic Courtès
2024-12-16 21:33 ` bug#73903: [PATCH 0/2] Add shepherd-for-home and make it default Dariqq
2024-12-16 21:33 ` bug#73903: [PATCH 1/2] gnu: Add shepherd-for-home Dariqq
2024-12-16 21:33 ` bug#73903: [PATCH 2/2] gnu: home: Use shepherd-for-home as the default shepherd Dariqq
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/guix.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).