summaryrefslogtreecommitdiff
path: root/flake.nix
blob: 446a74f4bc0a329409d020aa753d65698e8eb04a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
{
  inputs = {
    nixpkgs.url = "github:nixos/nixpkgs/nixos-23.11";
    unstable.url = "github:nixos/nixpkgs";

    home-manager = {
      url = "github:nix-community/home-manager/release-23.11";
      inputs.nixpkgs.follows = "nixpkgs";
    };

    nur.url = "github:nix-community/NUR";
    impermanence.url = "github:nix-community/impermanence";
    hm-isolation.url = "/home/ale/hm-isolation";

    nixvirt = {
      url = "/home/ale/NixVirt";
      inputs.nixpkgs.follows = "nixpkgs";
    };
  };

  outputs =
    { self, nixpkgs, unstable, home-manager, nur, impermanence, hm-isolation, nixvirt, ... }:
    let
      system = "x86_64-linux";

      pkgs = pkgsNoLocal.extend self.overlays.default;
      pkgsNoLocal = importPkgs nixpkgs;

      importPkgs = flake: import flake {
        inherit system;

        config = import ./pkgs/config nixpkgs.lib;
        overlays = [ nur.overlay ];
      };

      util = import ./util;
      inherit (util pkgs.lib) importAll;

      local = import ./pkgs;
    in
    with pkgs.lib; {
      formatter.${system} = pkgs.nixpkgs-fmt;
      packages.${system} = local pkgs pkgsNoLocal;

      overlays.default = final: prev:
        let
          locals = local final prev;
        in
        {
          local = locals;
          unstable = (importPkgs unstable).extend self.overlays.default;
        } // locals.override;

      nixosConfigurations =
        let
          nixosSystem = { modules }: makeOverridable nixpkgs.lib.nixosSystem {
            inherit pkgs system;
            modules = modules ++ [
              nixpkgs.nixosModules.notDetected
              impermanence.nixosModule
            ];
          };

          hostConfig = host: nixosSystem {
            modules = [
              ./sys
              host
              nixvirt.nixosModules.default
            ];
          };
        in
        mapAttrs (_: hostConfig) (importAll { root = ./sys/platform; })
        // {
          dmz = nixosSystem {
            modules = [ ./dmz ];
          };
        };

      homeConfigurations =
        let
          registry = { ... }: {
            config.nix.registry = {
              "nixpkgs".flake = nixpkgs;
              "unstable".flake = unstable;
              "nur".flake = nur;
            };
          };

          home = platform: home-manager.lib.homeManagerConfiguration {
            inherit pkgs;

            modules = [
              ./home
              platform
              registry
              hm-isolation.homeManagerModule
            ];
          };

          platformHome = platform:
            let
              value = home platform;
            in
            {
              inherit value;
              name = "${value.config.home.username}@${value.config.local.hostname}";
            };
        in
        mapAttrs' (_: platformHome) (importAll { root = ./home/platform; });
    };
}