blob: ced7d1441757989cabb111fa7852ebda3ed560a4 (
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
|
rec {
description = "TimmyOS System Config";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.11";
sops-nix = {
url = "github:Mic92/sops-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
home-manager = {
url = "github:nix-community/home-manager/release-24.11";
inputs.nixpkgs.follows = "nixpkgs";
};
arkenfox = {
url = "github:dwarfmaster/arkenfox-nixos";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { nixpkgs, home-manager, arkenfox, ... }@inputs :
let
system = "x86_64-linux";
pkgs = nixpkgs.legacyPackages.${system};
userDetails = {
username = "timmy";
home.root = "/home/timmy";
home.downloads = "/home/timmy/dls";
email = "tjkeller.xyz";
fullname = "Tim Keller";
};
mkNixosConfiguration = hostname: nixpkgs.lib.nixosSystem {
inherit system;
specialArgs = {
inherit inputs;
inherit userDetails;
};
modules = [
./modules/hosts/${hostname}/configuration.nix
./modules/root
home-manager.nixosModules.home-manager {
home-manager = {
backupFileExtension = "backup";
useGlobalPkgs = true;
useUserPackages = true;
users.${userDetails.username} = import ./modules/home;
extraSpecialArgs = {
inherit userDetails;
};
sharedModules = [
inputs.arkenfox.hmModules.arkenfox
./modules/hosts/${hostname}/home.nix
];
};
}
];
};
in {
nixosConfigurations = {
T430 = mkNixosConfiguration "T430";
T495 = mkNixosConfiguration "T495";
};
};
}
|