{ config, lib, pkgs, ... }: with lib; let globalCfg = config.services.scion; cfg = config.services.scion.scion-dispatcher; toml = pkgs.formats.toml { }; defaultConfig = { dispatcher = { id = "dispatcher"; socket_file_mode = "0770"; application_socket = "/dev/shm/dispatcher/default.sock"; }; log.console = { level = "info"; }; }; configFile = toml.generate "scion-dispatcher.toml" (recursiveUpdate defaultConfig cfg.settings); in { options.services.scion.scion-dispatcher = { enable = mkEnableOption "the scion-dispatcher service"; settings = mkOption { default = { }; type = toml.type; example = literalExpression '' { dispatcher = { id = "dispatcher"; socket_file_mode = "0770"; application_socket = "/dev/shm/dispatcher/default.sock"; }; log.console = { level = "info"; }; } ''; description = '' scion-dispatcher configuration. Refer to for details on supported values. ''; }; }; config = mkIf cfg.enable { # Needed for group ownership of the dispatcher socket users.groups.scion = {}; # scion programs hardcode path to dispatcher in /run/shm, and is not # configurable at runtime upstream plans to obsolete the dispatcher in # favor of an SCMP daemon, at which point this can be removed. system.activationScripts.scion-dispatcher = '' ln -sf /dev/shm /run/shm ''; systemd.services.scion-dispatcher = { description = "SCION Dispatcher"; after = [ "network-online.target" ]; wants = [ "network-online.target" ]; wantedBy = [ "multi-user.target" ]; serviceConfig = { Type = "simple"; Group = "scion"; DynamicUser = true; BindPaths = [ "/dev/shm:/run/shm" ]; ExecStartPre = "${pkgs.coreutils}/bin/rm -rf /run/shm/dispatcher"; ExecStart = "${globalCfg.package}/bin/scion-dispatcher --config ${configFile}"; Restart = "on-failure"; ${if globalCfg.stateless then "RuntimeDirectory" else "StateDirectory"} = "scion-dispatcher"; }; }; }; }