guix-commits
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

01/11: installer: Offer NM, Connman, and DHCP to non-desktop installs.


From: guix-commits
Subject: 01/11: installer: Offer NM, Connman, and DHCP to non-desktop installs.
Date: Sun, 7 Apr 2019 16:24:25 -0400 (EDT)

civodul pushed a commit to branch master
in repository guix.

commit 2e55f37c0c8fdfbc413edff61490161648a78dcc
Author: Ludovic Courtès <address@hidden>
Date:   Sun Apr 7 21:20:10 2019 +0200

    installer: Offer NM, Connman, and DHCP to non-desktop installs.
    
    * gnu/installer/services.scm (%system-services): Add NetworkManager,
    Connman, and the DHCP client.
    * gnu/installer/newt/services.scm (run-networking-cbt-page): Add
    'network-management?' parameter and honor it.
    (run-services-page): Adjust call accordingly.
---
 gnu/installer/newt/services.scm | 22 ++++++++++++++++------
 gnu/installer/services.scm      | 16 +++++++++++++++-
 2 files changed, 31 insertions(+), 7 deletions(-)

diff --git a/gnu/installer/newt/services.scm b/gnu/installer/newt/services.scm
index e1faf48..76db31d 100644
--- a/gnu/installer/newt/services.scm
+++ b/gnu/installer/newt/services.scm
@@ -45,13 +45,20 @@ choose the one to use on the log-in screen.")
       (condition
        (&installer-step-abort))))))
 
-(define (run-networking-cbt-page)
-  "Run a page allowing the user to select networking services."
+(define (run-networking-cbt-page network-management?)
+  "Run a page allowing the user to select networking services.  When
+NETWORK-MANAGEMENT? is true, include network management services like
+NetworkManager."
   (run-checkbox-tree-page
-   #:info-text (G_ "You can now select networking services to run on your
+   #:info-text (G_ "You can now select networking services to run on your \
 system.")
    #:title (G_ "Network service")
-   #:items (filter networking-system-service? %system-services)
+   #:items (filter (let ((types (if network-management?
+                                    '(network-management networking)
+                                    '(networking))))
+                     (lambda (service)
+                       (memq (system-service-type service) types)))
+                   %system-services)
    #:item->text system-service-name
    #:checkbox-tree-height 5
    #:exit-button-callback-procedure
@@ -61,5 +68,8 @@ system.")
        (&installer-step-abort))))))
 
 (define (run-services-page)
-  (append (run-desktop-environments-cbt-page)
-          (run-networking-cbt-page)))
+  (let ((desktop (run-desktop-environments-cbt-page)))
+    ;; When the user did not select any desktop services, and thus didn't get
+    ;; '%desktop-services', offer network management services.
+    (append desktop
+            (run-networking-cbt-page (null? desktop)))))
diff --git a/gnu/installer/services.scm b/gnu/installer/services.scm
index cb1ddc8..b79c2df 100644
--- a/gnu/installer/services.scm
+++ b/gnu/installer/services.scm
@@ -69,7 +69,21 @@
      (system-service
       (name "Tor anonymous network router")
       (type 'networking)
-      (snippet '(service tor-service-type))))))
+      (snippet '(service tor-service-type)))
+
+     ;; Network connectivity management.
+     (system-service
+      (name "NetworkManager network connection manager")
+      (type 'network-management)
+      (snippet '(service network-manager-service-type)))
+     (system-service
+      (name "Connman network connection manager")
+      (type 'network-management)
+      (snippet '(service connman-service-type)))
+     (system-service
+      (name "DHCP client")
+      (type 'network-management)
+      (snippet '(service dhcp-client-service))))))
 
 (define (desktop-system-service? service)
   "Return true if SERVICE is a desktop environment service."



reply via email to

[Prev in Thread] Current Thread [Next in Thread]