aboutsummaryrefslogtreecommitdiff
path: root/examples/system/flake.nix
blob: 383960bd997f8219aeeae2df5277ea9e225e9a15 (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
{
  description = "Deploy a full system with hello service as a separate profile";


  outputs = { self, nixpkgs }: {
    nixosConfigurations.example-nixos-system = nixpkgs.lib.nixosSystem {
      system = "x86_64-linux";
      modules = [ ./configuration.nix ];
    };

    nixosConfigurations.bare = nixpkgs.lib.nixosSystem {
      system = "x86_64-linux";
      modules = [ ./bare.nix "${nixpkgs}/nixos/modules/virtualisation/qemu-vm.nix" ];
    };

    # This is the application we actually want to run
    defaultPackage.x86_64-linux = import ./hello.nix nixpkgs;

    deploy.nodes.example = {
      sshOpts = [ "-p" "2221" ];
      hostname = "localhost";
      fastConnection = true;
      profiles = {
        system = {
          sshUser = "admin";
          activate = "$PROFILE/bin/switch-to-configuration switch";
          path = self.nixosConfigurations.example-nixos-system.config.system.build.toplevel;
          user = "root";
        };
        hello = {
          sshUser = "hello";
          activate = "$PROFILE/bin/activate";
          path = self.defaultPackage.x86_64-linux;
          user = "hello";
        };
      };
    };

    checks = builtins.mapAttrs (_: pkgs: {
      jsonschema = pkgs.runCommandNoCC "jsonschema-deploy-system" { }
      "${pkgs.python3.pkgs.jsonschema}/bin/jsonschema -i ${
        pkgs.writeText "deploy.json" (builtins.toJSON self.deploy)
      } ${../../interface/deploy.json} && touch $out";
    }) nixpkgs.legacyPackages;
  };
}