nixpkgs/nixos/modules/services/networking/fireqos.nix

50 lines
1.3 KiB
Nix
Raw Normal View History

2017-09-08 22:29:46 +00:00
{ config, lib, pkgs, ... }:
let
cfg = config.services.fireqos;
fireqosConfig = pkgs.writeText "fireqos.conf" "${cfg.config}";
in {
options.services.fireqos = {
enable = lib.mkOption {
type = lib.types.bool;
2017-09-08 22:29:46 +00:00
default = false;
description = ''
2017-09-08 22:29:46 +00:00
If enabled, FireQOS will be launched with the specified
configuration given in `config`.
'';
};
config = lib.mkOption {
type = lib.types.str;
2017-09-08 22:29:46 +00:00
default = "";
example = ''
interface wlp3s0 world-in input rate 10mbit ethernet
class web commit 50kbit
match tcp ports 80,443
interface wlp3s0 world-out input rate 10mbit ethernet
class web commit 50kbit
match tcp ports 80,443
'';
description = ''
2017-09-08 22:29:46 +00:00
The FireQOS configuration goes here.
'';
};
};
config = lib.mkIf cfg.enable {
2017-09-08 22:29:46 +00:00
systemd.services.fireqos = {
description = "FireQOS";
after = [ "network.target" ];
serviceConfig = {
Type = "oneshot";
RemainAfterExit = true;
ExecStart = "${pkgs.firehol}/bin/fireqos start ${fireqosConfig}";
ExecStop = [
"${pkgs.firehol}/bin/fireqos stop"
"${pkgs.firehol}/bin/fireqos clear_all_qos"
];
};
};
};
}