118 lines
3.3 KiB
Nix
118 lines
3.3 KiB
Nix
{
|
|
description = "Build Entire System";
|
|
|
|
inputs = {
|
|
|
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
|
|
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager/release-24.05";
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
};
|
|
|
|
nathan.url = "./home";
|
|
|
|
system.url = "./system";
|
|
#system.inputs.diskoConfig.inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
|
|
|
outputs = { self, nixpkgs, ... }@core_inputs: let
|
|
system = "x86_64-linux";
|
|
iso_system = "x86_64-linux";
|
|
|
|
host = "homebox";
|
|
username = "nathan";
|
|
|
|
devices = {
|
|
main = "/dev/nvme0n1";
|
|
bonus.disk1 = "/dev/nvme1n1";
|
|
};
|
|
|
|
in {
|
|
inputs.home-manager.useGlobalPkgs = true;
|
|
|
|
nixosConfigurations.${host} = nixpkgs.lib.nixosSystem {
|
|
|
|
inherit system;
|
|
specialArgs = {
|
|
core_inputs = (core_inputs // {inherit host;});
|
|
};
|
|
|
|
modules = [
|
|
core_inputs.system.nixosModule
|
|
core_inputs.home-manager.nixosModules.home-manager
|
|
|
|
({ lib, ... }: {
|
|
sysconfig = {
|
|
${host}.enable = true;
|
|
opts = {
|
|
firstBoot = true;
|
|
inherit host username devices;
|
|
};
|
|
};
|
|
disko = {
|
|
enable = true;
|
|
impermanent = true;
|
|
};
|
|
})
|
|
];
|
|
|
|
};
|
|
|
|
nixosConfigurations.iso = nixpkgs.lib.nixosSystem {
|
|
#inherit iso_system;
|
|
|
|
specialArgs = {
|
|
core_inputs = (core_inputs // {host = "live";});
|
|
};
|
|
|
|
modules = [
|
|
|
|
({ pkgs, modulesPath, ... }: {
|
|
imports = [
|
|
(modulesPath + "/installer/cd-dvd/installation-cd-minimal.nix")
|
|
];
|
|
|
|
environment.etc = {
|
|
"nixos/disko/default.nix".source = ./system/disko/default.nix;
|
|
"nixos/disko/disko.nix".source = ./system/disko/disko.nix;
|
|
"nixos/disko/disko_bonus.nix".source = ./system/disko/disko_bonus.nix;
|
|
"nixos/disko/impermanent.nix".source = ./system/disko/impermanent.nix;
|
|
"nixos/impermanence/default.nix".source = ./system/impermanence/default.nix;
|
|
"nixos/flake.nix".source = ./system/configuration/live/flake.nix;
|
|
};
|
|
|
|
services.openssh = {
|
|
enable = true;
|
|
};
|
|
|
|
networking = {
|
|
hostName = "live";
|
|
firewall.allowedTCPPorts = [ 22 ];
|
|
};
|
|
|
|
nixpkgs.hostPlatform = iso_system;
|
|
|
|
|
|
})
|
|
];
|
|
|
|
};
|
|
|
|
packages.${iso_system}.default = self.nixosConfigurations.iso.config.system.build.isoImage;
|
|
|
|
homeConfigurations."nathan" = core_inputs.home-manager.lib.homeManagerConfiguration {
|
|
pkgs = import nixpkgs {
|
|
inherit system;
|
|
config.allowUnfree = true;
|
|
};
|
|
extraSpecialArgs = { inherit core_inputs; };
|
|
|
|
modules = [ core_inputs.nathan.homeManagerModule ];
|
|
};
|
|
|
|
};
|
|
|
|
}
|