2022-05-19 14:39:52 +00:00
|
|
|
{ pkgs, depot, ... }:
|
|
|
|
name: { plugins }: module_tf:
|
|
|
|
|
|
|
|
let
|
|
|
|
|
2022-10-02 21:23:44 +00:00
|
|
|
inherit (pkgs) lib runCommand writeText writeScript;
|
2022-05-19 14:39:52 +00:00
|
|
|
inherit (lib) filterAttrsRecursive;
|
|
|
|
|
|
|
|
allPlugins = (p: plugins p ++ (with p; [
|
|
|
|
external
|
|
|
|
local
|
|
|
|
tls
|
|
|
|
p.null
|
|
|
|
]));
|
|
|
|
|
|
|
|
tf = pkgs.terraform.withPlugins allPlugins;
|
|
|
|
|
|
|
|
cleanTerraform = filterAttrsRecursive (k: _: ! (builtins.elem k [
|
|
|
|
"__readTree"
|
|
|
|
"__readTreeChildren"
|
|
|
|
]));
|
|
|
|
|
|
|
|
plugins_tf = {
|
|
|
|
terraform.required_providers = (builtins.listToAttrs (map
|
|
|
|
(p: {
|
|
|
|
name = lib.last (lib.splitString "/" p.provider-source-address);
|
|
|
|
value = {
|
|
|
|
source = p.provider-source-address;
|
|
|
|
version = p.version;
|
|
|
|
};
|
|
|
|
})
|
|
|
|
(allPlugins pkgs.terraform.plugins)));
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
module_tf' = module_tf // {
|
|
|
|
inherit (depot.users.grfn.terraform) globals;
|
|
|
|
plugins = plugins_tf;
|
|
|
|
};
|
|
|
|
|
2022-10-02 21:23:44 +00:00
|
|
|
module = runCommand "module" { } ''
|
2022-05-19 14:39:52 +00:00
|
|
|
mkdir $out
|
|
|
|
${lib.concatStrings (lib.mapAttrsToList (k: config_tf:
|
|
|
|
(let
|
|
|
|
# TODO: filterAttrsRecursive?
|
|
|
|
configJson = writeText "${k}.tf.json"
|
|
|
|
(builtins.toJSON (cleanTerraform config_tf));
|
|
|
|
in ''
|
|
|
|
${pkgs.jq}/bin/jq . ${configJson} > $out/${lib.escapeShellArg k}.tf.json
|
|
|
|
''))
|
|
|
|
(cleanTerraform module_tf'))}
|
|
|
|
'';
|
|
|
|
|
|
|
|
|
|
|
|
tfcmd = writeScript "${name}-tfcmd" ''
|
|
|
|
set -e
|
|
|
|
dir="''${TF_STATE_ROOT:-$HOME/tfstate}/${name}"
|
|
|
|
cd "$dir"
|
|
|
|
rm -f *.json
|
|
|
|
cp ${module}/*.json .
|
|
|
|
exec ${tf}/bin/terraform "$(basename "$0")"
|
|
|
|
'';
|
|
|
|
|
|
|
|
init = writeScript "${name}-init" ''
|
|
|
|
set -e
|
|
|
|
dir="''${TF_STATE_ROOT:-$HOME/tfstate}/${name}"
|
|
|
|
[ -d "$dir" ] || mkdir -p "$dir"
|
|
|
|
cd "$dir"
|
|
|
|
rm -f *.json
|
|
|
|
cp ${module}/*.json .
|
|
|
|
exec ${tf}/bin/terraform init
|
|
|
|
'';
|
|
|
|
|
|
|
|
# TODO: import (-config)
|
2022-10-02 21:23:44 +00:00
|
|
|
tfcmds = runCommand "${name}-tfcmds" { } ''
|
2022-05-19 14:39:52 +00:00
|
|
|
mkdir -p $out/bin
|
|
|
|
ln -s ${init} $out/bin/init
|
|
|
|
ln -s ${tfcmd} $out/bin/validate
|
|
|
|
ln -s ${tfcmd} $out/bin/plan
|
|
|
|
ln -s ${tfcmd} $out/bin/apply
|
|
|
|
ln -s ${tfcmd} $out/bin/destroy
|
|
|
|
'';
|
|
|
|
|
|
|
|
in
|
|
|
|
{
|
|
|
|
inherit name module;
|
|
|
|
terraform = tf;
|
|
|
|
cmds = tfcmds;
|
|
|
|
|
|
|
|
# run = {
|
|
|
|
# init = depot.nix.nixRunWrapper "init" tfcmds;
|
|
|
|
# validate = depot.nix.nixRunWrapper "validate" tfcmds;
|
|
|
|
# plan = depot.nix.nixRunWrapper "plan" tfcmds;
|
|
|
|
# apply = depot.nix.nixRunWrapper "apply" tfcmds;
|
|
|
|
# destroy = depot.nix.nixRunWrapper "destroy" tfcmds;
|
|
|
|
# };
|
|
|
|
|
2022-10-02 21:23:44 +00:00
|
|
|
test = runCommand "${name}-test" { } ''
|
2022-05-19 14:39:52 +00:00
|
|
|
set -e
|
|
|
|
export TF_STATE_ROOT=$(pwd)
|
|
|
|
${tfcmds}/bin/init
|
|
|
|
${tfcmds}/bin/validate
|
|
|
|
touch $out
|
|
|
|
'';
|
|
|
|
|
|
|
|
meta.targets = [ "module" "test" ];
|
|
|
|
}
|