# frozen_string_literal: true require 'luks' # Used to interact with dmcrypt class CryptSetup def initialize(devs, options) @boot = devs[:boot] @root = devs[:root] @home = devs[:home] @swap = devs[:swap] ||= nil @options = options @luks = options[:luks_name] @vg = options[:vg_name] @fs = options[:fs] ||= 'ext4' @mountpoint = options[:mountpoint] ||= '/mnt/getch' end def format format_boot format_root format_home end def keys add_boot_key add_root_key add_home_key end def configs config_boot config_root config_home config_swap end def swap_conf config_swap end protected def format_boot luks = Luks::Boot.new(@boot, @options) luks.encrypt luks.open luks.format luks.mount end # if boot and root are on the same device, we encrypt root with a key def format_root if @boot.split(/[0-9]/) == @root.split(/[0-9]/) root_with_key else root_with_pass end end def format_home @home || return home_with_pass end def add_boot_key luks = Luks::Boot.new(@boot, @options) luks.external_key end # Alrealy used key if they have same disk def add_root_key return if @boot.split(/[0-9]/) == @root.split(/[0-9]/) luks = Luks::Root.new(@root, @options) luks.external_key end def add_home_key @home || return luks = Luks::Home.new(@home, @options) luks.external_key end def config_boot return if !@boot || @options[:fs] == 'zfs' Luks::Boot.new(@boot, @options).write_config end def config_root @root || return Luks::Root.new(@root, @options).write_config end def config_home @home || return Luks::Home.new(@home, @options).write_config end def config_swap id = @options[:lvm] ? '' : Getch::Helpers.id(@swap) line = "swap-#{@luks}" line << if @options[:lvm] " /dev/#{@vg}/swap" else " /dev/disk/by-id/#{id}" end line << ' /dev/urandom swap,discard,cipher=aes-xts-plain64:sha256,size=512' NiTo.echo_a "#{@mountpoint}/etc/crypttab", line end private def root_with_key luks = Luks::Root.new(@root, @options) luks.encrypt_with_key luks.open_with_key end def root_with_pass luks = CryptSetup::Root.new(@root, @options) luks.encrypt luks.open end def home_with_pass luks = CryptSetup::Home.new(@home, @options) luks.encrypt luks.open end end