From: Skullheadx Date: Sat, 23 May 2026 23:11:44 +0000 (-0400) Subject: mutli host X-Git-Url: http://git.skullheadx.com/nixos/blog/static/gitweb.css?a=commitdiff_plain;h=89deb0d132e32c8538bc07ee9009361b525ae04e;p=nixos.git mutli host --- diff --git a/flake.nix b/flake.nix index fa473f0..9b76d89 100644 --- a/flake.nix +++ b/flake.nix @@ -36,38 +36,43 @@ url = "github:notashelf/nvf"; inputs.nixpkgs.follows = "nixpkgs"; }; - }; - outputs = - { - self, - nixpkgs, - hjem, - my-slstatus, - my-surf, - my-dwm, - my-st, - my-dmenu, - nvf, - }@inputs: - let - system = "x86_64-linux"; - pkgs = nixpkgs.legacyPackages.${system}; - customNeovim = nvf.lib.neovimConfiguration { - inherit pkgs; - modules = [ ./nvf/nvf.nix ]; - }; - in - { - nixosConfigurations.nepsis = nixpkgs.lib.nixosSystem { - specialArgs = { inherit inputs customNeovim; }; - modules = [ - hjem.nixosModules.default - ./configuration.nix - ./overlays.nix - ]; - }; - - packages.${system}.my-neovim = customNeovim.neovim; + outputs = { + self, + nixpkgs, + hjem, + my-slstatus, + my-surf, + my-dwm, + my-st, + my-dmenu, + nvf, + } @ inputs: let + system = "x86_64-linux"; + pkgs = nixpkgs.legacyPackages.${system}; + customNeovim = nvf.lib.neovimConfiguration { + inherit pkgs; + modules = [./nvf/nvf.nix]; + }; + in { + nixosConfigurations.nepsis = nixpkgs.lib.nixosSystem { + specialArgs = {inherit inputs customNeovim;}; + modules = [ + hjem.nixosModules.default + ./linux-common.nix + ./hosts/nepsis/configuration.nix + ./overlays.nix + ]; }; + nixosConfigurations.icon = nixpkgs.lib.nixosSystem { + modules = [ + hjem.nixosModules.default + ./linux-common.nix + ./hosts/icon/configuration.nix + ./overlays.nix + ]; + }; + + packages.${system}.my-neovim = customNeovim.neovim; + }; } diff --git a/hosts/icon/configuration.nix b/hosts/icon/configuration.nix new file mode 100644 index 0000000..e803175 --- /dev/null +++ b/hosts/icon/configuration.nix @@ -0,0 +1,73 @@ +{ + config, + pkgs, + inputs, + ... +}: { + imports = [ + ./hardware-configuration.nix + ]; + + networking.hostName = "icon"; + # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. + + # Configure network proxy if necessary + # networking.proxy.default = "http://user:password@proxy:port/"; + # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; + + # List packages installed in system profile. To search, run: + # $ nix search wget + environment.systemPackages = with pkgs; [ + ]; + + programs.git = { + enable = true; + config = { + user = { + name = "Skullheadx"; + email = "admonty1@protonmail.com"; + }; + pull.rebase = true; + url = { + "git@github.com:".insteadOf = "https://github.com/"; + }; + }; + }; + + programs.nix-ld.enable = true; + programs.nix-ld.libraries = with pkgs; [ + # Add any missing dynamic libraries for unpackaged + # programs here, NOT in environment.systemPackages + ]; + + environment.sessionVariables = { + }; + + # Some programs need SUID wrappers, can be configured further or are + # started in user sessions. + # programs.mtr.enable = true; + programs.gnupg.agent = { + enable = true; + enableSSHSupport = true; + }; + + # Services + services.openssh.enable = true; + services.rsync = { + enable = true; + }; + + # Open ports in the firewall. + # networking.firewall.allowedTCPPorts = [ ... ]; + # networking.firewall.allowedUDPPorts = [ ... ]; + # Or disable the firewall altogether. + # networking.firewall.enable = false; + + # This value determines the NixOS release from which the default + # settings for stateful data, like file locations and database versions + # on your system were taken. It‘s perfectly fine and recommended to leave + # this value at the release version of the first install of this system. + # Before changing this value read the documentation for this option + # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). + system.stateVersion = "25.05"; # Did you read the comment? +} diff --git a/configuration.nix b/hosts/nepsis/configuration.nix similarity index 82% rename from configuration.nix rename to hosts/nepsis/configuration.nix index edda465..6dc148e 100644 --- a/configuration.nix +++ b/hosts/nepsis/configuration.nix @@ -6,42 +6,19 @@ }: { imports = [ ./hardware-configuration.nix - ./lockscreen.nix - ./x11.nix - ./hjem.nix - ./audio.nix - ./vim.nix - ./sh.nix + ./../../lockscreen.nix + ./../../x11.nix + ./../../hjem.nix + ./../../audio.nix ]; - # Bootloader. - boot.loader.systemd-boot.enable = true; - boot.loader.efi.canTouchEfiVariables = true; - - boot.supportedFilesystems = ["exfat"]; - - # Use latest kernel. - boot.kernelPackages = pkgs.linuxPackages_latest; - networking.hostName = "nepsis"; - networking.networkmanager.enable = true; # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. # Configure network proxy if necessary # networking.proxy.default = "http://user:password@proxy:port/"; # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; - time.timeZone = "America/Toronto"; - - i18n.defaultLocale = "en_CA.UTF-8"; - - # Allow unfree packages - nixpkgs.config.allowUnfree = true; - nix.settings.experimental-features = [ - "nix-command" - "flakes" - ]; - # List packages installed in system profile. To search, run: # $ nix search wget environment.systemPackages = with pkgs; [ diff --git a/hardware-configuration.nix b/hosts/nepsis/hardware-configuration.nix similarity index 100% rename from hardware-configuration.nix rename to hosts/nepsis/hardware-configuration.nix diff --git a/linux-common.nix b/linux-common.nix new file mode 100644 index 0000000..101d7eb --- /dev/null +++ b/linux-common.nix @@ -0,0 +1,97 @@ +{ + config, + pkgs, + inputs, + ... +}: { + imports = [ + ./sh.nix + ]; + + # Bootloader. + boot.loader.systemd-boot.enable = true; + boot.loader.efi.canTouchEfiVariables = true; + boot.supportedFilesystems = ["exfat"]; + + # Use latest kernel. + boot.kernelPackages = pkgs.linuxPackages_latest; + + networking.networkmanager.enable = true; + # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. + + # Configure network proxy if necessary + # networking.proxy.default = "http://user:password@proxy:port/"; + # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; + + time.timeZone = "America/Toronto"; + + i18n.defaultLocale = "en_CA.UTF-8"; + + # Allow unfree packages + nixpkgs.config.allowUnfree = true; + nix.settings.experimental-features = [ + "nix-command" + "flakes" + ]; + + # List packages installed in system profile. To search, run: + # $ nix search wget + environment.systemPackages = with pkgs; [ + wget + nixfmt + fastfetch + pamixer + gcc + ]; + + programs.git = { + enable = true; + config = { + user = { + name = "Skullheadx"; + email = "admonty1@protonmail.com"; + }; + pull.rebase = true; + url = { + "git@github.com:".insteadOf = "https://github.com/"; + }; + }; + }; + + programs.nix-ld.enable = true; + programs.nix-ld.libraries = with pkgs; [ + # Add any missing dynamic libraries for unpackaged + # programs here, NOT in environment.systemPackages + ]; + + environment.sessionVariables = { + }; + + # Some programs need SUID wrappers, can be configured further or are + # started in user sessions. + # programs.mtr.enable = true; + programs.gnupg.agent = { + enable = true; + enableSSHSupport = true; + }; + + # Services + services.openssh.enable = true; + services.rsync = { + enable = true; + }; + + # Open ports in the firewall. + # networking.firewall.allowedTCPPorts = [ ... ]; + # networking.firewall.allowedUDPPorts = [ ... ]; + # Or disable the firewall altogether. + # networking.firewall.enable = false; + + # This value determines the NixOS release from which the default + # settings for stateful data, like file locations and database versions + # on your system were taken. It‘s perfectly fine and recommended to leave + # this value at the release version of the first install of this system. + # Before changing this value read the documentation for this option + # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). + system.stateVersion = "25.05"; # Did you read the comment? +}