There is nothing in this commit except for the changes made by nix-shell -p nixfmt-rfc-style --run "nixfmt ." If this has mucked up your open branches then sorry about that. You can probably nixfmt them to match before merging
33 lines
696 B
Nix
33 lines
696 B
Nix
{
|
|
liminix,
|
|
lib,
|
|
svc,
|
|
}:
|
|
{
|
|
partlabel,
|
|
mountpoint,
|
|
options,
|
|
fstype,
|
|
}:
|
|
let
|
|
inherit (liminix.services) oneshot;
|
|
device = "/dev/disk/by-partlabel/${partlabel}";
|
|
name = "mount.${lib.strings.sanitizeDerivationName (lib.escapeURL mountpoint)}";
|
|
options_string = if options == [ ] then "" else "-o ${lib.concatStringsSep "," options}";
|
|
controller = svc.uevent-rule.build {
|
|
serviceName = name;
|
|
symlink = device;
|
|
terms = {
|
|
partname = partlabel;
|
|
devtype = "partition";
|
|
};
|
|
};
|
|
in
|
|
oneshot {
|
|
inherit name;
|
|
timeout-up = 3600;
|
|
up = "mount -t ${fstype} ${options_string} ${device} ${mountpoint}";
|
|
down = "umount ${mountpoint}";
|
|
inherit controller;
|
|
}
|