112 lines
4.4 KiB
Nix
112 lines
4.4 KiB
Nix
{ lib
|
|
, stdenv
|
|
, buildGoModule
|
|
, fetchFromGitHub
|
|
, fetchFromGitLab
|
|
, callPackage
|
|
, config
|
|
, writeShellScript
|
|
|
|
, cdrtools # libvirt
|
|
}:
|
|
let
|
|
# Our generic constructor to build new providers.
|
|
#
|
|
# Is designed to combine with the terraform.withPlugins implementation.
|
|
mkProvider = lib.makeOverridable
|
|
({ owner
|
|
, repo
|
|
, rev
|
|
, spdx ? "UNSET"
|
|
, version ? lib.removePrefix "v" rev
|
|
, hash ? throw "use hash instead of sha256" # added 2202/09
|
|
, vendorHash ? throw "use vendorHash instead of vendorSha256" # added 2202/09
|
|
, deleteVendor ? false
|
|
, proxyVendor ? false
|
|
, mkProviderFetcher ? fetchFromGitHub
|
|
, mkProviderGoModule ? buildGoModule
|
|
# "https://registry.terraform.io/providers/vancluever/acme"
|
|
, homepage ? ""
|
|
# "registry.terraform.io/vancluever/acme"
|
|
, provider-source-address ? lib.replaceStrings [ "https://registry" ".io/providers" ] [ "registry" ".io" ] homepage
|
|
, ...
|
|
}@attrs:
|
|
assert lib.stringLength provider-source-address > 0;
|
|
mkProviderGoModule {
|
|
pname = repo;
|
|
inherit vendorHash version deleteVendor proxyVendor;
|
|
subPackages = [ "." ];
|
|
doCheck = false;
|
|
# https://github.com/hashicorp/terraform-provider-scaffolding/blob/a8ac8375a7082befe55b71c8cbb048493dd220c2/.goreleaser.yml
|
|
# goreleaser (used for builds distributed via terraform registry) requires that CGO is disabled
|
|
CGO_ENABLED = 0;
|
|
ldflags = [ "-s" "-w" "-X main.version=${version}" "-X main.commit=${rev}" ];
|
|
src = mkProviderFetcher {
|
|
name = "source-${rev}";
|
|
inherit owner repo rev hash;
|
|
};
|
|
|
|
meta = {
|
|
inherit homepage;
|
|
license = lib.getLicenseFromSpdxId spdx;
|
|
};
|
|
|
|
# Move the provider to libexec
|
|
postInstall = ''
|
|
dir=$out/libexec/terraform-providers/${provider-source-address}/${version}/''${GOOS}_''${GOARCH}
|
|
mkdir -p "$dir"
|
|
mv $out/bin/* "$dir/terraform-provider-$(basename ${provider-source-address})_${version}"
|
|
rmdir $out/bin
|
|
'';
|
|
|
|
# Keep the attributes around for later consumption
|
|
passthru = attrs // {
|
|
inherit provider-source-address;
|
|
updateScript = writeShellScript "update" ''
|
|
provider="$(basename ${provider-source-address})"
|
|
./pkgs/applications/networking/cluster/terraform-providers/update-provider "$provider"
|
|
'';
|
|
};
|
|
});
|
|
|
|
list = lib.importJSON ./providers.json;
|
|
|
|
# These providers are managed with the ./update-all script
|
|
automated-providers = lib.mapAttrs (_: attrs: mkProvider attrs) list;
|
|
|
|
# These are the providers that don't fall in line with the default model
|
|
special-providers =
|
|
{
|
|
# github api seems to be broken, doesn't just fail to recognize the license, it's ignored entirely.
|
|
checkly = automated-providers.checkly.override { spdx = "MIT"; };
|
|
gitlab = automated-providers.gitlab.override { mkProviderFetcher = fetchFromGitLab; owner = "gitlab-org"; };
|
|
# mkisofs needed to create ISOs holding cloud-init data and wrapped to terraform via deecb4c1aab780047d79978c636eeb879dd68630
|
|
libvirt = automated-providers.libvirt.overrideAttrs (_: { propagatedBuildInputs = [ cdrtools ]; });
|
|
};
|
|
|
|
# Put all the providers we not longer support in this list.
|
|
removed-providers =
|
|
let
|
|
archived = name: date: throw "the ${name} terraform provider has been archived by upstream on ${date}";
|
|
license = name: date: throw "the ${name} terraform provider removed from nixpkgs on ${date} because of unclear licensing";
|
|
removed = name: date: throw "the ${name} terraform provider removed from nixpkgs on ${date}";
|
|
in
|
|
lib.optionalAttrs config.allowAliases {
|
|
b2 = removed "b2" "2022/06";
|
|
checkpoint = removed "checkpoint" "2022/11";
|
|
dome9 = removed "dome9" "2022/08";
|
|
ksyun = removed "ksyun" "2023/04";
|
|
logicmonitor = license "logicmonitor" "2022/11";
|
|
ncloud = removed "ncloud" "2022/08";
|
|
nsxt = license "nsxt" "2022/11";
|
|
opc = archived "opc" "2022/05";
|
|
oraclepaas = archived "oraclepaas" "2022/05";
|
|
panos = removed "panos" "2022/05";
|
|
template = archived "template" "2022/05";
|
|
vercel = license "vercel" "2022/11";
|
|
};
|
|
|
|
# excluding aliases, used by terraform-full
|
|
actualProviders = automated-providers // special-providers;
|
|
in
|
|
actualProviders // removed-providers // { inherit actualProviders mkProvider; }
|