This repository was archived by the owner on Nov 27, 2025. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathflake.nix
More file actions
125 lines (121 loc) · 3.73 KB
/
flake.nix
File metadata and controls
125 lines (121 loc) · 3.73 KB
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
124
125
{
description = "Your new nix config";
inputs = {
# Nixpkgs
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
# You can access packages and modules from different nixpkgs revs
# at the same time. Here's an working example:
# nixpkgs-unstable.url = "github:nixos/nixpkgs/nixos-unstable";
# Also see the 'unstable-packages' overlay at 'overlays/default.nix'.
# Home manager
home-manager.inputs.nixpkgs.follows = "nixpkgs";
home-manager.url = "github:nix-community/home-manager";
agenix.url = "github:ryantm/agenix";
nixvim.url = "github:nix-community/nixvim";
nixvim.inputs.nixpkgs.follows = "nixpkgs";
nix-gaming.url = "github:fufexan/nix-gaming";
zen-browser.url = "github:0xc000022070/zen-browser-flake";
};
outputs = {
self,
nixpkgs,
home-manager,
agenix,
nixvim,
...
} @ inputs: let
inherit (self) outputs;
# Supported systems for your flake packages, shell, etc.
systems = [
"aarch64-linux"
"i686-linux"
"x86_64-linux"
"aarch64-darwin"
"x86_64-darwin"
];
# This is a function that generates an attribute by calling a function you
# pass to it, with each system as an argument
forAllSystems = nixpkgs.lib.genAttrs systems;
in {
# Your custom packages
# Accessible through 'nix build', 'nix shell', etc
packages = forAllSystems (system: import ./pkgs nixpkgs.legacyPackages.${system});
# Formatter for your nix files, available through 'nix fmt'
# Other options beside 'alejandra' include 'nixpkgs-fmt'
formatter = forAllSystems (system: nixpkgs.legacyPackages.${system}.alejandra);
nixosModules = builtins.listToAttrs (
(map (x: {
name = x;
value = import (./modules + "/${x}");
}) (builtins.attrNames (builtins.readDir ./modules)))
++ [
{
name = "agenix";
value = agenix.nixosModules.default;
}
]
);
homeModules =
builtins.listToAttrs
(
map
(name: {
inherit name;
value = import (./home-manager/modules + "/${name}");
})
(builtins.attrNames (builtins.readDir ./home-manager/modules))
)
// {
nix = {pkgs, ...}: {
imports = [
inputs.nixvim.homeModules.nixvim
# inputs.plasma-manager.homeModules.plasma-manager
# inputs.wall-utils.homeModules.wall-utils
];
};
};
# NixOS configuration entrypoint
# Available through 'nixos-rebuild --flake .#your-hostname'
# GreenMachine = nixpkgs.lib.nixosSystem {
# specialArgs = {inherit inputs outputs;};
# modules = [
# # > Our main nixos configuration file <
# ./nixos/GreenMachine/configuration.nix
# agenix.nixosModules.default
# ];
# };
# };
nixosConfigurations =
builtins.listToAttrs
(
map
(x: {
name = x;
value = nixpkgs.lib.nixosSystem {
specialArgs = {
inherit inputs;
flake-self = self;
};
modules =
builtins.attrValues self.nixosModules
++ [
inputs.home-manager.nixosModules.home-manager
inputs.nix-gaming.nixosModules.platformOptimizations
inputs.nixvim.nixosModules.nixvim
(import "${./.}/machines/${x}/configuration.nix" {inherit self;})
];
};
})
(builtins.attrNames (builtins.readDir ./machines))
);
homeConfigurations = {
lily = {...}: {
imports =
[
./home-manager/profiles/desktop.nix
]
++ builtins.attrValues self.homeModules;
};
};
};
}