install: Discover local substitute servers.

* gnu/installer/substitutes.scm: New file.
* gnu/installer/newt/substitutes.scm: New file.
* gnu/local.mk (INSTALLER_MODULES): Add them.
* po/guix/POTFILES.in: Add gnu/installer/newt/substitutes.scm.
* gnu/installer/proxy.scm (with-silent-shepherd): Move to ...
* gnu/installer/utils.scm: ... here.
* gnu/installer/record.scm (<installer>)[substitutes-page]: New field.
* gnu/installer/newt.scm (substitutes-page): New procedure,
(newt-installer): register it.
* gnu/installer.scm (installer-steps): Add "substitutes-page" step.
* gnu/system/install.scm (%installation-services): Add avahi-service-type and
enable substitute server discover in guix-service-type.
[<name-service-switch>]: Set it to %mdns-host-lookup-nss.
This commit is contained in:
Mathieu Othacehe 2020-12-04 11:33:16 +01:00
parent 6ca66f6414
commit 8361817bf6
No known key found for this signature in database
GPG key ID: 8354763531769CA6
10 changed files with 119 additions and 6 deletions

View file

@ -266,6 +266,13 @@ (define (installer-steps)
(compute (lambda _ (compute (lambda _
((installer-network-page current-installer))))) ((installer-network-page current-installer)))))
;; Ask whether to enable substitute server discovery.
(installer-step
(id 'substitutes)
(description (G_ "Substitute server discovery"))
(compute (lambda _
((installer-substitutes-page current-installer)))))
;; Prompt for users (name, group and home directory). ;; Prompt for users (name, group and home directory).
(installer-step (installer-step
(id 'user) (id 'user)

View file

@ -30,6 +30,7 @@ (define-module (gnu installer newt)
#:use-module (gnu installer newt page) #:use-module (gnu installer newt page)
#:use-module (gnu installer newt partition) #:use-module (gnu installer newt partition)
#:use-module (gnu installer newt services) #:use-module (gnu installer newt services)
#:use-module (gnu installer newt substitutes)
#:use-module (gnu installer newt timezone) #:use-module (gnu installer newt timezone)
#:use-module (gnu installer newt user) #:use-module (gnu installer newt user)
#:use-module (gnu installer newt utils) #:use-module (gnu installer newt utils)
@ -101,6 +102,9 @@ (define* (keymap-page layouts context)
(define (network-page) (define (network-page)
(run-network-page)) (run-network-page))
(define (substitutes-page)
(run-substitutes-page))
(define (hostname-page) (define (hostname-page)
(run-hostname-page)) (run-hostname-page))
@ -130,6 +134,7 @@ (define newt-installer
(locale-page locale-page) (locale-page locale-page)
(menu-page menu-page) (menu-page menu-page)
(network-page network-page) (network-page network-page)
(substitutes-page substitutes-page)
(timezone-page timezone-page) (timezone-page timezone-page)
(hostname-page hostname-page) (hostname-page hostname-page)
(user-page user-page) (user-page user-page)

View file

@ -0,0 +1,43 @@
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2020 Mathieu Othacehe <othacehe@gnu.org>
;;;
;;; This file is part of GNU Guix.
;;;
;;; GNU Guix is free software; you can redistribute it and/or modify it
;;; under the terms of the GNU General Public License as published by
;;; the Free Software Foundation; either version 3 of the License, or (at
;;; your option) any later version.
;;;
;;; GNU Guix is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;;; GNU General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
(define-module (gnu installer newt substitutes)
#:use-module (gnu installer substitutes)
#:use-module (gnu installer utils)
#:use-module (guix i18n)
#:use-module (newt)
#:use-module (ice-9 match)
#:export (run-substitutes-page))
(define* (run-substitutes-page)
(match (current-clients)
(()
(case (choice-window
(G_ "Substitute server discovery.")
(G_ "Enable") (G_ "Disable")
(G_ " By turning this option on, you allow Guix to fetch \
substitutes (pre-built binaries) during installation from servers \
discovered on your local area network (LAN) in addition to the official \
server. This can increase download throughput.
There are no security risks: only genuine substitutes may be retrieved from \
those servers. However, eavesdroppers on your LAN may be able to see what \
software you are installing."))
((1) (enable-discovery))
((2) (disable-discovery))))
(_ #f)))

View file

@ -17,15 +17,11 @@
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>. ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
(define-module (gnu installer proxy) (define-module (gnu installer proxy)
#:use-module (gnu installer utils)
#:use-module (gnu services herd) #:use-module (gnu services herd)
#:export (set-http-proxy #:export (set-http-proxy
clear-http-proxy)) clear-http-proxy))
(define-syntax-rule (with-silent-shepherd exp ...)
(parameterize ((shepherd-message-port
(%make-void-port "w")))
exp ...))
(define (set-http-proxy proxy) (define (set-http-proxy proxy)
(with-silent-shepherd (with-silent-shepherd
(with-shepherd-action 'guix-daemon (with-shepherd-action 'guix-daemon

View file

@ -33,6 +33,7 @@ (define-module (gnu installer record)
installer-locale-page installer-locale-page
installer-menu-page installer-menu-page
installer-network-page installer-network-page
installer-substitutes-page
installer-timezone-page installer-timezone-page
installer-hostname-page installer-hostname-page
installer-user-page installer-user-page
@ -73,6 +74,8 @@ (define-record-type* <installer>
(menu-page installer-menu-page) (menu-page installer-menu-page)
;; procedure void -> void ;; procedure void -> void
(network-page installer-network-page) (network-page installer-network-page)
;; procedure void -> void
(substitutes-page installer-substitutes-page)
;; procedure (zonetab) -> posix-timezone ;; procedure (zonetab) -> posix-timezone
(timezone-page installer-timezone-page) (timezone-page installer-timezone-page)
;; procedure void -> void ;; procedure void -> void

View file

@ -0,0 +1,41 @@
;;; GNU Guix --- Functional package management for GNU
;;; Copyright © 2020 Mathieu Othacehe <m.othacehe@gmail.com>
;;;
;;; This file is part of GNU Guix.
;;;
;;; GNU Guix is free software; you can redistribute it and/or modify it
;;; under the terms of the GNU General Public License as published by
;;; the Free Software Foundation; either version 3 of the License, or (at
;;; your option) any later version.
;;;
;;; GNU Guix is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;;; GNU General Public License for more details.
;;;
;;; You should have received a copy of the GNU General Public License
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
(define-module (gnu installer substitutes)
#:use-module (gnu installer utils)
#:use-module (gnu services herd)
#:export (enable-discovery
disable-discovery))
(define (enable-discovery)
(with-silent-shepherd
(with-shepherd-action 'guix-daemon
('discover "on")
result
result)))
(define (disable-discovery)
(with-silent-shepherd
(with-shepherd-action 'guix-daemon
('discover "off")
result
result)))
;; Local Variables:
;; eval: (put 'with-silent-shepherd 'scheme-indent-function 0)
;; End:

View file

@ -18,6 +18,7 @@
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>. ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
(define-module (gnu installer utils) (define-module (gnu installer utils)
#:use-module (gnu services herd)
#:use-module (guix utils) #:use-module (guix utils)
#:use-module (guix build utils) #:use-module (guix build utils)
#:use-module (guix i18n) #:use-module (guix i18n)
@ -43,7 +44,9 @@ (define-module (gnu installer utils)
with-server-socket with-server-socket
current-server-socket current-server-socket
current-clients current-clients
send-to-clients)) send-to-clients
with-silent-shepherd))
(define* (read-lines #:optional (port (current-input-port))) (define* (read-lines #:optional (port (current-input-port)))
"Read lines from PORT and return them as a list." "Read lines from PORT and return them as a list."
@ -233,3 +236,9 @@ (define remainder
(current-clients (reverse remainder)) (current-clients (reverse remainder))
exp) exp)
(define-syntax-rule (with-silent-shepherd exp ...)
"Evaluate EXP while discarding shepherd messages."
(parameterize ((shepherd-message-port
(%make-void-port "w")))
exp ...))

View file

@ -717,6 +717,7 @@ INSTALLER_MODULES = \
%D%/installer/record.scm \ %D%/installer/record.scm \
%D%/installer/services.scm \ %D%/installer/services.scm \
%D%/installer/steps.scm \ %D%/installer/steps.scm \
%D%/installer/substitutes.scm \
%D%/installer/tests.scm \ %D%/installer/tests.scm \
%D%/installer/timezone.scm \ %D%/installer/timezone.scm \
%D%/installer/user.scm \ %D%/installer/user.scm \
@ -733,6 +734,7 @@ INSTALLER_MODULES = \
%D%/installer/newt/page.scm \ %D%/installer/newt/page.scm \
%D%/installer/newt/partition.scm \ %D%/installer/newt/partition.scm \
%D%/installer/newt/services.scm \ %D%/installer/newt/services.scm \
%D%/installer/newt/substitutes.scm \
%D%/installer/newt/timezone.scm \ %D%/installer/newt/timezone.scm \
%D%/installer/newt/user.scm \ %D%/installer/newt/user.scm \
%D%/installer/newt/utils.scm \ %D%/installer/newt/utils.scm \

View file

@ -34,6 +34,7 @@ (define-module (gnu system install)
#:use-module ((guix store) #:select (%store-prefix)) #:use-module ((guix store) #:select (%store-prefix))
#:use-module (gnu installer) #:use-module (gnu installer)
#:use-module (gnu system locale) #:use-module (gnu system locale)
#:use-module (gnu services avahi)
#:use-module (gnu services dbus) #:use-module (gnu services dbus)
#:use-module (gnu services networking) #:use-module (gnu services networking)
#:use-module (gnu services shepherd) #:use-module (gnu services shepherd)
@ -335,6 +336,10 @@ (define bare-bones-os
;; The usual services. ;; The usual services.
(syslog-service) (syslog-service)
;; Use the Avahi daemon to discover substitute servers on the local
;; network. It can be faster than fetching from remote servers.
(service avahi-service-type)
;; The build daemon. Register the default substitute server key(s) ;; The build daemon. Register the default substitute server key(s)
;; as trusted to allow the installation process to use substitutes by ;; as trusted to allow the installation process to use substitutes by
;; default. ;; default.
@ -435,6 +440,7 @@ (define installation-os
(host-name "gnu") (host-name "gnu")
(timezone "Europe/Paris") (timezone "Europe/Paris")
(locale "en_US.utf8") (locale "en_US.utf8")
(name-service-switch %mdns-host-lookup-nss)
(bootloader (bootloader-configuration (bootloader (bootloader-configuration
(bootloader grub-bootloader) (bootloader grub-bootloader)
(target "/dev/sda"))) (target "/dev/sda")))

View file

@ -25,6 +25,7 @@ gnu/installer/newt/network.scm
gnu/installer/newt/page.scm gnu/installer/newt/page.scm
gnu/installer/newt/partition.scm gnu/installer/newt/partition.scm
gnu/installer/newt/services.scm gnu/installer/newt/services.scm
gnu/installer/newt/substitutes.scm
gnu/installer/newt/timezone.scm gnu/installer/newt/timezone.scm
gnu/installer/newt/user.scm gnu/installer/newt/user.scm
gnu/installer/newt/utils.scm gnu/installer/newt/utils.scm