2018-07-20 21:56:59 +01:00
|
|
|
{ config, lib, ... }:
|
2009-03-06 12:25:33 +00:00
|
|
|
|
2014-04-14 15:26:48 +01:00
|
|
|
with lib;
|
2013-09-04 12:05:09 +01:00
|
|
|
|
|
|
|
# unixODBC drivers (this solution is not perfect.. Because the user has to
|
|
|
|
# ask the admin to add a driver.. but it's simple and works
|
|
|
|
|
2016-04-26 19:18:21 +01:00
|
|
|
let
|
|
|
|
iniDescription = pkg: ''
|
|
|
|
[${pkg.fancyName}]
|
|
|
|
Description = ${pkg.meta.description}
|
|
|
|
Driver = ${pkg}/${pkg.driver}
|
|
|
|
'';
|
|
|
|
|
|
|
|
in {
|
2013-09-04 12:05:09 +01:00
|
|
|
###### interface
|
2009-03-06 12:25:33 +00:00
|
|
|
|
|
|
|
options = {
|
2013-09-04 12:05:09 +01:00
|
|
|
environment.unixODBCDrivers = mkOption {
|
2016-01-17 18:34:55 +00:00
|
|
|
type = types.listOf types.package;
|
2013-09-04 12:05:09 +01:00
|
|
|
default = [];
|
2021-10-03 17:06:03 +01:00
|
|
|
example = literalExpression "with pkgs.unixODBCDrivers; [ sqlite psql ]";
|
2022-07-19 14:05:45 +01:00
|
|
|
description = lib.mdDoc ''
|
2013-09-04 12:05:09 +01:00
|
|
|
Specifies Unix ODBC drivers to be registered in
|
2022-07-19 14:05:45 +01:00
|
|
|
{file}`/etc/odbcinst.ini`. You may also want to
|
|
|
|
add `pkgs.unixODBC` to the system path to get
|
2019-10-09 11:43:12 +01:00
|
|
|
a command line client to connect to ODBC databases.
|
2013-09-04 12:05:09 +01:00
|
|
|
'';
|
2009-03-06 12:25:33 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2013-09-04 12:05:09 +01:00
|
|
|
###### implementation
|
2009-03-06 12:25:33 +00:00
|
|
|
|
2013-09-04 12:05:09 +01:00
|
|
|
config = mkIf (config.environment.unixODBCDrivers != []) {
|
2016-04-26 19:18:21 +01:00
|
|
|
environment.etc."odbcinst.ini".text = concatMapStringsSep "\n" iniDescription config.environment.unixODBCDrivers;
|
2009-03-06 12:25:33 +00:00
|
|
|
};
|
2013-09-04 12:05:09 +01:00
|
|
|
|
2009-03-06 12:25:33 +00:00
|
|
|
}
|