diff --git a/pkgs/tools/networking/octodns/default.nix b/pkgs/tools/networking/octodns/default.nix index e511070a4b79..d59389f8b273 100644 --- a/pkgs/tools/networking/octodns/default.nix +++ b/pkgs/tools/networking/octodns/default.nix @@ -1,26 +1,28 @@ { lib, - buildPythonPackage, - dnspython, fetchFromGitHub, - fqdn, - idna, - natsort, - pytestCheckHook, - python-dateutil, - python, - pythonOlder, - pyyaml, + python3, runCommand, - setuptools, -}: -buildPythonPackage rec { + # passthru + octodns, +}: +let + # Export `python` with `octodns` as a module for `octodns-providers`. + python = python3.override { + self = python; + packageOverrides = final: prev: { + octodns = final.toPythonModule octodns; + }; + }; + python3Packages = python.pkgs; +in +python3Packages.buildPythonApplication rec { pname = "octodns"; version = "1.10.0"; pyproject = true; - disabled = pythonOlder "3.8"; + disabled = python.pythonOlder "3.8"; src = fetchFromGitHub { owner = "octodns"; @@ -29,11 +31,11 @@ buildPythonPackage rec { hash = "sha256-L3c4lYt/fgMctJFArc1XlR+hvpz10kcBcYYXajnNQr0="; }; - build-system = [ + build-system = with python3Packages; [ setuptools ]; - dependencies = [ + dependencies = with python3Packages; [ dnspython fqdn idna @@ -42,21 +44,30 @@ buildPythonPackage rec { pyyaml ]; - nativeCheckInputs = [ + nativeCheckInputs = with python3Packages; [ pytestCheckHook ]; pythonImportsCheck = [ "octodns" ]; - passthru.withProviders = - ps: - let - pyEnv = python.withPackages ps; - in - runCommand "octodns-with-providers" { } '' - mkdir -p $out/bin - ln -st $out/bin ${pyEnv}/bin/octodns-* - ''; + passthru = { + providers = lib.recurseIntoAttrs ( + lib.packagesFromDirectoryRecursive { + inherit (python3Packages) callPackage; + directory = ./providers; + } + ); + + withProviders = + ps: + let + pyEnv = python.withPackages ps; + in + runCommand "octodns-with-providers" { } '' + mkdir -p $out/bin + ln -st $out/bin ${pyEnv}/bin/octodns-* + ''; + }; meta = with lib; { description = "Tools for managing DNS across multiple providers"; diff --git a/pkgs/tools/networking/octodns/providers/bind/default.nix b/pkgs/tools/networking/octodns/providers/bind/package.nix similarity index 100% rename from pkgs/tools/networking/octodns/providers/bind/default.nix rename to pkgs/tools/networking/octodns/providers/bind/package.nix diff --git a/pkgs/tools/networking/octodns/providers/cloudflare/default.nix b/pkgs/tools/networking/octodns/providers/cloudflare/package.nix similarity index 100% rename from pkgs/tools/networking/octodns/providers/cloudflare/default.nix rename to pkgs/tools/networking/octodns/providers/cloudflare/package.nix diff --git a/pkgs/tools/networking/octodns/providers/ddns/default.nix b/pkgs/tools/networking/octodns/providers/ddns/package.nix similarity index 100% rename from pkgs/tools/networking/octodns/providers/ddns/default.nix rename to pkgs/tools/networking/octodns/providers/ddns/package.nix diff --git a/pkgs/tools/networking/octodns/providers/gandi/default.nix b/pkgs/tools/networking/octodns/providers/gandi/package.nix similarity index 100% rename from pkgs/tools/networking/octodns/providers/gandi/default.nix rename to pkgs/tools/networking/octodns/providers/gandi/package.nix diff --git a/pkgs/tools/networking/octodns/providers/hetzner/default.nix b/pkgs/tools/networking/octodns/providers/hetzner/package.nix similarity index 100% rename from pkgs/tools/networking/octodns/providers/hetzner/default.nix rename to pkgs/tools/networking/octodns/providers/hetzner/package.nix diff --git a/pkgs/tools/networking/octodns/providers/powerdns/default.nix b/pkgs/tools/networking/octodns/providers/powerdns/package.nix similarity index 100% rename from pkgs/tools/networking/octodns/providers/powerdns/default.nix rename to pkgs/tools/networking/octodns/providers/powerdns/package.nix diff --git a/pkgs/tools/networking/octodns/providers/transip/default.nix b/pkgs/tools/networking/octodns/providers/transip/package.nix similarity index 100% rename from pkgs/tools/networking/octodns/providers/transip/default.nix rename to pkgs/tools/networking/octodns/providers/transip/package.nix diff --git a/pkgs/top-level/all-packages.nix b/pkgs/top-level/all-packages.nix index 452dc92b2da6..692491b32888 100644 --- a/pkgs/top-level/all-packages.nix +++ b/pkgs/top-level/all-packages.nix @@ -419,17 +419,9 @@ with pkgs; deviceTree = callPackage ../os-specific/linux/device-tree { }; - octodns = python3Packages.callPackage ../tools/networking/octodns { }; + octodns = callPackage ../tools/networking/octodns { }; - octodns-providers = recurseIntoAttrs { - bind = python3Packages.callPackage ../tools/networking/octodns/providers/bind { }; - gandi = python3Packages.callPackage ../tools/networking/octodns/providers/gandi { }; - hetzner = python3Packages.callPackage ../tools/networking/octodns/providers/hetzner { }; - powerdns = python3Packages.callPackage ../tools/networking/octodns/providers/powerdns { }; - cloudflare = python3Packages.callPackage ../tools/networking/octodns/providers/cloudflare { }; - ddns = python3Packages.callPackage ../tools/networking/octodns/providers/ddns { }; - transip = python3Packages.callPackage ../tools/networking/octodns/providers/transip { }; - }; + octodns-providers = octodns.providers; oletools = with python3.pkgs; toPythonApplication oletools;