aboutsummaryrefslogtreecommitdiffstats
path: root/modules/by-name/ni/nix
diff options
context:
space:
mode:
authorBenedikt Peetz <benedikt.peetz@b-peetz.de>2024-10-18 17:07:46 +0200
committerBenedikt Peetz <benedikt.peetz@b-peetz.de>2024-10-18 17:07:46 +0200
commitc52c7f314ccadcc2fcd91e28c8fd1b88f6d5ce0c (patch)
treee8b947710b467b32740598ff574982097836f66c /modules/by-name/ni/nix
parentchore(pkgs/yt): 1.2.1 -> 1.3.0 (diff)
downloadnixos-config-c52c7f314ccadcc2fcd91e28c8fd1b88f6d5ce0c.zip
refactor(modules): Move all system modules to `by-name`
From now on all modules should be added to the new `by-name` directory. This should help remove the (superficial and utterly useless) distinction between `home-manager` and `NixOS` modules.
Diffstat (limited to 'modules/by-name/ni/nix')
-rw-r--r--modules/by-name/ni/nix/module.nix61
1 files changed, 61 insertions, 0 deletions
diff --git a/modules/by-name/ni/nix/module.nix b/modules/by-name/ni/nix/module.nix
new file mode 100644
index 00000000..980bbd39
--- /dev/null
+++ b/modules/by-name/ni/nix/module.nix
@@ -0,0 +1,61 @@
+{
+ pkgs,
+ # flakes
+ nixpkgs_as_input,
+ templates,
+ self,
+ system,
+ ...
+}: {
+ nix = {
+ package = pkgs.nixVersions.latest;
+
+ # Disable nix channels (this is a remnant of old days)
+ channel.enable = false;
+
+ registry = {
+ nixpkgs.flake = nixpkgs_as_input;
+ n.flake =
+ nixpkgs_as_input
+ // {
+ # Otherwise nixpkgs's config and overlays are not available:
+
+ # Both attrs exists, so we just override both and hope
+ outputs.legacyPackages."${system}" = pkgs;
+ legacyPackages."${system}" = pkgs;
+ };
+
+ t.flake = templates;
+
+ my_flake.flake = self;
+ m.flake = self;
+ };
+
+ gc = {
+ automatic = true;
+ dates = "weekly";
+ options = "--delete-older-than 7d";
+ };
+
+ settings = {
+ auto-optimise-store = true;
+ experimental-features = [
+ "nix-command"
+ "flakes"
+ #"ca-derivations"
+ ];
+
+ use-xdg-base-directories = true;
+
+ #substituters = ["https://cache.ngi0.nixos.org/"];
+ #trusted-public-keys = ["cache.ngi0.nixos.org-1:KqH5CBLNSyX184S9BKZJo1LxrxJ9ltnY2uAs5c/f1MA="];
+
+ fallback = true; # Build from source, if binary can't be substituted
+
+ keep-failed = true; # keep failed tmp build dirs
+ pure-eval = true; # restrict file system and network access to hash
+
+ sandbox-fallback = false; # Don't disable the sandbox, if the kernel doesn't support it
+ };
+ };
+}