]> git.immae.eu Git - perso/Immae/Config/Nix.git/blame - nixops/modules/websites/aten/default.nix
Add certificate creation and handling to websites
[perso/Immae/Config/Nix.git] / nixops / modules / websites / aten / default.nix
CommitLineData
8a964143 1{ lib, pkgs, config, myconfig, ... }:
3013caf1 2let
1bd8b03e 3 aten_dev = pkgs.callPackage ./aten.nix {
8f904d0d 4 inherit (pkgs.webapps) aten;
1bd8b03e
IB
5 config = myconfig.env.websites.aten.integration;
6 };
7 aten_prod = pkgs.callPackage ./aten.nix {
8f904d0d 8 inherit (pkgs.webapps) aten;
1bd8b03e
IB
9 config = myconfig.env.websites.aten.production;
10 };
86f6924f 11
1bd8b03e 12 cfg = config.services.myWebsites.Aten;
3013caf1
IB
13in {
14 options.services.myWebsites.Aten = {
15 production = {
16 enable = lib.mkEnableOption "enable Aten's website in production";
17 };
18 integration = {
19 enable = lib.mkEnableOption "enable Aten's website in integration";
20 };
21 };
22
23 config = lib.mkMerge [
24 (lib.mkIf cfg.production.enable {
1a718805 25 secrets.keys = aten_prod.keys;
9eae2b47 26 services.webstats.sites = [ { name = "aten.pro"; } ];
e4a945cd 27
8eded9ec 28 services.myPhpfpm.preStart.aten_prod = aten_prod.phpFpm.preStart;
a0c845b4 29 services.myPhpfpm.serviceDependencies.aten_prod = aten_prod.phpFpm.serviceDeps;
98584540 30 services.myPhpfpm.poolConfigs.aten_prod = aten_prod.phpFpm.pool;
86f6924f 31 system.activationScripts.aten_prod = aten_prod.activationScript;
e5073add
IB
32 system.extraSystemBuilderCmds = ''
33 mkdir -p $out/webapps
1bd8b03e 34 ln -s ${aten_prod.app.webRoot} $out/webapps/${aten_prod.apache.webappName}
e5073add 35 '';
daf64e3f
IB
36 services.websites.production.modules = aten_prod.apache.modules;
37 services.websites.production.vhostConfs.aten = {
7df420c2
IB
38 certName = "aten";
39 certMainHost = "aten.pro";
40 hosts = [ "aten.pro" "www.aten.pro" ];
41 root = aten_prod.apache.root;
42 extraConfig = [ aten_prod.apache.vhostConf ];
f8bde3d6 43 };
3013caf1
IB
44 })
45 (lib.mkIf cfg.integration.enable {
1a718805 46 secrets.keys = aten_dev.keys;
8eded9ec 47 services.myPhpfpm.preStart.aten_dev = aten_dev.phpFpm.preStart;
a0c845b4 48 services.myPhpfpm.serviceDependencies.aten_dev = aten_dev.phpFpm.serviceDeps;
98584540 49 services.myPhpfpm.poolConfigs.aten_dev = aten_dev.phpFpm.pool;
86f6924f 50 system.activationScripts.aten_dev = aten_dev.activationScript;
e5073add
IB
51 system.extraSystemBuilderCmds = ''
52 mkdir -p $out/webapps
1bd8b03e 53 ln -s ${aten_dev.app.webRoot} $out/webapps/${aten_dev.apache.webappName}
e5073add 54 '';
daf64e3f
IB
55 services.websites.integration.modules = aten_dev.apache.modules;
56 services.websites.integration.vhostConfs.aten = {
f8bde3d6 57 certName = "eldiron";
7df420c2 58 addToCerts = true;
f8bde3d6 59 hosts = [ "dev.aten.pro" ];
e5073add 60 root = aten_dev.apache.root;
f8bde3d6
IB
61 extraConfig = [ aten_dev.apache.vhostConf ];
62 };
3013caf1
IB
63 })
64 ];
65}
66