Class: CFA::Grub2::Default
- Inherits:
-
BaseModel
- Object
- BaseModel
- CFA::Grub2::Default
- Defined in:
- lib/cfa/grub2/default.rb
Overview
Represents grub configuration in /etc/default/grub Main features:
-
Do not overwrite files
-
When setting value first try to just change value if key already exists
-
When key is not set, then try to find commented out line with key and replace it with real config
-
When even commented out code is not there, then append configuration to the end of file
Defined Under Namespace
Classes: KernelParams
Constant Summary collapse
- PATH =
"/etc/default/grub".freeze
- VALID_TERMINAL_OPTIONS =
[:serial, :console, :gfxterm].freeze
Instance Method Summary collapse
- #cryptodisk ⇒ Object
-
#initialize(file_handler: nil) ⇒ Default
constructor
A new instance of Default.
- #kernel_params ⇒ Object
- #load ⇒ Object
- #os_prober ⇒ Object
- #recovery_entry ⇒ Object
- #recovery_params ⇒ Object
- #save(changes_only: false) ⇒ Object
- #serial_console ⇒ Object
-
#serial_console=(value) ⇒ Object
Sets GRUB_SERIAL_COMMAND option.
-
#terminal ⇒ Array<Symbol>?
Reads value of GRUB_TERMINAL from /etc/default/grub.
-
#terminal=(values) ⇒ Object
Sets GRUB_TERMINAL option.
- #xen_hypervisor_params ⇒ Object
- #xen_kernel_params ⇒ Object
Constructor Details
Instance Method Details
#cryptodisk ⇒ Object
100 101 102 103 |
# File 'lib/cfa/grub2/default.rb', line 100 def cryptodisk @cryptodisk ||= BooleanValue.new("GRUB_ENABLE_CRYPTODISK", self, true_value: "y", false_value: "n") end |
#kernel_params ⇒ Object
65 66 67 68 69 |
# File 'lib/cfa/grub2/default.rb', line 65 def kernel_params @kernel_params ||= KernelParams.new( value_for("GRUB_CMDLINE_LINUX_DEFAULT"), "GRUB_CMDLINE_LINUX_DEFAULT" ) end |
#load ⇒ Object
46 47 48 49 50 51 52 53 54 55 |
# File 'lib/cfa/grub2/default.rb', line 46 def load super kernels = [kernel_params, xen_hypervisor_params, xen_kernel_params, recovery_params] kernels.each do |kernel| param_line = value_for(kernel.key) kernel.replace(param_line) if param_line end end |
#os_prober ⇒ Object
57 58 59 60 61 62 63 |
# File 'lib/cfa/grub2/default.rb', line 57 def os_prober @os_prober ||= BooleanValue.new( "GRUB_DISABLE_OS_PROBER", self, # grub key is disable, so use reverse logic true_value: "false", false_value: "true" ) end |
#recovery_entry ⇒ Object
92 93 94 95 96 97 98 |
# File 'lib/cfa/grub2/default.rb', line 92 def recovery_entry @recovery_entry ||= BooleanValue.new( "GRUB_DISABLE_RECOVERY", self, # grub key is disable, so use reverse logic true_value: "false", false_value: "true" ) end |
#recovery_params ⇒ Object
85 86 87 88 89 90 |
# File 'lib/cfa/grub2/default.rb', line 85 def recovery_params @recovery_params ||= KernelParams.new( value_for("GRUB_CMDLINE_LINUX_RECOVERY"), "GRUB_CMDLINE_LINUX_RECOVERY" ) end |
#save(changes_only: false) ⇒ Object
34 35 36 37 38 39 40 41 42 43 44 |
# File 'lib/cfa/grub2/default.rb', line 34 def save(changes_only: false) # serialize kernel params object before save kernels = [@kernel_params, @xen_hypervisor_params, @xen_kernel_params, @recovery_params] kernels.each do |params| # FIXME: this empty prevent writing explicit empty kernel params. generic_set(params.key, params.serialize) if params && !params.empty? end super end |
#serial_console ⇒ Object
153 154 155 |
# File 'lib/cfa/grub2/default.rb', line 153 def serial_console value_for("GRUB_SERIAL_COMMAND") end |
#serial_console=(value) ⇒ Object
Sets GRUB_SERIAL_COMMAND option
Updates GRUB_SERIAL_COMMAND with given value, also enables serial console in GRUB_TERMINAL
148 149 150 151 |
# File 'lib/cfa/grub2/default.rb', line 148 def serial_console=(value) self.terminal = (terminal || []) | [:serial] generic_set("GRUB_SERIAL_COMMAND", value) end |
#terminal ⇒ Array<Symbol>?
Reads value of GRUB_TERMINAL from /etc/default/grub
GRUB_TERMINAL option allows multiple values as space separated string
113 114 115 116 117 118 119 120 121 122 123 124 |
# File 'lib/cfa/grub2/default.rb', line 113 def terminal values = value_for("GRUB_TERMINAL") return nil if values.nil? || values.empty? values.split.map do |value| msg = "unknown GRUB_TERMINAL option #{value.inspect}" raise msg if !VALID_TERMINAL_OPTIONS.include?(value.to_sym) value.to_sym end end |
#terminal=(values) ⇒ Object
Sets GRUB_TERMINAL option
Raises an ArgumentError exception in case of invalid value
132 133 134 135 136 137 138 139 140 |
# File 'lib/cfa/grub2/default.rb', line 132 def terminal=(values) values = [] if values.nil? msg = "A value is invalid: #{values.inspect}".freeze invalid = values.any? { |v| !VALID_TERMINAL_OPTIONS.include?(v) } raise ArgumentError, msg if invalid generic_set("GRUB_TERMINAL", values.join(" ")) end |
#xen_hypervisor_params ⇒ Object
71 72 73 74 75 76 |
# File 'lib/cfa/grub2/default.rb', line 71 def xen_hypervisor_params @xen_hypervisor_params ||= KernelParams.new( value_for("GRUB_CMDLINE_XEN_DEFAULT"), "GRUB_CMDLINE_XEN_DEFAULT" ) end |
#xen_kernel_params ⇒ Object
78 79 80 81 82 83 |
# File 'lib/cfa/grub2/default.rb', line 78 def xen_kernel_params @xen_kernel_params ||= KernelParams.new( value_for("GRUB_CMDLINE_LINUX_XEN_REPLACE_DEFAULT"), "GRUB_CMDLINE_LINUX_XEN_REPLACE_DEFAULT" ) end |