-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
151 lines (134 loc) · 4.04 KB
/
flake.nix
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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
{
description = "NixOS Workshop";
nixConfig = {
substituters = [
# Replace the official cache with a mirror located in China
# Add here some other mirror if needed.
"https://cache.nixos.org/"
];
extra-substituters = [
# Nix community's cache server
"https://nix-community.cachix.org"
];
extra-trusted-public-keys = [
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
];
};
inputs = {
# Nixpkgs (stuff for the system.)
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.11";
# Nixpkgs (unstable stuff for certain packages.)
# Also see the 'unstable-packages' overlay at 'overlays/default.nix'.
nixpkgsUnstable.url = "github:nixos/nixpkgs/nixos-unstable";
# Index the nix-store with `nix-locate`.
nix-index-database = {
url = "github:nix-community/nix-index-database";
inputs.nixpkgs.follows = "nixpkgs";
};
# Some Hardware Modules.
hardware = {
url = "github:NixOS/nixos-hardware";
};
# Home-Manager for NixOS.
home-manager = {
url = "github:nix-community/home-manager/release-24.11";
inputs.nixpkgs.follows = "nixpkgs";
};
# Format the repo with nix-treefmt.
treefmt-nix = {
url = "github:numtide/treefmt-nix";
inputs.nixpkgs.follows = "nixpkgsUnstable";
};
# Declarative Disk partitioning for VMs.
disko = {
url = "github:nix-community/disko";
inputs.nixpkgs.follows = "nixpkgs";
};
# Age Encryption Tool for NixOS.
agenix = {
url = "github:ryantm/agenix";
inputs.nixpkgs.follows = "nixpkgsUnstable";
};
};
outputs =
{
self,
nixpkgs,
...
}@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;
# Your custom packages: Accessible through 'nix build', 'nix shell', etc.
packages = forAllSystems (system: (import ./pkgs) nixpkgs.legacyPackages.${system});
# Formatter for all files.
formatter = forAllSystems (
system:
let
pkgs = nixpkgs.legacyPackages.${system};
treefmtEval = inputs.treefmt-nix.lib.evalModule pkgs ./treefmt.nix;
treefmt = treefmtEval.config.build.wrapper;
in
treefmt
);
# Your custom packages and modifications, exported as overlays
overlays = import ./overlays { inherit inputs; };
# Reusable nixos modules you might want to export.
nixosModules = import ./modules/nixos;
# NixOS configuration entrypoint: Available through 'nixos-rebuild --flake .#your-hostname'
nixosConfigurations = import ./nixos { inherit inputs outputs; };
# The deploy configuration for `deploy-rs` tool to
# push the VM to the cloud.
deploy = {
nodes.workshop-cloud-vm = {
hostname = "workshop-cloud-vm";
fastConnection = true;
profiles = {
system = {
user = "root";
sshUser = "root";
path = inputs.deploy-rs.lib.x86_64-linux.activate.nixos nixosConfigurations.vm;
};
};
};
};
# Development shell to work in this repository.
devShells = forAllSystems (
system:
let
pkgs = (import inputs.nixpkgsUnstable) { inherit system; };
in
{
default = pkgs.mkShell {
packages = [
pkgs.nix-output-monitor
pkgs.just
pkgs.virt-manager
pkgs.virt-viewer
];
};
}
);
in
{
inherit
formatter
packages
overlays
nixosModules
nixosConfigurations
deploy
devShells
;
};
}