{ config , lib , inputs , self , pkgs , ... }: let inherit (lib) mkEnableOption mkOption types; cfg = config.my.programs.nix; mkNom = system: nix: inputs.nix-monitored.packages.${system}.default.override { withNotify = false; nix = nix; }; in { options.my.programs.nix = { gc = { enable = mkEnableOption "nix-gc"; minimumFreedGB = mkOption { default = 32; type = types.int; apply = number: toString (number * 1024 * 1024 * 1024); }; }; optimise.enable = mkEnableOption "nix-optimise"; }; config = { my.nixpkgs.overlays = [ (final: prev: { nixos-rebuild = prev.nixos-rebuild.override { nix = mkNom final.system final.nix; }; }) ]; home-manager.users.moritz.programs.direnv.nix-direnv.package = pkgs.nix-direnv.override { nix = config.nix.package; }; age.secrets.nix-github-token.file = ../../secrets/nix-github-token.age; nix = { nixPath = [ "nixpkgs=${inputs.nixpkgs}" ]; package = pkgs.nix; extraOptions = '' !include ${config.age.secrets.nix-github-token.path} experimental-features = nix-command flakes ''; gc = { automatic = cfg.gc.enable; options = "--max-freed ${cfg.gc.minimumFreedGB} --delete-older-than 14d"; dates = "weekly"; }; optimise = { automatic = cfg.optimise.enable; dates = [ "weekly" ]; }; registry = { master-upstream.to = { type = "github"; owner = "nixos"; repo = "nixpkgs"; }; master.flake = inputs.master; nixpkgs.flake = inputs.nixpkgs; stable.flake = inputs.stable; dotfiles.flake = self; default.flake = self; d.flake = self; }; settings = { substituters = [ "https://cache.nixos.org/" ]; trusted-public-keys = [ "cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=" ]; trusted-users = [ "root" "@wheel" ]; }; }; }; }