Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve INSTALLATION documentation, add swapfile support and some minor fixes #130

Merged
merged 1 commit into from
Apr 18, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
57 changes: 49 additions & 8 deletions INSTALLATION.md
Original file line number Diff line number Diff line change
Expand Up @@ -69,12 +69,12 @@ This is my current disk layout (using `cfdisk`):
Label: gpt, identifier: 4BAEBBEA-64DB-4DE6-A7F2-04E8972BF153

Device Start End Sectors Size Type
>> /dev/nvme0n1p1 2048 487423 485376 237M EFI System
/dev/nvme0n1p1 2048 487423 485376 237M EFI System
/dev/nvme0n1p2 487424 1139156991 1138669568 543G Linux filesystem
/dev/nvme0n1p3 1139156992 1206265855 67108864 32G Linux swap
```

I will use `/dev/nvme0n1p4` and `/dev/nvme0n1p5` respectively for `/` and `swap` partitions.
I will use `/dev/nvme0n1p4` and `/dev/nvme0n1p5` respectively for `/` and `swap` partitions. **The swap partition is optional**, you can use a [Swap file](https://wiki.archlinux.org/title/Swap#Swap_file) if you want the ability to vary its size on-the-fly.
The rest is a Ubuntu 20.04 LTS installation. I'll share the EFI partition too between the two distros.

Export the following variables, that we'll be used by next installation steps:
Expand All @@ -86,15 +86,41 @@ export SWAP_PARTITION=/dev/nvme0n1p3
export LUKS_PARTITION=/dev/mapper/cryptroot
```

> **NOTE**: the `/dev/mapper/cryptroot` is the open decrypted partition. The `cryptsetup open` command described below will create the proper device and it will link it to this path. At the moment of the execution of the export commands the device is not present yet, so the `ls /dev/mapper` command will not show it.

Just to be sure about the partitions, you can always run `lsblk` to see partitions per disk.

> **_VERY IMPORTANT_**: From now on i'll use `/dev/nvme0n1p2` for the root partition and `/dev/nvme0n1p3` for the swap one.
> Adjust them according to your setup.

### Hybernation
### Windows dual boot

If you are going to install Archlinux beside Windows, you should shrink the Windows partition to make space for the new installation. You can do this directly from Windows 11 Disk Management tool and **without the need of disabling the BitLocker encryption**.

As described [here](https://wiki.archlinux.org/title/Unified_Extensible_Firmware_Interface/Secure_Boot), you must disable Secure Boot in the UEFI settings. After this process, you have to recover the Windows BitLocker encryption using the recovery key. The recovery process of the Windows BitLocker encryption has to be re-taken after the installation of Archlinux, booting into Windows using GRUB. If you bootstrap Windows using a Microsoft account, you can find the recovery key in the Microsoft account page [here](https://account.microsoft.com/devices/recoverykey).

Just for reference, the following is the disk layout of a dual boot system:

```bash
Device Start End Sectors Size Type
/dev/nvme0n1p1 2048 534527 532480 260M EFI System
/dev/nvme0n1p2 534528 567295 32768 16M Microsoft reserved
/dev/nvme0n1p3 567296 315140095 314572800 150G Microsoft basic data
/dev/nvme0n1p4 1996312576 2000408575 4096000 2G Windows recovery environment
/dev/nvme0n1p5 315140096 315652095 512000 250M EFI System
/dev/nvme0n1p6 315652096 1996312575 1680660480 801.4G Linux filesystem
```

The `/dev/nvme0n1p5` is is the EFI partition for the Archlinux installation, and the `/dev/nvme0n1p6` is the encrypted partition that hosts the btrfs filesystem and contains all the subvolumes. **In this case, the swap partition is not present, and the swap file is used instead**.

### Hibernation

Suspend to disk (aka hibernate) feature is a process where the contents of RAM are written to the swap partition (or file) before the system is powered off. It saves the machine's state into swap space and completely powers off the machine. When the machine is powered on, the state is restored. Until then, there is zero power consumption. [Here](https://wiki.archlinux.org/title/Power_management/Suspend_and_hibernate#Hibernation) you can find more information about hibernation.

#### Swap partition

System will be configured to use the the partition labeled as `swap` as the swap partition.
You must be sure to add this label to the swap partition, it should be like this:
You must make sure to add this label to the swap partition, it should be like this:

```
❯ sudo gdisk -l /dev/nvme0n1
Expand Down Expand Up @@ -142,6 +168,12 @@ The operation has completed successfully.
/dev/nvme0n1p3: UUID="29ddcc21-8a13-49b5-8dc1-767ff387b15a" TYPE="swap" PARTLABEL="swap" PARTUUID="30b47a33-c1b3-924d-9c1c-0adff8f018fd"
```

#### Swap file

If you decide to use a swap file instead of a swap partition, you have to configure some additional parameters to make hibernation work. You can find the information about configuring the swap file offset [here](https://wiki.archlinux.org/title/Power_management/Suspend_and_hibernate#Acquire_swap_file_offset).

In this provisioner, you can configure `swapfile.enabled` and `swapfile.configure_hibernate` to `true` and all the other parameters according to your needs in the `config/default.yaml` file. The ansible role will take care of creating the swap file and configuring the system to use it.

### ROOT LUKS encryption (optional)

1. Archlinux wiki: https://wiki.archlinux.org/title/Dm-crypt/Encrypting_an_entire_system#LUKS_on_a_partition
Expand All @@ -168,7 +200,7 @@ mkswap ${SWAP_PARTITION}
swapon ${SWAP_PARTITION}
```

### BTRFS Setup with encryption
### BTRFS Setup with encryption (STRONGLY RECOMMENDED)

We are going to create btrfs volumes and subvolumes:

Expand Down Expand Up @@ -204,7 +236,11 @@ mkdir -p /mnt/mnt/allvolumes
mount -o noatime,compress=zstd,subvol=/ ${LUKS_PARTITION} /mnt/mnt/allvolumes
```

### BTRFS Setup without encryption
### BTRFS Setup without encryption (DISCOURAGED)

> **NOTE**: if you have installed the system with encryption, you can skip this step and go to [Install Archlinux using the provisioner](#install-archlinux-using-the-provisioner).

⚠️ **Please avoid this kind of configuration, it's not secure and it's not recommended. Use it only for testing purposes.** ⚠️

We are going to create btrfs volumes and subvolumes:

Expand Down Expand Up @@ -273,7 +309,7 @@ Start by cloning the repo:

```bash
cd /root
git clone https://github.com/paolomainardi/archlinux-ansible-provisioner.git provisioner
git clone https://github.com/sparkfabrik/archlinux-ansible-provisioner.git provisioner
cd provisioner
```

Expand All @@ -286,13 +322,18 @@ You can find [here](./config/docs/configuration.md) the schema documentation.
cp config/default.yaml.tpl config/default.yaml
# --- EDIT THIS FILE ACCORDING TO YOUR NEEDS ---
vim config/default.yaml
# Install the base Arch Linux system using `pacstrap` and configure some basic system settings.
CONFIG=./config/default.yaml make bootstrap
# Install all the packages and configure the system.
CONFIG=./config/default.yaml make system
```

> **_VERY IMPORTANT_**: Ansible will use the default values specified by the roles, you should change it or pass it, at the moment
> the later option is not supported by the Makefile.

### Configure GRUB to the encrypted disk (only for encrypted installations)
### Configure GRUB for the encrypted disk (only for encrypted installations)

The following steps are needed to configure GRUB to be able to boot from an encrypted disk:

1. Run `vim /mnt/etc/mkinitcpio.conf` and, to the `HOOKS` array, add `keyboard` between `autodetect` and `modconf` and add `encrypt` between `block` and `filesystems`
- It should look like this: `HOOKS=(base udev autodetect keyboard modconf block encrypt filesystems keyboard fsck)`
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ init:
bootstrap: init
ansible-playbook playbooks/bootstrap.yml -i localhost, -c local --extra-vars "@$(CONFIG)"

system: bootstrap
system:
mkdir -p /mnt/root/provisioner
cp -aR . /mnt/root/provisioner
arch-chroot /mnt ansible-galaxy collection install -r /root/provisioner/requirements.yml
Expand Down
25 changes: 18 additions & 7 deletions config/default.yaml.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -6,23 +6,34 @@ system:
timezone: Europe/Rome
bluetooth:
controllerMode: dual
grub:
gfxmode: 1920x1080x32
timeshift:
autosnap:
enabled: true
maxSnapshots: 10
swapfile:
enabled: false
btrfs_temporary_mount_point: /mnt/btrfs
btrfs_device: /dev/mapper/cryptroot
btrfs_volume_name: "@swap" # Quote the name if it contains special characters
btrfs_volume_mountpoint: /swap
filename: swapfile
size: 16G
configure_hibernate: false

packages:
obs: false
desktop:
gnome:
extensions:
- appindicatorsupport@rgcjonas.gmail.com
- just-perfection-desktop@just-perfection
- screenshot-window-sizer@gnome-shell-extensions.gcampax.github.com
- user-theme@gnome-shell-extensions.gcampax.github.com
- dash-to-dock@micxgx.gmail.com
- ding@rastersoft.com
- Vitals@CoreCoding.com
- appindicatorsupport@rgcjonas.gmail.com
- just-perfection-desktop@just-perfection
- screenshot-window-sizer@gnome-shell-extensions.gcampax.github.com
- user-theme@gnome-shell-extensions.gcampax.github.com
- dash-to-dock@micxgx.gmail.com
- ding@rastersoft.com
- Vitals@CoreCoding.com
keybindings:
open_terminal_shortcut: "<Super>Return" # "<Primary><Alt>t"
dconf:
Expand Down
54 changes: 53 additions & 1 deletion config/schemas/configuration.schema.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,19 @@ properties:
examples:
- dual
type: string
grub:
$id: "#/properties/system/properties/grub"
additionalProperties: true
type: object
properties:
gfxmode:
$id: "#/properties/system/grub/properties/gfxmode"
default: 1920x1080x32
description: Set the gfxmode of the grub screen.
examples:
- 1920x1080x32
- 1280x720x32
type: string
timeshift:
$id: "#/properties/timeshift"
additionalProperties: true
Expand All @@ -214,7 +227,7 @@ properties:
title: The maxSnaphots schema
type: integer
enabled:
$id: "#/properties/timeshift/autosnap/propertie/enabled"
$id: "#/properties/timeshift/autosnap/properties/enabled"
default: true
description: An explanation about the purpose of this instance.
examples:
Expand All @@ -223,6 +236,45 @@ properties:
type: integer
title: The timeshift schema
type: object
swapfile:
$id: "#/properties/swapfile"
description: Swapfile configurations.
additionalProperties: true
properties:
enabled:
$id: "#/properties/swapfile/properties/enabled"
type: boolean
default: false
title: Enable swapfile
description: Activate the swapfile feature instead of a swap partition.
examples:
- true
path:
$id: "#/properties/swapfile/properties/path"
type: string
default: /swapfile
title: The path of the swapfile
description: The path where the swapfile will be created.
examples:
- /swapfile
- /path/of/the/swapfile
size:
$id: "#/properties/swapfile/properties/size"
type: string
default: 16G
title: The size of the swapfile
description: The size of the swapfile.
examples:
- 2G
- 8G
configure_hibernate:
$id: "#/properties/swapfile/properties/configure_hibernate"
type: boolean
default: false
title: Configure hibernate to use the swapfile
description: Use the swapfile for hibernation.
examples:
- true
sparkfabrik:
$id: "#/properties/sparkfabrik"
default: false
Expand Down
10 changes: 9 additions & 1 deletion playbooks/roles/bootstrap/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -46,10 +46,18 @@
loop:
- { regex: en_US\.UTF-8 UTF-8, line: en_US.UTF-8 UTF-8 }
- { regex: en_US ISO-8859-1, line: en_US ISO-8859-1 }
- { regex: it_IT\.UTF-8 UTF-8, line: it_IT.UTF-8 UTF-8 }
- { regex: it_IT ISO-8859-1, line: it_IT ISO-8859-1 }

- name: Create locale.conf
vars:
locale_contet: |
LANG=en_US.UTF-8
LC_TIME=it_IT.UTF-8
LC_PAPER=it_IT.UTF-8
LC_MEASUREMENT=it_IT.UTF-8
copy:
content: "LANG=en_US.UTF-8"
content: "{{ locale_contet }}"
dest: /mnt/etc/locale.conf

- name: Generate locales
Expand Down
24 changes: 0 additions & 24 deletions playbooks/roles/gnome/files/toggle_touchpad.sh

This file was deleted.

24 changes: 24 additions & 0 deletions playbooks/roles/gnome/files/x1_toggle_touchpad.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#!/bin/sh

DEVICES_ID=$(xinput list | grep -iE "syn.*t|Elan TrackPoint" | awk '{print substr($6,4)}')

MATCHED_DEVICES=$(xinput list | grep -iE "syn.*t|Elan TrackPoint")
if [ -n "${MATCHED_DEVICES}" ]; then
for DEVICE_LINE in ${MATCHED_DEVICES}; do
DEVICES_ID=$(echo "${DEVICE_LINE}" | awk '{match($0,"id=([0-9]+)",m)}END{print m[1]}')
if [ -n "${DEVICES_ID}" ]; then
STATUS=-1
for DEVICE_ID in ${DEVICES_ID}; do
if [ ${STATUS} -eq -1 ]; then
STATUS=$(xinput list-props ${DEVICES_ID} | grep "Device Enabled" | awk '{print $4}')
fi

if [ ${STATUS} -eq 0 ]; then
xinput enable ${DEVICES_ID}
elif [ ${STATUS} -eq 1 ]; then
xinput disable ${DEVICES_ID}
fi
done
fi
done
fi
6 changes: 6 additions & 0 deletions playbooks/roles/gnome/files/z16_toggle_touchpad.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/env bash

CUR_STATE=$(gsettings get org.gnome.desktop.peripherals.touchpad send-events)
NEW_STATE=$([ "${CUR_STATE}" = "'enabled'" ] && echo "'disabled'" || echo "'enabled'")

gsettings set org.gnome.desktop.peripherals.touchpad send-events "${NEW_STATE}"
10 changes: 8 additions & 2 deletions playbooks/roles/gnome/tasks/dconf.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,15 @@
- name: Configure gnome
tags: [gnome, gnome-config, dconf]
become: yes
become_user: '{{ system.username }}'
become_user: "{{ system.username }}"
block:
- name: Install gnome Adwaita-dark theme from aur
kewlfft.aur.aur:
use: paru
name:
- adwaita-dark
become: yes
become_user: aur_builder
- name: Use gtk theme 'Yaru-dark'
dconf:
key: "/org/gnome/desktop/interface/gtk-theme"
Expand Down Expand Up @@ -104,4 +111,3 @@
debug:
msg: "Installed extensions: {{ desktop.gnome.extensions }}"
when: debug

Loading