aboutsummaryrefslogtreecommitdiff
path: root/installer
diff options
context:
space:
mode:
authorCraig Jennings <c@cjennings.net>2026-06-23 21:05:17 -0400
committerCraig Jennings <c@cjennings.net>2026-06-23 21:05:17 -0400
commit73e66b703258270a3d688a51dd90ed2f24401568 (patch)
tree17a8e146a1525912ae3761e5f269043eaa43874a /installer
parentedb5016809f3bc657283d8c2402970dbbab3c5cf (diff)
downloadarchangel-73e66b703258270a3d688a51dd90ed2f24401568.tar.gz
archangel-73e66b703258270a3d688a51dd90ed2f24401568.zip
refactor(installer): extract parse_btrfs_subvol_opts helper
mount_btrfs_subvolumes and generate_btrfs_fstab each carried an identical block that composed a subvolume's mount options from BTRFS_OPTS plus the per-subvol extra flags. The two could drift out of sync. Extracted the logic into parse_btrfs_subvol_opts (pure string transform), preserving the exact behavior, and called it from both. Added bats cases covering the default, compress=no, nodatacow, nosuid, and combined paths.
Diffstat (limited to 'installer')
-rw-r--r--installer/lib/btrfs.sh69
1 files changed, 34 insertions, 35 deletions
diff --git a/installer/lib/btrfs.sh b/installer/lib/btrfs.sh
index 0a34be0..67c96a0 100644
--- a/installer/lib/btrfs.sh
+++ b/installer/lib/btrfs.sh
@@ -340,6 +340,36 @@ create_btrfs_subvolumes() {
# Btrfs Mount Functions
#############################
+# Compose the mount-option string for a single subvolume: the shared
+# BTRFS_OPTS prefixed with subvol=<name>, then the per-subvol extra
+# flags applied. compress=no and nodatacow both drop the default
+# compress=zstd; nodatacow also appends nodatacow; nosuid appends
+# nosuid,nodev. Pure string transform — no I/O. Shared by
+# mount_btrfs_subvolumes and generate_btrfs_fstab so the two stay in sync.
+# Usage: parse_btrfs_subvol_opts NAME EXTRA
+parse_btrfs_subvol_opts() {
+ local name="$1" extra="$2"
+ local opts="subvol=$name,$BTRFS_OPTS"
+
+ if [[ -n "$extra" ]]; then
+ # compress=no: drop the default compression, don't add anything
+ if [[ "$extra" == *"compress=no"* ]]; then
+ opts=$(echo "$opts" | sed 's/,compress=zstd//')
+ fi
+ # nodatacow implies no compression (incompatible), so drop it too
+ if [[ "$extra" == *"nodatacow"* ]]; then
+ opts="$opts,nodatacow"
+ opts=$(echo "$opts" | sed 's/,compress=zstd//')
+ fi
+ # nosuid,nodev hardening for tmp subvolumes
+ if [[ "$extra" == *"nosuid"* ]]; then
+ opts="$opts,nosuid,nodev"
+ fi
+ fi
+
+ echo "$opts"
+}
+
mount_btrfs_subvolumes() {
local partition="$1"
@@ -356,25 +386,8 @@ mount_btrfs_subvolumes() {
# Skip root, already mounted
[[ "$name" == "@" ]] && continue
- # Build mount options
- local opts="subvol=$name,$BTRFS_OPTS"
-
- # Apply extra options (override defaults where specified)
- if [[ -n "$extra" ]]; then
- # Handle compress=no by removing compress from opts and not adding it
- if [[ "$extra" == *"compress=no"* ]]; then
- opts=$(echo "$opts" | sed 's/,compress=zstd//')
- fi
- # Handle nodatacow
- if [[ "$extra" == *"nodatacow"* ]]; then
- opts="$opts,nodatacow"
- opts=$(echo "$opts" | sed 's/,compress=zstd//')
- fi
- # Handle nosuid,nodev for tmp
- if [[ "$extra" == *"nosuid"* ]]; then
- opts="$opts,nosuid,nodev"
- fi
- fi
+ local opts
+ opts=$(parse_btrfs_subvol_opts "$name" "$extra")
info "Mounting $name -> $MNTPOINT$mountpoint"
mkdir -p "$MNTPOINT$mountpoint"
@@ -412,22 +425,8 @@ EOF
for subvol_spec in "${BTRFS_SUBVOLS[@]}"; do
IFS=':' read -r name mountpoint extra <<< "$subvol_spec"
- # Build mount options
- local opts="subvol=$name,$BTRFS_OPTS"
-
- # Apply extra options
- if [[ -n "$extra" ]]; then
- if [[ "$extra" == *"compress=no"* ]]; then
- opts=$(echo "$opts" | sed 's/,compress=zstd//')
- fi
- if [[ "$extra" == *"nodatacow"* ]]; then
- opts="$opts,nodatacow"
- opts=$(echo "$opts" | sed 's/,compress=zstd//')
- fi
- if [[ "$extra" == *"nosuid"* ]]; then
- opts="$opts,nosuid,nodev"
- fi
- fi
+ local opts
+ opts=$(parse_btrfs_subvol_opts "$name" "$extra")
echo "UUID=$uuid $mountpoint btrfs $opts 0 0" >> $MNTPOINT/etc/fstab
done