forked from dan/liminix
Instead of treating the trigger as the "main" service and the triggered service as subsidary, now we treat the triggered service as the service and the trigger as "subsidary". This needs some special handling when we work out which services go in the default bundle, but it works better for declaring dependencies on triggered services because it means the dependency runs after the triggered service comes up, not just when the watcher-for-events starts
38 lines
1.0 KiB
Nix
38 lines
1.0 KiB
Nix
# this is unlikely to be the final form or location of this code, it's
|
|
# an interim module which wraps the uevent-watch command
|
|
|
|
{ lib, pkgs, config, ... }:
|
|
let
|
|
inherit (lib) mkOption types;
|
|
inherit (pkgs) liminix;
|
|
# inherit (pkgs.liminix.services) bundle;
|
|
in {
|
|
options = {
|
|
system.service.uevent-rule = mkOption {
|
|
description = "a service which starts other services based on device state (sysfs)";
|
|
type = liminix.lib.types.serviceDefn;
|
|
};
|
|
};
|
|
config = {
|
|
system.service.uevent-rule = liminix.callService ./rule.nix {
|
|
serviceName = mkOption {
|
|
description = "name of the service to run when the rule matches";
|
|
type = types.str;
|
|
};
|
|
terms = mkOption {
|
|
type = types.attrs;
|
|
example = {
|
|
devtype = "usb_device";
|
|
attrs.idVendor = "8086";
|
|
};
|
|
default = {};
|
|
};
|
|
symlink = mkOption {
|
|
description = "create symlink targeted on devpath";
|
|
type = types.nullOr types.str;
|
|
default = null;
|
|
};
|
|
};
|
|
};
|
|
}
|