159e378cbb
GitOrigin-RevId: c04d5652cfa9742b1d519688f65d1bbccea9eb7e
123 lines
3.5 KiB
Nix
123 lines
3.5 KiB
Nix
{ config, lib, pkgs, ... }:
|
|
let
|
|
|
|
cfg = config.services.cntlm;
|
|
|
|
configFile = if cfg.configText != "" then
|
|
pkgs.writeText "cntlm.conf" ''
|
|
${cfg.configText}
|
|
''
|
|
else
|
|
pkgs.writeText "lighttpd.conf" ''
|
|
# Cntlm Authentication Proxy Configuration
|
|
Username ${cfg.username}
|
|
Domain ${cfg.domain}
|
|
Password ${cfg.password}
|
|
${lib.optionalString (cfg.netbios_hostname != "") "Workstation ${cfg.netbios_hostname}"}
|
|
${lib.concatMapStrings (entry: "Proxy ${entry}\n") cfg.proxy}
|
|
${lib.optionalString (cfg.noproxy != []) "NoProxy ${lib.concatStringsSep ", " cfg.noproxy}"}
|
|
|
|
${lib.concatMapStrings (port: ''
|
|
Listen ${toString port}
|
|
'') cfg.port}
|
|
|
|
${cfg.extraConfig}
|
|
'';
|
|
|
|
in
|
|
|
|
{
|
|
|
|
options.services.cntlm = {
|
|
|
|
enable = lib.mkEnableOption "cntlm, which starts a local proxy";
|
|
|
|
username = lib.mkOption {
|
|
type = lib.types.str;
|
|
description = ''
|
|
Proxy account name, without the possibility to include domain name ('at' sign is interpreted literally).
|
|
'';
|
|
};
|
|
|
|
domain = lib.mkOption {
|
|
type = lib.types.str;
|
|
description = "Proxy account domain/workgroup name.";
|
|
};
|
|
|
|
password = lib.mkOption {
|
|
default = "/etc/cntlm.password";
|
|
type = lib.types.str;
|
|
description = "Proxy account password. Note: use chmod 0600 on /etc/cntlm.password for security.";
|
|
};
|
|
|
|
netbios_hostname = lib.mkOption {
|
|
type = lib.types.str;
|
|
default = "";
|
|
description = ''
|
|
The hostname of your machine.
|
|
'';
|
|
};
|
|
|
|
proxy = lib.mkOption {
|
|
type = lib.types.listOf lib.types.str;
|
|
description = ''
|
|
A list of NTLM/NTLMv2 authenticating HTTP proxies.
|
|
|
|
Parent proxy, which requires authentication. The same as proxy on the command-line, can be used more than once to specify unlimited
|
|
number of proxies. Should one proxy fail, cntlm automatically moves on to the next one. The connect request fails only if the whole
|
|
list of proxies is scanned and (for each request) and found to be invalid. Command-line takes precedence over the configuration file.
|
|
'';
|
|
example = [ "proxy.example.com:81" ];
|
|
};
|
|
|
|
noproxy = lib.mkOption {
|
|
description = ''
|
|
A list of domains where the proxy is skipped.
|
|
'';
|
|
default = [];
|
|
type = lib.types.listOf lib.types.str;
|
|
example = [ "*.example.com" "example.com" ];
|
|
};
|
|
|
|
port = lib.mkOption {
|
|
default = [3128];
|
|
type = lib.types.listOf lib.types.port;
|
|
description = "Specifies on which ports the cntlm daemon listens.";
|
|
};
|
|
|
|
extraConfig = lib.mkOption {
|
|
type = lib.types.lines;
|
|
default = "";
|
|
description = "Additional config appended to the end of the generated {file}`cntlm.conf`.";
|
|
};
|
|
|
|
configText = lib.mkOption {
|
|
type = lib.types.lines;
|
|
default = "";
|
|
description = "Verbatim contents of {file}`cntlm.conf`.";
|
|
};
|
|
|
|
};
|
|
|
|
###### implementation
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
systemd.services.cntlm = {
|
|
description = "CNTLM is an NTLM / NTLM Session Response / NTLMv2 authenticating HTTP proxy";
|
|
after = [ "network.target" ];
|
|
wantedBy = [ "multi-user.target" ];
|
|
serviceConfig = {
|
|
User = "cntlm";
|
|
ExecStart = ''
|
|
${pkgs.cntlm}/bin/cntlm -U cntlm -c ${configFile} -v -f
|
|
'';
|
|
};
|
|
};
|
|
|
|
users.users.cntlm = {
|
|
name = "cntlm";
|
|
description = "cntlm system-wide daemon";
|
|
isSystemUser = true;
|
|
};
|
|
};
|
|
}
|