[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
11/13: doc: Give an example showing how to add an account in the childhu
From: |
guix-commits |
Subject: |
11/13: doc: Give an example showing how to add an account in the childhurd. |
Date: |
Sun, 1 Oct 2023 17:02:33 -0400 (EDT) |
civodul pushed a commit to branch master
in repository guix.
commit 990d20d4a8685b61d7975a8b24d2e9722194d33f
Author: Ludovic Courtès <ludo@gnu.org>
AuthorDate: Fri Sep 22 14:39:57 2023 +0200
doc: Give an example showing how to add an account in the childhurd.
* doc/guix.texi (Virtualization Services): Give an example showing how
to add an account.
---
doc/guix.texi | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 51 insertions(+)
diff --git a/doc/guix.texi b/doc/guix.texi
index 04d2ad0a69..e03840aa16 100644
--- a/doc/guix.texi
+++ b/doc/guix.texi
@@ -35731,6 +35731,57 @@ initialize ``secrets'' inside the VM: SSH host keys,
authorized
substitute keys, and so on---see the explanation of @code{secret-root}
below.
+You will probably find it useful to create an account for you in the
+GNU/Hurd virtual machine and to authorize logins with your SSH key. To
+do that, you can define the GNU/Hurd system in the usual way
+(@pxref{Using the Configuration System}), and then pass that operating
+system as the @code{os} field of @code{hurd-vm-configuration}, as in
+this example:
+
+@lisp
+(define childhurd-os
+ ;; Definition of my GNU/Hurd system, derived from the default one.
+ (operating-system
+ (inherit %hurd-vm-operating-system)
+
+ ;; Add a user account.
+ (users (cons (user-account
+ (name "charlie")
+ (comment "This is me!")
+ (group "users")
+ (supplementary-groups '("wheel"))) ;for 'sudo'
+ %base-user-accounts))
+
+ (services
+ ;; Modify the SSH configuration to allow login as "root"
+ ;; and as "charlie" using public key authentication.
+ (modify-services (operating-system-user-services
+ %hurd-vm-operating-system)
+ (openssh-service-type
+ config => (openssh-configuration
+ (inherit config)
+ (authorized-keys
+ `(("root"
+ ,(local-file
+ "/home/charlie/.ssh/id_rsa.pub"))
+ ("charlie"
+ ,(local-file
+ "/home/charlie/.ssh/id_rsa.pub"))))))))))
+
+(operating-system
+ ;; @dots{}
+ (services
+ ;; Add the 'hurd-vm' service, configured to use the
+ ;; operating system configuration above.
+ (append (list (service hurd-vm-service-type
+ (hurd-vm-configuration
+ (os %childhurd-os))))
+ %base-services)))
+@end lisp
+
+That's it! The remainder of this section provides the reference of the
+service configuration.
+
@defvar hurd-vm-service-type
This is the type of the Hurd in a Virtual Machine service. Its value
must be a @code{hurd-vm-configuration} object, which specifies the
- branch master updated (dfaeaae9c7 -> b9fae146d6), guix-commits, 2023/10/01
- 09/13: tests: hurd-vm: Remove custom disk image configuration., guix-commits, 2023/10/01
- 05/13: services: guix: Use the right locale package on GNU/Hurd., guix-commits, 2023/10/01
- 01/13: system: vm: Remove unused variable., guix-commits, 2023/10/01
- 07/13: services: childhurd: Authorize the childhurd’s key on the host., guix-commits, 2023/10/01
- 10/13: services: hurd-vm: Disable password-based authentication for root., guix-commits, 2023/10/01
- 11/13: doc: Give an example showing how to add an account in the childhurd.,
guix-commits <=
- 02/13: secret-service: Increase default handshake timeout., guix-commits, 2023/10/01
- 08/13: services: hurd-vm: ‘image’ field has to be an <image> record., guix-commits, 2023/10/01
- 04/13: gnu: glibc-utf8-locales: Reintroduce input labels., guix-commits, 2023/10/01
- 06/13: services: guix: Support declarative offloading setup., guix-commits, 2023/10/01
- 03/13: services: hurd-vm: Use the default SSH port number., guix-commits, 2023/10/01
- 12/13: services: hurd-vm: Implement zero-configuration offloading., guix-commits, 2023/10/01
- 13/13: news: Add entry for declarative offloading., guix-commits, 2023/10/01