diff options
| author | tv <tv@krebsco.de> | 2018-07-13 13:52:22 +0200 |
|---|---|---|
| committer | tv <tv@krebsco.de> | 2018-07-13 13:53:46 +0200 |
| commit | c47d8972ad29f80472e9778e6db76838dd8c0cd3 (patch) | |
| tree | 327a572ad696b75b8fa161f7d358baba15db6591 /disko.nix | |
| parent | db6151ff06777deb05b345f1775c037d8671687d (diff) | |
move disko.nix to example/ and add usage
Diffstat (limited to 'disko.nix')
| -rw-r--r-- | disko.nix | 52 |
1 files changed, 0 insertions, 52 deletions
diff --git a/disko.nix b/disko.nix deleted file mode 100644 index 2e6805a..0000000 --- a/disko.nix +++ /dev/null @@ -1,52 +0,0 @@ -with import <nixpkgs/lib>; -with builtins; - -let - - fun.filesystem = q: x: '' - mkfs.${x.format} ${q.device} - ''; - - fun.lvm = q: x: '' - pvcreate ${q.device} - vgcreate ${x.name} ${q.device} - ${concatStringsSep "\n" (mapAttrsToList (name: f (q // { inherit name; vgname = x.name; device = null; /* ??? */ })) x.lvs)} - ''; - - fun.luks = q: x: '' - cryptsetup -q luksFormat ${q.device} ${x.keyfile} - cryptsetup luksOpen ${q.device} ${x.name} --key-file ${x.keyfile} - - ${f (q // { device = "/dev/mapper/${x.name}"; }) x.content} - ''; - - fun.partition = q: x: - "(part ${toString (map (f q) (children x))})"; - - fun.table = q: x: '' - parted -s -a optimal ${q.device} mklabel ${x.format} - ${concatStrings (imap (i: part: " \nparted -s -a optimal ${q.device} mkpart ${part.part-type} ${part.fs-type or ""} ${part.start} ${part.end} ${optionalString (part.bootable or false) "\nparted -s -a optimal ${q.device} set ${toString i} boot on "}") x.partitions)} - - ${concatStrings (imap (i: x: f (q // { device = q.device + toString i; }) x.content) x.partitions)} - ''; - - fun.lv = q: x: '' - lvcreate -L ${x.size} -n ${q.name} ${q.vgname} - - ${f (q // { device = "/dev/${q.vgname}/${q.name}"; }) x.content} - ''; - - children = x: { - lvm = attrValues x.lvs; - luks = [x.content]; - partition = [x.content]; - table = x.partitions; - lv = [x.content]; - }.${x.type}; - - f = q: x: fun.${x.type} q x; - - q0.device = "/dev/sda"; - x0 = import ./example.nix; -in - f q0 x0 |
