summaryrefslogtreecommitdiff
path: root/flake.nix
blob: 44a7d7063208143c35f887f06f926f724866cb60 (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
112
113
114
115
116
117
118
119
120
121
122
123
{
  inputs = {
    nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
    unstable.url = "github:nixos/nixpkgs";

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

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

    nixvirt = {
      url = "github:AshleyYakeley/NixVirt";
      inputs = {
        nixpkgs.follows = "nixpkgs";

        #FIXME: Por qué existe esto?
        nixpkgs-ovmf.follows = "nixpkgs";
      };
    };
  };

  outputs =
    flakes@{ 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
            ];

            specialArgs = {
              inherit flakes;
            };
          };

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

          hv = nixosSystem {
            modules = [ ./hv ];
          };
        };

      homeConfigurations =
        let
          registry = { ... }: {
            config.nix.registry = mapAttrs
              (_: value: {
                flake = value;
              })
              flakes;
          };

          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; });
    };
}