{ description = "A highly structured configuration database."; nixConfig.extra-experimental-features = "nix-command flakes ca-references"; inputs = { nixos.url = "nixpkgs/release-21.05"; latest.url = "nixpkgs/nixos-unstable"; digga.url = "github:divnix/digga"; digga.inputs.nixpkgs.follows = "nixos"; digga.inputs.nixlib.follows = "nixos"; digga.inputs.home-manager.follows = "home"; bud.url = "github:divnix/bud"; bud.inputs.nixpkgs.follows = "nixos"; bud.inputs.devshell.follows = "digga/devshell"; home.url = "github:nix-community/home-manager/release-21.05"; home.inputs.nixpkgs.follows = "nixos"; darwin.url = "github:LnL7/nix-darwin"; darwin.inputs.nixpkgs.follows = "latest"; deploy.follows = "digga/deploy"; agenix.url = "github:ryantm/agenix"; agenix.inputs.nixpkgs.follows = "latest"; nvfetcher.url = "github:berberman/nvfetcher"; nvfetcher.inputs.nixpkgs.follows = "latest"; nvfetcher.inputs.flake-compat.follows = "digga/deploy/flake-compat"; nvfetcher.inputs.flake-utils.follows = "digga/flake-utils-plus/flake-utils"; naersk.url = "github:nmattia/naersk"; naersk.inputs.nixpkgs.follows = "latest"; nixos-hardware.url = "github:nixos/nixos-hardware"; # start ANTI CORRUPTION LAYER # remove after https://github.com/NixOS/nix/pull/4641 nixpkgs.follows = "nixos"; nixlib.follows = "digga/nixlib"; blank.follows = "digga/blank"; flake-utils-plus.follows = "digga/flake-utils-plus"; flake-utils.follows = "digga/flake-utils"; # end ANTI CORRUPTION LAYER fenix.url = "github:nix-community/fenix"; }; outputs = { self , digga , bud , nixos , home , nixos-hardware , agenix , fenix , nvfetcher , deploy , ... } @ inputs: digga.lib.mkFlake { inherit self inputs; channelsConfig = { allowUnfree = true; }; channels = { nixos = { imports = [ (digga.lib.importOverlays ./overlays) ]; overlays = [ digga.overlays.patchedNix agenix.overlay nvfetcher.overlay deploy.overlay ./pkgs/default.nix fenix.overlay ]; }; latest = { }; }; lib = import ./lib { lib = digga.lib // nixos.lib; }; sharedOverlays = [ (final: prev: { __dontExport = true; lib = prev.lib.extend (lfinal: lprev: { our = self.lib; }); }) ]; nixos = { hostDefaults = { system = "x86_64-linux"; channelName = "nixos"; imports = [ (digga.lib.importModules ./modules) ]; externalModules = [ { lib.our = self.lib; } digga.nixosModules.bootstrapIso digga.nixosModules.nixConfig home.nixosModules.home-manager agenix.nixosModules.age bud.nixosModules.bud ]; }; imports = [ (digga.lib.importHosts ./hosts) ]; hosts = { /* set host specific properties here */ NixOS = { }; }; importables = rec { profiles = digga.lib.rakeLeaves ./profiles // { users = digga.lib.rakeLeaves ./users; }; suites = (import ./suites) { inherit profiles; }; }; }; home = { imports = [ (digga.lib.importModules ./users/modules) ]; externalModules = [ ]; importables = rec { profiles = digga.lib.rakeLeaves ./users/profiles; suites = with profiles; rec { base = [ direnv git ]; }; }; users = { nixos = { suites, ... }: { imports = suites.base; }; }; # digga.lib.importers.rakeLeaves ./users/hm; }; devshell = ./shell; homeConfigurations = digga.lib.mkHomeConfigurations self.nixosConfigurations; deploy.nodes = digga.lib.mkDeployNodes self.nixosConfigurations { }; defaultTemplate = self.templates.bud; templates.bud.path = ./.; templates.bud.description = "bud template"; } // { budModules = { devos = import ./bud; }; } ; }