dotfiles/modules/os/core/shared/nix.nix
eriedaberrie 7e1cb4b389 Initial commit
Note: not the actual initial commit.

I swear I will stop repeatedly force pushing to this single commit eventually
ok.
2024-11-07 01:59:05 -08:00

62 lines
1.6 KiB
Nix

{ config, lib, pkgs, inputs, self, ... }:
{
nixpkgs = {
config = {
allowUnfree = true;
};
overlays = [
inputs.grim-hyprland.overlays.default
(final: prev: {
mkNixPak = inputs.nixpak.lib.nixpak {
pkgs = final;
inherit lib;
};
})
];
};
nix = {
package = pkgs.lix;
settings = let
flakeConfig = (import "${self}/flake.nix").nixConfig;
in {
experimental-features = [ "nix-command" "flakes" "repl-flake" ];
auto-optimise-store = true;
keep-outputs = true;
keep-derivations = true;
substituters = flakeConfig.extra-substituters;
trusted-public-keys = flakeConfig.extra-trusted-public-keys;
trusted-users = [ "@wheel" ];
};
# Make nix commands use config's flake lock
registry = {
nixpkgs.flake = inputs.nixpkgs;
stable.flake = inputs.nixpkgs-stable;
};
nixPath = [
"nixpkgs=/etc/nix/inputs/nixpkgs"
"stable=/etc/nix/inputs/stable"
];
extraOptions = ''
!include ${config.age.secrets.nix-tokens.path}
'';
gc = {
automatic = true;
dates = "weekly";
options = "--delete-older-than 7d";
randomizedDelaySec = "30min";
};
};
environment = {
systemPackages = [ pkgs.nh ];
sessionVariables.FLAKE = "${config.users.users.${config.my.user.username}.home}/.config/nixos";
etc = {
"nix/inputs/nixpkgs".source = inputs.nixpkgs.outPath;
"nix/inputs/stable".source = inputs.nixpkgs-stable.outPath;
"current-flake".source = self;
};
};
}