mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-20 04:31:52 +00:00
Merge pull request #3047 from chrisfarms/freetds
Simple nixos module to enable configuration of freetds
This commit is contained in:
commit
0036f4d792
|
@ -61,6 +61,7 @@
|
|||
./programs/ssmtp.nix
|
||||
./programs/venus.nix
|
||||
./programs/wvdial.nix
|
||||
./programs/freetds.nix
|
||||
./programs/zsh/zsh.nix
|
||||
./rename.nix
|
||||
./security/apparmor.nix
|
||||
|
|
61
nixos/modules/programs/freetds.nix
Normal file
61
nixos/modules/programs/freetds.nix
Normal file
|
@ -0,0 +1,61 @@
|
|||
# Global configuration for freetds environment.
|
||||
|
||||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
|
||||
cfg = config.environment.freetds;
|
||||
|
||||
in
|
||||
{
|
||||
###### interface
|
||||
|
||||
options = {
|
||||
|
||||
environment.freetds = mkOption {
|
||||
type = types.attrsOf types.str;
|
||||
default = {};
|
||||
example = {
|
||||
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 = mkIf (length (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 =
|
||||
(concatStrings (mapAttrsToList (name: value:
|
||||
''
|
||||
[${name}]
|
||||
${value}
|
||||
''
|
||||
) cfg));
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
}
|
Loading…
Reference in a new issue