1# Minica can provide a CA key and cert, plus a key
2# and cert for our fake CA server's Web Front End (WFE).
3{
4 pkgs ? import <nixpkgs> { },
5 minica ? pkgs.minica,
6 runCommandCC ? pkgs.runCommandCC,
7}:
8let
9 conf = import ./snakeoil-certs.nix;
10 domain = conf.domain;
11 domainSanitized = pkgs.lib.replaceStrings [ "*" ] [ "_" ] domain;
12in
13runCommandCC "generate-tests-certs"
14 {
15 buildInputs = [
16 (minica.overrideAttrs (old: {
17 postPatch = ''
18 sed -i 's_NotAfter: time.Now().AddDate(2, 0, 30),_NotAfter: time.Now().AddDate(20, 0, 0),_' main.go
19 '';
20 }))
21 ];
22
23 }
24 ''
25 minica \
26 --ca-key ca.key.pem \
27 --ca-cert ca.cert.pem \
28 --domains "${domain}"
29
30 mkdir -p $out
31 mv ca.*.pem $out/
32 mv ${domainSanitized}/key.pem $out/${domainSanitized}.key.pem
33 mv ${domainSanitized}/cert.pem $out/${domainSanitized}.cert.pem
34 ''