From 5b7b17dda01b38557d3967a12beebbcbc847939b Mon Sep 17 00:00:00 2001 From: DavHau Date: Tue, 4 Apr 2023 13:01:49 +0200 Subject: [PATCH] init: invokeai-dream2nix Testing the grounds for the upcoming dream2nix v1. Advantages: - get rid of ./packages - reduced amount of overlays/overriding - potentially simplifies upgrading invokeai (less dependency hell) - comes with some cool dream2nix features like `nix build .#invokeai-d2n.docs` Shortcomings: - no amd/nvidia support yet. - dream2nix is unstable - the fetchPip fetcher is slow and ends up downloading more stuff than it needs to (not be a problem once cached) - interface for maintainers is different from nixpkgs --- flake.lock | 308 ++++++++++++++++++++++- flake.nix | 7 +- projects/invokeai/default.nix | 16 +- projects/invokeai/lock-x86_64-linux.json | 3 + projects/invokeai/package-d2n.nix | 136 ++++++++++ 5 files changed, 459 insertions(+), 11 deletions(-) create mode 100644 projects/invokeai/lock-x86_64-linux.json create mode 100644 projects/invokeai/package-d2n.nix diff --git a/flake.lock b/flake.lock index 299f98e2..9ab690f9 100644 --- a/flake.lock +++ b/flake.lock @@ -1,6 +1,158 @@ { "nodes": { + "all-cabal-json": { + "flake": false, + "locked": { + "lastModified": 1665552503, + "narHash": "sha256-r14RmRSwzv5c+bWKUDaze6pXM7nOsiz1H8nvFHJvufc=", + "owner": "nix-community", + "repo": "all-cabal-json", + "rev": "d7c0434eebffb305071404edcf9d5cd99703878e", + "type": "github" + }, + "original": { + "owner": "nix-community", + "ref": "hackage", + "repo": "all-cabal-json", + "type": "github" + } + }, + "crane": { + "flake": false, + "locked": { + "lastModified": 1670900067, + "narHash": "sha256-VXVa+KBfukhmWizaiGiHRVX/fuk66P8dgSFfkVN4/MY=", + "owner": "ipetkov", + "repo": "crane", + "rev": "59b31b41a589c0a65e4a1f86b0e5eac68081468b", + "type": "github" + }, + "original": { + "owner": "ipetkov", + "repo": "crane", + "type": "github" + } + }, + "devshell": { + "flake": false, + "locked": { + "lastModified": 1663445644, + "narHash": "sha256-+xVlcK60x7VY1vRJbNUEAHi17ZuoQxAIH4S4iUFUGBA=", + "owner": "numtide", + "repo": "devshell", + "rev": "e3dc3e21594fe07bdb24bdf1c8657acaa4cb8f66", + "type": "github" + }, + "original": { + "owner": "numtide", + "repo": "devshell", + "type": "github" + } + }, + "dream2nix": { + "inputs": { + "all-cabal-json": "all-cabal-json", + "crane": "crane", + "devshell": "devshell", + "drv-parts": "drv-parts", + "flake-compat": "flake-compat", + "flake-parts": "flake-parts", + "flake-utils-pre-commit": "flake-utils-pre-commit", + "ghc-utils": "ghc-utils", + "gomod2nix": "gomod2nix", + "mach-nix": "mach-nix", + "nix-pypi-fetcher": "nix-pypi-fetcher", + "nixpkgs": [ + "nixpkgs" + ], + "nixpkgsV1": [ + "nixpkgs" + ], + "poetry2nix": "poetry2nix", + "pre-commit-hooks": "pre-commit-hooks", + "pruned-racket-catalog": "pruned-racket-catalog" + }, + "locked": { + "lastModified": 1680605243, + "narHash": "sha256-dUrxj653kcLvjNKRI7NoTJoj+Q7G+vOYsl4iuwtnIWo=", + "owner": "nix-community", + "repo": "dream2nix", + "rev": "34a80ab215f1f24068ea9c76f3a7e5bc19478653", + "type": "github" + }, + "original": { + "owner": "nix-community", + "repo": "dream2nix", + "type": "github" + } + }, + "drv-parts": { + "inputs": { + "flake-compat": [ + "dream2nix", + "flake-compat" + ], + "flake-parts": [ + "dream2nix", + "flake-parts" + ], + "nixpkgs": [ + "dream2nix", + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1680172861, + "narHash": "sha256-QMyI338xRxaHFDlCXdLCtgelGQX2PdlagZALky4ZXJ8=", + "owner": "davhau", + "repo": "drv-parts", + "rev": "ced8a52f62b0a94244713df2225c05c85b416110", + "type": "github" + }, + "original": { + "owner": "davhau", + "repo": "drv-parts", + "type": "github" + } + }, + "flake-compat": { + "flake": false, + "locked": { + "lastModified": 1673956053, + "narHash": "sha256-4gtG9iQuiKITOjNQQeQIpoIB6b16fm+504Ch3sNKLd8=", + "owner": "edolstra", + "repo": "flake-compat", + "rev": "35bb57c0c8d8b62bbfd284272c928ceb64ddbde9", + "type": "github" + }, + "original": { + "owner": "edolstra", + "repo": "flake-compat", + "type": "github" + } + }, "flake-parts": { + "inputs": { + "nixpkgs-lib": [ + "dream2nix", + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1675933616, + "narHash": "sha256-/rczJkJHtx16IFxMmAWu5nNYcSXNg1YYXTHoGjLrLUA=", + "owner": "hercules-ci", + "repo": "flake-parts", + "rev": "47478a4a003e745402acf63be7f9a092d51b83d7", + "type": "github" + }, + "original": { + "owner": "hercules-ci", + "repo": "flake-parts", + "type": "github" + } + }, + "flake-parts_2": { "inputs": { "nixpkgs-lib": [ "nixpkgs" @@ -20,7 +172,7 @@ "type": "github" } }, - "flake-parts_2": { + "flake-parts_3": { "inputs": { "nixpkgs-lib": "nixpkgs-lib" }, @@ -37,7 +189,7 @@ "type": "indirect" } }, - "flake-parts_3": { + "flake-parts_4": { "inputs": { "nixpkgs-lib": [ "hercules-ci-effects", @@ -74,9 +226,56 @@ "type": "github" } }, + "flake-utils-pre-commit": { + "locked": { + "lastModified": 1644229661, + "narHash": "sha256-1YdnJAsNy69bpcjuoKdOYQX0YxZBiCYZo4Twxerqv7k=", + "owner": "numtide", + "repo": "flake-utils", + "rev": "3cecb5b042f7f209c56ffd8371b2711a290ec797", + "type": "github" + }, + "original": { + "owner": "numtide", + "repo": "flake-utils", + "type": "github" + } + }, + "ghc-utils": { + "flake": false, + "locked": { + "lastModified": 1662774800, + "narHash": "sha256-1Rd2eohGUw/s1tfvkepeYpg8kCEXiIot0RijapUjAkE=", + "ref": "refs/heads/master", + "rev": "bb3a2d3dc52ff0253fb9c2812bd7aa2da03e0fea", + "revCount": 1072, + "type": "git", + "url": "https://gitlab.haskell.org/bgamari/ghc-utils" + }, + "original": { + "type": "git", + "url": "https://gitlab.haskell.org/bgamari/ghc-utils" + } + }, + "gomod2nix": { + "flake": false, + "locked": { + "lastModified": 1627572165, + "narHash": "sha256-MFpwnkvQpauj799b4QTBJQFEddbD02+Ln5k92QyHOSk=", + "owner": "tweag", + "repo": "gomod2nix", + "rev": "67f22dd738d092c6ba88e420350ada0ed4992ae8", + "type": "github" + }, + "original": { + "owner": "tweag", + "repo": "gomod2nix", + "type": "github" + } + }, "hercules-ci-agent": { "inputs": { - "flake-parts": "flake-parts_3", + "flake-parts": "flake-parts_4", "nix-darwin": "nix-darwin", "nixpkgs": "nixpkgs", "pre-commit-hooks-nix": "pre-commit-hooks-nix" @@ -96,7 +295,7 @@ }, "hercules-ci-effects": { "inputs": { - "flake-parts": "flake-parts_2", + "flake-parts": "flake-parts_3", "hercules-ci-agent": "hercules-ci-agent", "nixpkgs": [ "nixpkgs" @@ -119,16 +318,16 @@ "invokeai-src": { "flake": false, "locked": { - "lastModified": 1677475057, - "narHash": "sha256-REtyVcyRgspn1yYvB4vIHdOrPRZRNSSraepHik9MfgE=", + "lastModified": 1680358663, + "narHash": "sha256-4wz2GFVWgz3V0GjR5qPN0s2h5kjZHZs+k/JCTfEMAPw=", "owner": "invoke-ai", "repo": "InvokeAI", - "rev": "650f4bb58ceca458bff1410f35cd6d6caad399c6", + "rev": "fd74f5138437a43bea5b9bb186c84b6b0fd05d39", "type": "github" }, "original": { "owner": "invoke-ai", - "ref": "v2.3.1.post2", + "ref": "v2.3.3", "repo": "InvokeAI", "type": "github" } @@ -150,6 +349,21 @@ "type": "github" } }, + "mach-nix": { + "flake": false, + "locked": { + "lastModified": 1634711045, + "narHash": "sha256-m5A2Ty88NChLyFhXucECj6+AuiMZPHXNbw+9Kcs7F6Y=", + "owner": "DavHau", + "repo": "mach-nix", + "rev": "4433f74a97b94b596fa6cd9b9c0402104aceef5d", + "type": "github" + }, + "original": { + "id": "mach-nix", + "type": "indirect" + } + }, "nix-darwin": { "inputs": { "nixpkgs": [ @@ -172,6 +386,22 @@ "type": "github" } }, + "nix-pypi-fetcher": { + "flake": false, + "locked": { + "lastModified": 1669065297, + "narHash": "sha256-UStjXjNIuIm7SzMOWvuYWIHBkPUKQ8Id63BMJjnIDoA=", + "owner": "DavHau", + "repo": "nix-pypi-fetcher", + "rev": "a9885ac6a091576b5195d547ac743d45a2a615ac", + "type": "github" + }, + "original": { + "owner": "DavHau", + "repo": "nix-pypi-fetcher", + "type": "github" + } + }, "nixpkgs": { "locked": { "lastModified": 1672262501, @@ -222,6 +452,48 @@ "type": "github" } }, + "poetry2nix": { + "flake": false, + "locked": { + "lastModified": 1666918719, + "narHash": "sha256-BkK42fjAku+2WgCOv2/1NrPa754eQPV7gPBmoKQBWlc=", + "owner": "nix-community", + "repo": "poetry2nix", + "rev": "289efb187123656a116b915206e66852f038720e", + "type": "github" + }, + "original": { + "owner": "nix-community", + "ref": "1.36.0", + "repo": "poetry2nix", + "type": "github" + } + }, + "pre-commit-hooks": { + "inputs": { + "flake-utils": [ + "dream2nix", + "flake-utils-pre-commit" + ], + "nixpkgs": [ + "dream2nix", + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1646153636, + "narHash": "sha256-AlWHMzK+xJ1mG267FdT8dCq/HvLCA6jwmx2ZUy5O8tY=", + "owner": "cachix", + "repo": "pre-commit-hooks.nix", + "rev": "b6bc0b21e1617e2b07d8205e7fae7224036dfa4b", + "type": "github" + }, + "original": { + "owner": "cachix", + "repo": "pre-commit-hooks.nix", + "type": "github" + } + }, "pre-commit-hooks-nix": { "inputs": { "flake-utils": "flake-utils", @@ -245,9 +517,27 @@ "type": "github" } }, + "pruned-racket-catalog": { + "flake": false, + "locked": { + "lastModified": 1672537287, + "narHash": "sha256-SuOvXVcLfakw18oJB/PuRMyvGyGG1+CQD3R+TGHIv44=", + "owner": "nix-community", + "repo": "pruned-racket-catalog", + "rev": "c8b89557fb53b36efa2ee48a769c7364df0f6262", + "type": "github" + }, + "original": { + "owner": "nix-community", + "ref": "catalog", + "repo": "pruned-racket-catalog", + "type": "github" + } + }, "root": { "inputs": { - "flake-parts": "flake-parts", + "dream2nix": "dream2nix", + "flake-parts": "flake-parts_2", "hercules-ci-effects": "hercules-ci-effects", "invokeai-src": "invokeai-src", "koboldai-src": "koboldai-src", diff --git a/flake.nix b/flake.nix index 58a8d014..9b47abc9 100644 --- a/flake.nix +++ b/flake.nix @@ -11,7 +11,7 @@ url = "github:NixOS/nixpkgs/nixos-unstable"; }; invokeai-src = { - url = "github:invoke-ai/InvokeAI/v2.3.1.post2"; + url = "github:invoke-ai/InvokeAI/v2.3.3"; flake = false; }; koboldai-src = { @@ -26,6 +26,11 @@ url = "github:hercules-ci/hercules-ci-effects"; inputs.nixpkgs.follows = "nixpkgs"; }; + dream2nix = { + url = "github:nix-community/dream2nix"; + inputs.nixpkgs.follows = "nixpkgs"; + }; + dream2nix.inputs.nixpkgsV1.follows = "nixpkgs"; }; outputs = { flake-parts, invokeai-src, hercules-ci-effects, ... }@inputs: flake-parts.lib.mkFlake { inherit inputs; } { diff --git a/projects/invokeai/default.nix b/projects/invokeai/default.nix index cce85984..c9d5e001 100644 --- a/projects/invokeai/default.nix +++ b/projects/invokeai/default.nix @@ -1,4 +1,4 @@ -{ config, inputs, lib, withSystem, ... }: +{ config, inputs, lib, withSystem, self,... }: { perSystem = { config, pkgs, ... }: let @@ -7,6 +7,12 @@ src = inputs.invokeai-src; mkInvokeAIVariant = args: pkgs.callPackage ./package.nix ({ inherit src; } // args); + + dream2nix-setup-module = {config, lib, ...}: { + lock.repoRoot = self; + lock.lockFileRel = "/projects/invokeai/lock-${config.deps.stdenv.system}.json"; + }; + in { packages = { invokeai-amd = mkInvokeAIVariant { @@ -15,6 +21,14 @@ invokeai-nvidia = mkInvokeAIVariant { aipython3 = aipython3-nvidia; }; + invokeai-d2n = inputs.dream2nix.lib.evalModules { + modules = [ + dream2nix-setup-module + ./package-d2n.nix + ]; + packageSets.nixpkgs = inputs.nixpkgs.legacyPackages.x86_64-linux; + specialArgs.inputs = {inherit (inputs) invokeai-src;}; + }; }; }; diff --git a/projects/invokeai/lock-x86_64-linux.json b/projects/invokeai/lock-x86_64-linux.json new file mode 100644 index 00000000..9f1219b4 --- /dev/null +++ b/projects/invokeai/lock-x86_64-linux.json @@ -0,0 +1,3 @@ +{ + "fetchPipHash": "sha256-7o6yCdBAmlOM9+0K3nRyNOUIK/FrPIJHsNSTvIKDWaY=" +} diff --git a/projects/invokeai/package-d2n.nix b/projects/invokeai/package-d2n.nix new file mode 100644 index 00000000..ae6190c9 --- /dev/null +++ b/projects/invokeai/package-d2n.nix @@ -0,0 +1,136 @@ +{ + config, + lib, + dream2nix, + inputs, + ... +}: let + pyproject = lib.pipe (config.mkDerivation.src + /pyproject.toml) [ + builtins.readFile + builtins.fromTOML + ]; + +in { + imports = [ + dream2nix.modules.drv-parts.mach-nix-xs + ]; + + name = "invokeai"; + version = "0.0.0"; + + deps = {nixpkgs, ...}: { + inherit (nixpkgs) + breakpointHook + fetchurl + gcc-unwrapped + glib + xorg + zlib + ; + }; + + buildPythonPackage = { + format = "pyproject"; + }; + + mkDerivation = { + src = inputs.invokeai-src; + buildInputs = [ + config.deps.python.pkgs.setuptools + ]; + patchPhase = '' + runHook prePatch + + # Add subprocess to the imports + substituteInPlace ./ldm/invoke/config/invokeai_configure.py --replace \ + 'import shutil' \ + ' + import shutil + import subprocess + ' + # shutil.copytree will inherit the permissions of files in the /nix/store + # which are read only, so we subprocess.call cp instead and tell it not to + # preserve the mode + substituteInPlace ./ldm/invoke/config/invokeai_configure.py --replace \ + "shutil.copytree(configs_src, configs_dest, dirs_exist_ok=True)" \ + "subprocess.call('cp -r --no-preserve=mode {configs_src} {configs_dest}'.format(configs_src=configs_src, configs_dest=configs_dest), shell=True)" + runHook postPatch + ''; + postFixup = '' + chmod +x $out/bin/* + wrapPythonPrograms + ''; + }; + + env = { + autoPatchelfIgnoreMissingDeps = [ + "libcuda.so.1" + "libtbb.so.12" + ]; + makeWrapperArgs = [ + '' --run ' + if [ -d "/usr/lib/wsl/lib" ] + then + echo "Running via WSL (Windows Subsystem for Linux), setting LD_LIBRARY_PATH=/usr/lib/wsl/lib" + set -x + export LD_LIBRARY_PATH="/usr/lib/wsl/lib" + set +x + fi + ' + '' + ]; + }; + + mach-nix.pythonSources.fetch-pip = { + pypiSnapshotDate = "2023-04-02"; + # remove last (windows only) requirement due to dream2nix splitting issue + requirementsList = lib.init pyproject.project.dependencies; + }; + + mach-nix.manualSetupDeps = { + basicsr = [ + "lmdb" + "yapf" + "tb-nightly" + "tqdm" + "scikit-image" + "scipy" + "opencv-python" + ]; + }; + + mach-nix.drvs = { + antlr4-python3-runtime.nixpkgs-overrides.enable = false; + test-tube = { + mkDerivation.doCheck = false; + mkDerivation.doInstallCheck = false; + }; + + urwid = { + mkDerivation.doCheck = lib.mkForce false; + }; + + filterpy = { + mkDerivation.doCheck = false; + }; + + basicsr = { + mkDerivation = { + nativeBuildInputs = [ + config.deps.python.pkgs.cython + config.deps.python.pkgs.numpy + config.deps.python.pkgs.torch + config.deps.breakpointHook + ]; + dontStrip = true; + doCheck = false; + }; + buildPythonPackage = { + pipInstallFlags = [ + "--ignore-installed" + ]; + catchConflicts = false; + }; + }; + }; +}