blob: d8fd67e930d17ac9f4c93ec7b9afab58567bf67f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
;;; Consfigurator -- Lisp declarative configuration management system
;;; Copyright (C) 2021 Sean Whitton <spwhitton@spwhitton.name>
;;; This file 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, or (at your option)
;;; any later version.
;;; This file 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 this program. If not, see <http://www.gnu.org/licenses/>.
(in-package :consfigurator.property.grub)
(named-readtables:in-readtable :consfigurator)
(defmethod install-bootloader-propspec
((type (eql 'grub)) volume &rest args &key &allow-other-keys)
`(grub-installed ,volume ,@args))
(defmethod install-bootloader-binaries-propspec
((type (eql 'grub)) volume &key (target "i386-pc") &allow-other-keys)
`(os:etypecase
(debianlike
(apt:installed
"initramfs-tools"
,(eswitch (target :test #'string=)
("i386-pc" "grub-pc")
("x86_64-efi" "grub-efi-amd64")
("arm64-efi" "grub-efi-arm64"))))))
(defprop grub-installed :posix
(volume &key (target "i386-pc") force-extra-removable)
"Use grub-install(8) to install grub to VOLUME."
(:desc "GRUB installed")
(:apply
(let ((running-on-target (container:contained-p :efi-nvram)))
(assert-remote-euid-root)
(mrun :inform "update-initramfs" "-u")
(let ((os-prober (and (not running-on-target)
(remote-exists-p "/etc/grub.d/30_os-prober"))))
;; work around Debian bug #802717
(when os-prober (file:has-mode "/etc/grub.d/30_os-prober" #o644))
(mrun :inform "update-grub")
(when os-prober (file:has-mode "/etc/grub.d/30_os-prober" #o755)))
(mrun :inform "grub-install" (strcat "--target=" target)
(and (string-suffix-p target "-efi") running-on-target
"--no-nvram")
(and force-extra-removable "--force-extra-removable")
(device-file volume)))))
|