From 9b53ee7b11b1bf28483c0c5a73f11a3e73a561cd Mon Sep 17 00:00:00 2001 From: Jairo Llopis Date: Fri, 8 Jul 2022 12:49:58 +0100 Subject: feat: noop partitions Some deployments just need a raw block device because the app works better when handling those. Examples: Ceph, Longhorn, OpenEBS. The new `noop` type supports that. It just does nothing with the partitions created, whenever applied. @moduon MT-904 --- lib/default.nix | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'lib') diff --git a/lib/default.nix b/lib/default.nix index ec8e4bf..7793acf 100644 --- a/lib/default.nix +++ b/lib/default.nix @@ -31,6 +31,8 @@ let { config.lvm = q: x: foldl' recursiveUpdate {} (mapAttrsToList (name: config-f { inherit name; vgname = x.name; }) x.lvs); + config.noop = q: x: {}; + config.partition = q: x: config-f { device = q.device + toString q.index; } x.content; @@ -65,6 +67,8 @@ let { ${concatStrings (mapAttrsToList (name: create-f { inherit name; vgname = x.name; }) x.lvs)} ''; + create.noop = q: x: ""; + create.partition = q: x: '' parted -s ${q.device} mkpart ${x.part-type} ${x.fs-type or ""} ${x.start} ${x.end} ${optionalString (x.bootable or false) '' @@ -119,6 +123,8 @@ let { '';} ); + mount.noop = q: x: {}; + mount.partition = q: x: mount-f { device = q.device + toString q.index; } x.content; -- cgit v1.2.3