-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdarwin-module.nix
93 lines (87 loc) · 3.19 KB
/
darwin-module.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
{
config,
lib,
pkgs,
...
}:
let
enabledInstances = lib.filterAttrs (name: cfg: cfg.enable) config.services.process-compose-deploy;
in
{
imports = [ ./options.nix ];
config = lib.mkIf (enabledInstances != { }) {
environment.systemPackages = lib.flatten (
lib.attrsets.mapAttrsToList (
name: cfg:
let
run-wrapper =
name: script:
pkgs.writeShellScriptBin name ''
set -euo pipefail
export ${
lib.concatStringsSep " " (
lib.mapAttrsToList (
name: value: "${name}=${lib.escapeShellArg (toString value)}"
) cfg.environment
)
}
export PATH=$PATH:${lib.makeBinPath [ pkgs.bash ]}
cd /var/lib/process-compose/${name}/data
sudo -E -u daemon ${script} "$@"
'';
adminScript = pkgs.writeShellScript "adm-${name}" ''
set -euo pipefail
$PC_PROFILE_PATH/bin/* ${lib.optionalString cfg.useUnixSocket "-U"} \
--log-file "$HOME/client.log" "$@"
'';
updateScript = pkgs.writeShellScript "update-${name}" ''
set -euo pipefail
if [[ "$1" != /nix/store/* ]]; then
echo "not a closure: $1"
exit 1
fi
${lib.getExe' config.nix.package "nix-env"} -p "$PC_PROFILE_PATH" --set "$1"
${lib.getExe' config.nix.package "nix-env"} -p "$PC_PROFILE_PATH" --delete-generations +3
${adminScript} project update "''${@:1}"
'';
in
[
(run-wrapper "process-compose-adm-${name}" adminScript)
(run-wrapper "process-compose-deploy-${name}" updateScript)
]
) enabledInstances
);
launchd.daemons = lib.mapAttrs' (
name: cfg:
lib.nameValuePair "process-compose-${name}" {
environment = lib.mapAttrs (_: toString) cfg.environment;
script = ''
set -euo pipefail
export PATH=$PATH:${lib.makeBinPath [ pkgs.bash ]}
${lib.optionalString (cfg.environmentFile != null) "source ${cfg.environmentFile}"}
mkdir -p /var/lib/process-compose/${name}/data
chown daemon:daemon /var/lib/process-compose/${name} /var/lib/process-compose/${name}/data
if [ -L "$PC_PROFILE_PATH" ] && [ -e "$PC_PROFILE_PATH" ]; then
echo "using $(readlink -f "$PC_PROFILE_PATH")"
else
rm -f "$PC_PROFILE_PATH"
${lib.getExe' config.nix.package "nix-env"} -p "$PC_PROFILE_PATH" --set ${cfg.defaultProfile}
fi
cd /var/lib/process-compose/${name}/data
sudo -E -u daemon $PC_PROFILE_PATH/bin/* ${lib.optionalString cfg.useUnixSocket "-U"} \
--tui=false \
--keep-project \
--ordered-shutdown \
--disable-dotenv \
--log-file "$HOME/server.log"
'';
serviceConfig = {
KeepAlive = true;
RunAtLoad = true;
StandardOutPath = "/var/log/process-compose-${name}.out.log";
StandardErrorPath = "/var/log/process-compose-${name}.err.log";
};
}
) enabledInstances;
};
}