2020-04-24 23:36:52 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
cfg = config.security.pki;
|
|
|
|
|
|
|
|
cacertPackage = pkgs.cacert.override {
|
|
|
|
blacklist = cfg.caCertificateBlacklist;
|
2021-12-06 16:07:01 +00:00
|
|
|
extraCertificateFiles = cfg.certificateFiles;
|
|
|
|
extraCertificateStrings = cfg.certificates;
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
2024-02-29 20:09:43 +00:00
|
|
|
caBundleName = if cfg.useCompatibleBundle then "ca-no-trust-rules-bundle.crt" else "ca-bundle.crt";
|
|
|
|
caBundle = "${cacertPackage}/etc/ssl/certs/${caBundleName}";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
options = {
|
2024-04-21 15:54:59 +00:00
|
|
|
security.pki.installCACerts = mkEnableOption "installing CA certificates to the system" // {
|
2023-07-15 17:15:38 +00:00
|
|
|
default = true;
|
|
|
|
internal = true;
|
|
|
|
};
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2024-02-29 20:09:43 +00:00
|
|
|
security.pki.useCompatibleBundle = mkEnableOption ''usage of a compatibility bundle.
|
|
|
|
|
2024-07-01 15:47:52 +00:00
|
|
|
Such a bundle consists exclusively of `BEGIN CERTIFICATE` and no `BEGIN TRUSTED CERTIFICATE`,
|
|
|
|
which is an OpenSSL specific PEM format.
|
2024-02-29 20:09:43 +00:00
|
|
|
|
|
|
|
It is known to be incompatible with certain software stacks.
|
|
|
|
|
|
|
|
Nevertheless, enabling this will strip all additional trust rules provided by the
|
2024-07-01 15:47:52 +00:00
|
|
|
certificates themselves. This can have security consequences depending on your usecases
|
2024-02-29 20:09:43 +00:00
|
|
|
'';
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
security.pki.certificateFiles = mkOption {
|
|
|
|
type = types.listOf types.path;
|
|
|
|
default = [];
|
2021-10-06 13:57:05 +00:00
|
|
|
example = literalExpression ''[ "''${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt" ]'';
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
A list of files containing trusted root certificates in PEM
|
|
|
|
format. These are concatenated to form
|
2022-08-12 12:06:08 +00:00
|
|
|
{file}`/etc/ssl/certs/ca-certificates.crt`, which is
|
2020-04-24 23:36:52 +00:00
|
|
|
used by many programs that use OpenSSL, such as
|
2022-08-12 12:06:08 +00:00
|
|
|
{command}`curl` and {command}`git`.
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
security.pki.certificates = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [];
|
2021-10-06 13:57:05 +00:00
|
|
|
example = literalExpression ''
|
2020-04-24 23:36:52 +00:00
|
|
|
[ '''
|
|
|
|
NixOS.org
|
|
|
|
=========
|
|
|
|
-----BEGIN CERTIFICATE-----
|
|
|
|
MIIGUDCCBTigAwIBAgIDD8KWMA0GCSqGSIb3DQEBBQUAMIGMMQswCQYDVQQGEwJJ
|
|
|
|
TDEWMBQGA1UEChMNU3RhcnRDb20gTHRkLjErMCkGA1UECxMiU2VjdXJlIERpZ2l0
|
|
|
|
...
|
|
|
|
-----END CERTIFICATE-----
|
|
|
|
'''
|
|
|
|
]
|
|
|
|
'';
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
A list of trusted root certificates in PEM format.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
security.pki.caCertificateBlacklist = mkOption {
|
|
|
|
type = types.listOf types.str;
|
|
|
|
default = [];
|
|
|
|
example = [
|
|
|
|
"WoSign" "WoSign China"
|
|
|
|
"CA WoSign ECC Root"
|
|
|
|
"Certification Authority of WoSign G2"
|
|
|
|
];
|
2024-04-21 15:54:59 +00:00
|
|
|
description = ''
|
2020-04-24 23:36:52 +00:00
|
|
|
A list of blacklisted CA certificate names that won't be imported from
|
|
|
|
the Mozilla Trust Store into
|
2022-08-12 12:06:08 +00:00
|
|
|
{file}`/etc/ssl/certs/ca-certificates.crt`. Use the
|
2020-04-24 23:36:52 +00:00
|
|
|
names from that file.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2023-07-15 17:15:38 +00:00
|
|
|
config = mkIf cfg.installCACerts {
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# NixOS canonical location + Debian/Ubuntu/Arch/Gentoo compatibility.
|
2021-12-06 16:07:01 +00:00
|
|
|
environment.etc."ssl/certs/ca-certificates.crt".source = caBundle;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# Old NixOS compatibility.
|
2021-12-06 16:07:01 +00:00
|
|
|
environment.etc."ssl/certs/ca-bundle.crt".source = caBundle;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# CentOS/Fedora compatibility.
|
2021-12-06 16:07:01 +00:00
|
|
|
environment.etc."pki/tls/certs/ca-bundle.crt".source = caBundle;
|
|
|
|
|
|
|
|
# P11-Kit trust source.
|
|
|
|
environment.etc."ssl/trust-source".source = "${cacertPackage.p11kit}/etc/ssl/trust-source";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|