nixpkgs/nixos/modules/services/misc/osrm.nix
2024-08-30 23:00:55 +02:00

84 lines
2.0 KiB
Nix

{ config, lib, pkgs, ... }:
let
cfg = config.services.osrm;
in
{
options.services.osrm = {
enable = lib.mkOption {
type = lib.types.bool;
default = false;
description = "Enable the OSRM service.";
};
address = lib.mkOption {
type = lib.types.str;
default = "0.0.0.0";
description = "IP address on which the web server will listen.";
};
port = lib.mkOption {
type = lib.types.port;
default = 5000;
description = "Port on which the web server will run.";
};
threads = lib.mkOption {
type = lib.types.int;
default = 4;
description = "Number of threads to use.";
};
algorithm = lib.mkOption {
type = lib.types.enum [ "CH" "CoreCH" "MLD" ];
default = "MLD";
description = "Algorithm to use for the data. Must be one of CH, CoreCH, MLD";
};
extraFlags = lib.mkOption {
type = lib.types.listOf lib.types.str;
default = [];
example = [ "--max-table-size 1000" "--max-matching-size 1000" ];
description = "Extra command line arguments passed to osrm-routed";
};
dataFile = lib.mkOption {
type = lib.types.path;
example = "/var/lib/osrm/berlin-latest.osrm";
description = "Data file location";
};
};
config = lib.mkIf cfg.enable {
users.users.osrm = {
group = config.users.users.osrm.name;
description = "OSRM user";
createHome = false;
isSystemUser = true;
};
users.groups.osrm = { };
systemd.services.osrm = {
description = "OSRM service";
after = [ "network.target" ];
wantedBy = [ "multi-user.target" ];
serviceConfig = {
User = config.users.users.osrm.name;
ExecStart = ''
${pkgs.osrm-backend}/bin/osrm-routed \
--ip ${cfg.address} \
--port ${toString cfg.port} \
--threads ${toString cfg.threads} \
--algorithm ${cfg.algorithm} \
${toString cfg.extraFlags} \
${cfg.dataFile}
'';
};
};
};
}