mirror of
https://codeberg.org/jopejoe1/nix-conf.git
synced 2025-01-21 03:39:47 +01:00
155 lines
4.6 KiB
Nix
155 lines
4.6 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
self,
|
|
...
|
|
}:
|
|
|
|
let
|
|
cfg = config.jopejoe1.nix;
|
|
in
|
|
{
|
|
options.jopejoe1.nix = {
|
|
enable = lib.mkEnableOption "Enable Nix";
|
|
};
|
|
options.jopejoe1.gui = {
|
|
enable = lib.mkEnableOption "Enable GUI";
|
|
};
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
nix = {
|
|
settings = {
|
|
substituters = lib.mkForce [
|
|
"https://cache.nixos.org"
|
|
"https://nix-community.cachix.org"
|
|
];
|
|
trusted-public-keys = lib.mkForce [
|
|
"cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY="
|
|
"nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="
|
|
];
|
|
sandbox = true;
|
|
require-sigs = true;
|
|
max-jobs = "auto";
|
|
allowed-users = [ "*" ];
|
|
trusted-users = [
|
|
"builder"
|
|
"jopejeo1"
|
|
"root"
|
|
];
|
|
experimental-features = [
|
|
"nix-command"
|
|
"flakes"
|
|
];
|
|
warn-dirty = true;
|
|
allow-dirty = false;
|
|
use-xdg-base-directories = true;
|
|
keep-going = true;
|
|
builders-use-substitutes = true;
|
|
download-attempts = 1;
|
|
fallback = true;
|
|
};
|
|
buildMachines =
|
|
let
|
|
getMainArch =
|
|
name:
|
|
self.nixosConfigurations.${name}.config.nixpkgs.hostPlatform.system
|
|
or self.nixosConfigurations.${name}.config.nixpkgs.system;
|
|
getArchs =
|
|
name:
|
|
[ (getMainArch name) ]
|
|
++ self.nixosConfigurations.${name}.config.nix.settings.extra-platforms or [ ];
|
|
in
|
|
[
|
|
{
|
|
systems = getArchs "hetzner";
|
|
supportedFeatures = self.nixosConfigurations.hetzner.config.nix.settings.system-features;
|
|
hostName = "hetzner";
|
|
publicHostKey = "c3NoLWVkMjU1MTkgQUFBQUMzTnphQzFsWkRJMU5URTVBQUFBSUZYQzNPVGRPd0w4V1NDaHhFRENiNS9WbUZYcDZmWUZEM21MMFhFdzFFTDAgcm9vdEBoZXR6bmVyCg==";
|
|
protocol = "ssh-ng";
|
|
sshUser = "builder";
|
|
sshKey = "/root/.ssh/builder";
|
|
speedFactor = 5;
|
|
maxJobs = 12;
|
|
}
|
|
{
|
|
systems = getArchs "zap";
|
|
supportedFeatures = self.nixosConfigurations.zap.config.nix.settings.system-features;
|
|
hostName = "zap";
|
|
publicHostKey = "c3NoLWVkMjU1MTkgQUFBQUMzTnphQzFsWkRJMU5URTVBQUFBSU5Xb056T0QrM0UzT20xbGpkRUNxWUhaQkZteHA3bTNsS1MxSHBkQnZkZjYgcm9vdEB6YXAK";
|
|
protocol = "ssh-ng";
|
|
sshUser = "builder";
|
|
sshKey = "/root/.ssh/builder";
|
|
maxJobs = 4;
|
|
}
|
|
{
|
|
systems = getArchs "kuraokami";
|
|
supportedFeatures = self.nixosConfigurations.kuraokami.config.nix.settings.system-features;
|
|
hostName = "kuraokami";
|
|
publicHostKey = "c3NoLWVkMjU1MTkgQUFBQUMzTnphQzFsWkRJMU5URTVBQUFBSUtJbFZhWTZ0aTJkVFVGUks0eFVoRitxa1kwbUhiT3pNSWpjTjZpMFNiTW0gcm9vdEBrdXJhb2thbWkK";
|
|
protocol = "ssh-ng";
|
|
sshUser = "builder";
|
|
sshKey = "/root/.ssh/builder";
|
|
speedFactor = 10;
|
|
maxJobs = 24;
|
|
}
|
|
];
|
|
distributedBuilds = true;
|
|
package = pkgs.lix;
|
|
registry = lib.mkForce (
|
|
(lib.mapAttrs (_: flake: { inherit flake; })) (
|
|
(lib.filterAttrs (_: lib.isType "flake")) self.inputs
|
|
)
|
|
// {
|
|
self.flake = self;
|
|
}
|
|
);
|
|
nixPath = lib.mkForce [ "/etc/nix/path" ];
|
|
|
|
};
|
|
|
|
nixpkgs = {
|
|
config = {
|
|
allowUnfree = true;
|
|
nvidia.acceptLicense = true;
|
|
};
|
|
overlays = [
|
|
(_self: super: rec {
|
|
firefox-addons = self.inputs.firefox-addons.packages.${config.nixpkgs.hostPlatform.system};
|
|
localPkgs = self.outputs.packages.${config.nixpkgs.hostPlatform.system};
|
|
})
|
|
];
|
|
};
|
|
|
|
environment.etc = lib.mapAttrs' (name: value: {
|
|
name = "nix/path/${name}";
|
|
value.source = value.flake;
|
|
}) config.nix.registry;
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
nix-index
|
|
nix-prefetch-git
|
|
nixpkgs-review
|
|
];
|
|
|
|
home-manager = {
|
|
useGlobalPkgs = true;
|
|
useUserPackages = true;
|
|
backupFileExtension = "backup";
|
|
sharedModules = [
|
|
self.outputs.homeManagerModules.default
|
|
self.inputs.catppuccin.homeManagerModules.catppuccin
|
|
];
|
|
};
|
|
|
|
systemd.services.nix-daemon.serviceConfig.LimitNOFILE = lib.mkForce 1048576000;
|
|
|
|
networking.hosts = {
|
|
"192.168.194.46" = [ "zap" ];
|
|
"192.168.194.54" = [ "kuraokami" ];
|
|
"192.168.194.208" = [ "hetzner" ];
|
|
"192.168.194.232" = [ "omoikane" ];
|
|
};
|
|
users.mutableUsers = false;
|
|
};
|
|
}
|