{ description = "I do not have to explain myself"; inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable"; nixos-hardware.url = "github:NixOS/nixos-hardware"; nur.url = "github:nix-community/NUR"; lix = { url = "https://git.lix.systems/lix-project/lix/archive/main.tar.gz"; flake = false; }; lix-module = { url = "https://git.lix.systems/lix-project/nixos-module/archive/main.tar.gz"; inputs.nixpkgs.follows = "nixpkgs"; inputs.lix.follows = "lix"; }; lanzaboote = { url = "github:nix-community/lanzaboote"; inputs.nixpkgs.follows = "nixpkgs"; inputs.rust-overlay.follows = "rust-overlay"; }; colmena = { url = "github:zhaofengli/colmena"; inputs.nixpkgs.follows = "nixpkgs"; }; home-manager = { url = "github:nix-community/home-manager"; inputs.nixpkgs.follows = "nixpkgs"; }; catppuccin.url = "github:catppuccin/nix"; catppuccin-palette = { url = "github:catppuccin/palette"; flake = false; }; linux-hardened.url = "git+https://woof.rip/mikael/linux-hardened.git"; nix-index-database = { url = "github:illdefined/nix-index-database"; inputs.nixpkgs.follows = "nixpkgs"; }; rust-overlay = { url = "github:oxalica/rust-overlay"; inputs.nixpkgs.follows = "nixpkgs"; }; niri = { url = "github:sodiboo/niri-flake"; inputs.nixpkgs.follows = "nixpkgs"; }; ripgrep-all = { url = "github:phiresky/ripgrep-all"; inputs.nixpkgs.follows = "nixpkgs"; inputs.rust-overlay.follows = "rust-overlay"; }; }; nixConfig = { allow-import-form-derivation = true; extra-experimental-features = [ "pipe-operator" ]; extra-substituters = [ "https://colmena.cachix.org" "https://nix-community.cachix.org" "https://cache.kyouma.net" ]; extra-trusted-public-keys = [ "colmena.cachix.org-1:7BzpDnjjH8ki2CT3f6GdOk7QAzPOl+1t3LvTLXqYcSg=" "nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs=" "cache.kyouma.net:Frjwu4q1rnwE/MnSTmX9yx86GNA/z3p/oElGvucLiZg=" ]; }; outputs = { self, nixpkgs, ... }@inputs: let inherit (nixpkgs) lib; load = base: default: builtins.readDir base |> lib.filterAttrs (name: type: builtins.match "(regular|directory)" type != null) |> lib.mapAttrs' (name: type: { name = if type == "regular" then lib.removeSuffix ".nix" name else name; value = let path = if type == "directory" then "${name}/${default}.nix" else name; in import "${base}/${path}" inputs; }); eachSystem = fun: lib.mapAttrs fun self.lib.platforms; in { lib = load ./lib "lib" // { inherit load; }; overlays = load ./overlay "overlay"; legacyPackages = eachSystem (system: platform: let pkgs = import nixpkgs { localSystem = builtins.currentSystem or system; crossSystem = platform; overlays = [ self.overlays.default ]; config = { allowBroken = true; allowUnsupportedSystem = true; }; }; in pkgs // { config = pkgs.config // { replaceStdenv = { pkgs }: self.lib.stdenv pkgs pkgs.stdenv; /*replaceCrossStdenv = { buildPackages, baseStdenv }: self.lib.stdenv self.legacyPackages.${system} baseStdenv;*/ }; }); packages = eachSystem (system: platform: let pkgs = self.legacyPackages.${system}; in load ./package "package" |> lib.mapAttrs (name: pkg: self.legacyPackages.${system}.callPackage pkg { }) |> lib.filterAttrs (name: pkg: lib.meta.availableOn platform pkg)); nixosModules = load ./nixos/module "module"; colmena = load ./nixos/config "configuration" // { meta = { nixpkgs = self.legacyPackages.x86_64-linux; }; defaults = { name, config, ... }: { deployment = { allowLocalDeployment = true; targetHost = config.networking.fqdnOrHostName; targetUser = null; }; nixpkgs = let platform = self.lib.platforms.x86_64-linux; in { buildPlatform = builtins.currentSystem or platform.system; hostPlatform = platform; }; }; }; nixosConfigurations = let hive = inputs.colmena.lib.makeHive self.outputs.colmena; in hive.nodes; homeModules = load ./home/module "module"; homeConfigurations = load ./home/config "home"; devShells = eachSystem (system: platform: load ./shell "shell" |> lib.mapAttrs (name: shell: self.legacyPackages.${system}.callPackage shell { }) |> lib.filterAttrs (name: shell: lib.meta.availableOn platform shell)); hydraJobs = { package = self.packages |> lib.foldlAttrs (jobs: system: packages: lib.recursiveUpdate jobs (lib.mapAttrs (name: package: { ${system} = package; }) packages)) { }; shell = self.devShells |> lib.foldlAttrs (jobs: system: shells: lib.recursiveUpdate jobs (lib.mapAttrs (name: shell: { ${system} = shell; }) shells)) { }; nixos = self.nixosConfigurations |> lib.mapAttrs (name: host: { ${host.pkgs.system} = host.config.system.build.toplevel; }); }; }; }