65 lines
1.5 KiB
Nix
65 lines
1.5 KiB
Nix
{ pkgs, config, lib, ... }:
|
|
let
|
|
cfg = config.services.local-ai;
|
|
inherit (lib) mkOption types;
|
|
in
|
|
{
|
|
options.services.local-ai = {
|
|
enable = lib.mkEnableOption "local-ai";
|
|
|
|
package = lib.mkPackageOption pkgs "local-ai" { };
|
|
|
|
extraArgs = mkOption {
|
|
type = types.listOf types.str;
|
|
default = [ ];
|
|
};
|
|
|
|
port = mkOption {
|
|
type = types.port;
|
|
default = 8080;
|
|
};
|
|
|
|
threads = mkOption {
|
|
type = types.int;
|
|
default = 1;
|
|
};
|
|
|
|
models = mkOption {
|
|
type = types.either types.package types.str;
|
|
default = "models";
|
|
};
|
|
|
|
parallelRequests = mkOption {
|
|
type = types.int;
|
|
default = 1;
|
|
};
|
|
|
|
logLevel = mkOption {
|
|
type = types.enum [ "error" "warn" "info" "debug" "trace" ];
|
|
default = "warn";
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
systemd.services.local-ai = {
|
|
wantedBy = [ "multi-user.target" ];
|
|
environment.LLAMACPP_PARALLEL = toString cfg.parallelRequests;
|
|
serviceConfig = {
|
|
DynamicUser = true;
|
|
ExecStart = lib.escapeShellArgs ([
|
|
"${cfg.package}/bin/local-ai"
|
|
"--address=:${toString cfg.port}"
|
|
"--threads=${toString cfg.threads}"
|
|
"--localai-config-dir=."
|
|
"--models-path=${cfg.models}"
|
|
"--log-level=${cfg.logLevel}"
|
|
]
|
|
++ lib.optional (cfg.parallelRequests > 1) "--parallel-requests"
|
|
++ cfg.extraArgs);
|
|
RuntimeDirectory = "local-ai";
|
|
WorkingDirectory = "%t/local-ai";
|
|
};
|
|
};
|
|
};
|
|
}
|