-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
124 lines (113 loc) · 3.41 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
{
description = "noob NixOS Flake Configuration";
inputs = {
nixpkgs.url = "github:NixOs/nixpkgs/release-24.11";
# disko.url = "github:nix-community/disko";
# disko.inputs.nixpkgs.follows = "nixpkgs";
home-manager = {
url = "github:nix-community/home-manager/release-24.11";
inputs.nixpkgs.follows = "nixpkgs";
};
sops-nix = {
url = "github:Mic92/sops-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
# Load secrets from private repository
nix-secrets = {
url = "git+ssh://[email protected]/lukethacoder/nix-private.git?ref=main&shallow=1";
flake = false;
};
};
outputs = {
self,
nixpkgs,
# disko,
home-manager,
sops-nix,
...
}@inputs:
let
system = "x86_64-linux";
# overlays = [
# (self: super: {
# go = super.go_1_24;
# })
# # (final: prev: {
# # # override go version to fix sops-nix issue?
# # go = final.pkgs.go_1_24;
# # sops-install-secrets = prev.sops-install-secrets.overrideAttrs (oldAttrs: {
# # buildInputs = (oldAttrs.buildInputs or []) ++ [ final.pkgs.go_1_24 ];
# # });
# # })
# ];
# overlays = [
# (final: prev: {
# sops-install-secrets = prev.sops-install-secrets.overrideAttrs (oldAttrs: {
# buildInputs = (oldAttrs.buildInputs or []) ++ [ final.pkgs.go_1_23 ];
# });
# })
# ];
pkgs = import nixpkgs {
inherit system;
# inherit overlays;
};
in {
nix.extraOptions = ''
plugin-files = ${pkgs.nix-plugins}/lib/nix/plugins
'';
nixosConfigurations = {
opslag = nixpkgs.lib.nixosSystem {
inherit system;
specialArgs = {
inherit inputs;
vars = import ./machines/nixos/vars.nix;
};
modules = [
# Base configuration and modules
./modules/system
./modules/sops
./modules/tailscale
./modules/fonts
./modules/gnome
./modules/podman
./modules/email
# Disko
# ./disko/opslag.nix
# disko.nixosModules.disko
# Import machine config + secrets
./machines/nixos
./machines/nixos/opslag
# Services and applications
./containers/homepage
./containers/traefik
# ./containers/deluge
./containers/qbittorrent
# ./containers/grafana
./containers/jellyfin
./containers/navidrome
./containers/immich
# ./containers/homeassistant
# ./containers/adguard
# ./containers/syncthing
# Users
./users/luke
home-manager.nixosModules.home-manager
{
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
home-manager.extraSpecialArgs = {
inherit inputs;
vars = import ./machines/nixos/vars.nix;
};
home-manager.users.luke.imports = [
# agenix.homeManagerModules.default
# nix-index-database.hmModules.nix-index
./users/luke/dots.nix
];
home-manager.backupFileExtension = "bak";
}
];
};
};
};
}