Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
66 lines
1.4 KiB
Nix
66 lines
1.4 KiB
Nix
# Global configuration for freetds environment.
|
|
|
|
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}:
|
|
|
|
let
|
|
|
|
cfg = config.environment.freetds;
|
|
|
|
in
|
|
{
|
|
###### interface
|
|
|
|
options = {
|
|
|
|
environment.freetds = lib.mkOption {
|
|
type = lib.types.attrsOf lib.types.str;
|
|
default = { };
|
|
example = lib.literalExpression ''
|
|
{ MYDATABASE = '''
|
|
host = 10.0.2.100
|
|
port = 1433
|
|
tds version = 7.2
|
|
''';
|
|
}
|
|
'';
|
|
description = ''
|
|
Configure freetds database entries. Each attribute denotes
|
|
a section within freetds.conf, and the value (a string) is the config
|
|
content for that section. When at least one entry is configured
|
|
the global environment variables FREETDSCONF, FREETDS and SYBASE
|
|
will be configured to allow the programs that use freetds to find the
|
|
library and config.
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
###### implementation
|
|
|
|
config = lib.mkIf (builtins.length (builtins.attrNames cfg) > 0) {
|
|
|
|
environment.variables.FREETDSCONF = "/etc/freetds.conf";
|
|
environment.variables.FREETDS = "/etc/freetds.conf";
|
|
environment.variables.SYBASE = "${pkgs.freetds}";
|
|
|
|
environment.etc."freetds.conf" = {
|
|
text = (
|
|
lib.concatStrings (
|
|
lib.mapAttrsToList (name: value: ''
|
|
[${name}]
|
|
${value}
|
|
'') cfg
|
|
)
|
|
);
|
|
};
|
|
|
|
};
|
|
|
|
}
|