2024-12-31 10:50:01 -08:00
|
|
|
{
|
2024-09-13 14:55:27 -07:00
|
|
|
description = "Joey's Flake";
|
2024-12-31 10:50:01 -08:00
|
|
|
inputs = {
|
2025-01-06 13:15:05 -08:00
|
|
|
# Package repositories:
|
2024-12-05 12:52:17 -08:00
|
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11";
|
2024-09-13 14:55:27 -07:00
|
|
|
nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixos-unstable";
|
2024-09-16 16:45:05 -07:00
|
|
|
home-manager = {
|
2024-12-05 12:52:17 -08:00
|
|
|
url = "github:nix-community/home-manager/release-24.11";
|
2024-09-16 16:45:05 -07:00
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
2025-01-06 13:15:05 -08:00
|
|
|
|
|
|
|
# Applications:
|
|
|
|
hyprland = {
|
|
|
|
url = "github:hyprwm/Hyprland";
|
|
|
|
inputs.nixpkgs.follows = "nixpkgs-unstable";
|
|
|
|
};
|
2024-10-28 18:04:04 -07:00
|
|
|
nixgl.url = "github:nix-community/nixGL";
|
2024-09-14 12:43:44 -07:00
|
|
|
nix-flatpak.url = "github:gmodena/nix-flatpak";
|
2024-09-16 16:45:05 -07:00
|
|
|
stylix = {
|
2025-01-06 13:15:05 -08:00
|
|
|
url = "github:danth/stylix/release-24.11";
|
2024-09-16 16:45:05 -07:00
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
2024-12-07 00:39:36 -08:00
|
|
|
zen-browser.url = "github:0xc000022070/zen-browser-flake";
|
2024-10-28 18:04:04 -07:00
|
|
|
sops-nix = {
|
2024-12-31 10:50:01 -08:00
|
|
|
url = "github:Mic92/sops-nix";
|
2024-10-28 18:04:04 -07:00
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
2024-12-31 10:50:01 -08:00
|
|
|
deploy-rs.url = "github:serokell/deploy-rs";
|
2025-01-02 15:27:44 -08:00
|
|
|
ghostty.url = "github:ghostty-org/ghostty";
|
2024-09-13 14:55:27 -07:00
|
|
|
};
|
2024-12-31 10:50:01 -08:00
|
|
|
outputs = inputs@{
|
|
|
|
nixpkgs,
|
|
|
|
nixpkgs-unstable,
|
|
|
|
home-manager,
|
2024-10-28 18:04:04 -07:00
|
|
|
nixgl,
|
2025-01-02 15:27:44 -08:00
|
|
|
ghostty,
|
2025-01-23 22:48:53 -08:00
|
|
|
deploy-rs,
|
|
|
|
self,
|
2024-12-31 10:50:01 -08:00
|
|
|
...
|
2025-02-16 00:14:45 -08:00
|
|
|
}: {
|
2024-09-13 14:55:27 -07:00
|
|
|
nixosConfigurations = {
|
2025-02-16 15:14:46 -08:00
|
|
|
desktop = let
|
|
|
|
sys = {
|
|
|
|
username = "joey";
|
|
|
|
hostname = "desktop";
|
|
|
|
kernelPackage = "linux_zen"; # Read more: https://nixos.wiki/wiki/Linux_kernel; Other options: https://mynixos.com/nixpkgs/packages/linuxKernel.packages;
|
|
|
|
sshPrivateKey = ".ssh/joey.desktop@jafner.net";
|
|
|
|
};
|
|
|
|
system = "x86_64-linux";
|
|
|
|
pkgs = import inputs.nixpkgs {
|
|
|
|
inherit system;
|
|
|
|
overlays = [ nixgl.overlay ];
|
|
|
|
config = { allowUnfreePredicate = (_: true); };
|
|
|
|
};
|
|
|
|
in nixpkgs.lib.nixosSystem {
|
|
|
|
modules = [
|
|
|
|
./systems/desktop/configuration.nix
|
|
|
|
inputs.nix-flatpak.nixosModules.nix-flatpak
|
|
|
|
inputs.home-manager.nixosModules.home-manager
|
|
|
|
inputs.sops-nix.nixosModules.sops
|
|
|
|
{
|
|
|
|
home-manager.sharedModules = [
|
|
|
|
inputs.nix-flatpak.homeManagerModules.nix-flatpak
|
|
|
|
inputs.stylix.homeManagerModules.stylix
|
|
|
|
];
|
|
|
|
home-manager.extraSpecialArgs = { inherit pkgs inputs sys; };
|
|
|
|
}
|
|
|
|
./modules/system.nix
|
|
|
|
./modules/git.nix
|
|
|
|
./modules/sops.nix
|
|
|
|
./modules/docker.nix
|
|
|
|
./modules/smb.nix
|
|
|
|
./modules/iscsi.nix
|
|
|
|
./modules/services/minecraft-server.nix
|
|
|
|
./modules/programs/spotify.nix
|
|
|
|
./modules/services/flatpak.nix
|
|
|
|
./modules/services/minecraft-server.nix
|
|
|
|
./systems/desktop/hardware/audio.nix
|
|
|
|
./systems/desktop/hardware/goxlr-mini.nix
|
|
|
|
./systems/desktop/hardware/libinput.nix
|
|
|
|
./systems/desktop/hardware/printing.nix
|
|
|
|
./systems/desktop/hardware/razer.nix
|
|
|
|
./systems/desktop/hardware/wooting.nix
|
|
|
|
./systems/desktop/hardware/xpad.nix
|
|
|
|
./systems/desktop/hardware.nix
|
|
|
|
./systems/desktop/desktop-environment.nix
|
|
|
|
./systems/desktop/terminal-environment.nix
|
|
|
|
./systems/desktop/theme.nix
|
|
|
|
./systems/desktop/filesystems.nix
|
|
|
|
./systems/desktop/defaultApplications.nix
|
|
|
|
./systems/desktop/clips.nix
|
|
|
|
];
|
|
|
|
inherit system;
|
|
|
|
specialArgs = { inherit pkgs inputs;
|
|
|
|
sys = sys;
|
|
|
|
docker = {
|
|
|
|
username = sys.username;
|
|
|
|
};
|
|
|
|
sops = {
|
|
|
|
username = sys.username;
|
|
|
|
sshPrivateKey = sys.sshPrivateKey;
|
|
|
|
repoRoot = "/home/joey/Git/Jafner.net";
|
|
|
|
};
|
|
|
|
git = {
|
|
|
|
username = sys.username;
|
|
|
|
realname = "Joey Hafner";
|
|
|
|
email = "joey@jafner.net";
|
|
|
|
sshPrivateKey = sys.sshPrivateKey;
|
|
|
|
signingKey = "B0BBF464024BCEAE";
|
|
|
|
};
|
|
|
|
smb = {
|
2025-02-16 15:21:24 -08:00
|
|
|
secretsFile = ./systems/desktop/smb.secrets;
|
2025-02-16 15:14:46 -08:00
|
|
|
automount_opts = "x-systemd.automount,noauto,x-systemd.idle-timeout=60,x-systemd.device-timeout=5s,x-systemd.mount-timeout=5s";
|
|
|
|
permissions_opts = "credentials=/run/secrets/smb,uid=1000,gid=1000";
|
|
|
|
};
|
|
|
|
iscsi = {
|
|
|
|
iqn = "iqn.2020-03.net.jafner:joey-desktop";
|
|
|
|
portalIP = "192.168.1.12:3260";
|
|
|
|
mountPath = "/mnt/iscsi"; # Unused until I can figure out how to write a proper iscsi fileSystems block.
|
|
|
|
fsType = "ext4"; # Unused until I can figure out how to write a proper iscsi fileSystems block.
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2025-01-30 15:07:48 -08:00
|
|
|
|
2025-02-16 01:26:30 -08:00
|
|
|
# # build with:
|
|
|
|
# # nix build .#nixosConfigurations.iso.config.system.build.isoImage
|
|
|
|
# iso = let
|
|
|
|
# sys = {
|
|
|
|
# username = "admin";
|
|
|
|
# hostname = "installer";
|
|
|
|
# signingKey = "";
|
|
|
|
# kernelPackage = "linux_6_12"; # Read more: https://nixos.wiki/wiki/Linux_kernel; Other options: https://mynixos.com/nixpkgs/packages/linuxKernel.packages;
|
|
|
|
# sshPrivateKey = ".ssh/joey.desktop@jafner.net";
|
|
|
|
# };
|
|
|
|
# system = "x86_64-linux";
|
|
|
|
# pkgs = import inputs.nixpkgs {
|
|
|
|
# inherit system;
|
|
|
|
# config = { allowUnfreePredicate = (_: true); };
|
|
|
|
# };
|
|
|
|
# in nixpkgs.lib.nixosSystem {
|
|
|
|
# modules = [
|
|
|
|
# "${nixpkgs}/nixos/modules/installer/cd-dvd/installation-cd-minimal.nix"
|
|
|
|
# "${nixpkgs}/nixos/modules/installer/cd-dvd/channel.nix"
|
|
|
|
# { imports = [ ./modules/system.nix ]; }
|
|
|
|
# ];
|
|
|
|
# inherit system pkgs;
|
|
|
|
# specialArgs = { inherit sys; };
|
|
|
|
# };
|
2025-01-23 13:46:47 -08:00
|
|
|
|
2025-02-16 01:26:30 -08:00
|
|
|
# # build with:
|
|
|
|
# # nix build .#nixosConfigurations.cloudimage.config.system.build.digitalOceanImage
|
|
|
|
# cloudimage = let
|
|
|
|
# sys = {
|
|
|
|
# username = "admin";
|
|
|
|
# hostname = "digital-ocean";
|
|
|
|
# signingKey = "";
|
|
|
|
# kernelPackage = "linux_6_12"; # Read more: https://nixos.wiki/wiki/Linux_kernel; Other options: https://mynixos.com/nixpkgs/packages/linuxKernel.packages;
|
|
|
|
# sshPrivateKey = ".ssh/joey.desktop@jafner.net";
|
|
|
|
# };
|
|
|
|
# system = "x86_64-linux";
|
|
|
|
# pkgs = import inputs.nixpkgs {
|
|
|
|
# inherit system;
|
|
|
|
# config = { allowUnfreePredicate = (_: true); };
|
|
|
|
# };
|
|
|
|
# in nixpkgs.lib.nixosSystem {
|
|
|
|
# modules = [
|
|
|
|
# "${nixpkgs}/nixos/modules/virtualisation/digital-ocean-image.nix"
|
|
|
|
# { imports = [ ./modules/system.nix ]; }
|
|
|
|
# ];
|
|
|
|
# inherit system pkgs;
|
|
|
|
# specialArgs = { inherit sys; };
|
|
|
|
# };
|
|
|
|
# artificer = let
|
|
|
|
# sys = {
|
|
|
|
# username = "admin";
|
|
|
|
# hostname = "artificer";
|
|
|
|
# signingKey = "";
|
|
|
|
# kernelPackage = "linux_6_12"; # Read more: https://nixos.wiki/wiki/Linux_kernel; Other options: https://mynixos.com/nixpkgs/packages/linuxKernel.packages;
|
|
|
|
# sshPrivateKey = ".ssh/admin@artificer";
|
|
|
|
# };
|
|
|
|
# system = "x86_64-linux";
|
|
|
|
# pkgs = import inputs.nixpkgs {
|
|
|
|
# inherit system;
|
|
|
|
# config = { allowUnfreePredicate = (_: true); };
|
|
|
|
# };
|
|
|
|
# in nixpkgs.lib.nixosSystem {
|
|
|
|
# modules = [
|
|
|
|
# ./systems/artificer/configuration.nix
|
|
|
|
# inputs.home-manager.nixosModules.home-manager
|
|
|
|
# inputs.sops-nix.nixosModules.sops
|
|
|
|
# "${nixpkgs}/nixos/modules/virtualisation/digital-ocean-image.nix"
|
|
|
|
# { imports = [ ./modules/system.nix ];
|
|
|
|
# sys = sys; }
|
|
|
|
# { imports = [ ./modules/git.nix ];
|
|
|
|
# git = {
|
|
|
|
# username = sys.username;
|
|
|
|
# realname = sys.hostname;
|
|
|
|
# email = "noreply@jafner.net";
|
|
|
|
# sshPrivateKey = sys.ssyPrivateKey;
|
|
|
|
# signingKey = "";
|
|
|
|
# }; }
|
|
|
|
# { imports = [ ./modules/sops.nix ];
|
|
|
|
# sops = {
|
|
|
|
# username = sys.username;
|
|
|
|
# sshPrivateKey = sys.sshPrivateKey;
|
|
|
|
# repoRoot = "/home/admin/Jafner.net";
|
|
|
|
# }; }
|
|
|
|
# { imports = [ ./modules/docker.nix ];
|
|
|
|
# docker = {
|
|
|
|
# username = sys.username;
|
|
|
|
# }; }
|
|
|
|
# ];
|
|
|
|
# inherit system pkgs;
|
|
|
|
# specialArgs = { inherit sys; };
|
|
|
|
# };
|
2025-01-30 15:07:48 -08:00
|
|
|
fighter = let
|
|
|
|
sys = {
|
|
|
|
username = "admin";
|
|
|
|
hostname = "fighter";
|
2025-02-16 00:14:45 -08:00
|
|
|
sshPrivateKey = ".ssh/admin@fighter";
|
2025-02-06 15:59:08 -08:00
|
|
|
kernelPackage = "linux_6_12"; # Read more: https://nixos.wiki/wiki/Linux_kernel; Other options: https://mynixos.com/nixpkgs/packages/linuxKernel.packages;
|
2025-01-30 15:07:48 -08:00
|
|
|
};
|
|
|
|
system = "x86_64-linux";
|
|
|
|
pkgs = import inputs.nixpkgs {
|
|
|
|
inherit system;
|
2025-02-07 14:00:25 -08:00
|
|
|
config = { allowUnfreePredicate = (_: true); allowUnfree = true; };
|
2025-01-30 15:07:48 -08:00
|
|
|
};
|
|
|
|
in nixpkgs.lib.nixosSystem {
|
|
|
|
modules = [
|
|
|
|
./systems/fighter/configuration.nix
|
2025-01-31 11:27:47 -08:00
|
|
|
inputs.home-manager.nixosModules.home-manager
|
2025-02-06 01:38:06 -08:00
|
|
|
inputs.sops-nix.nixosModules.sops
|
2025-02-16 01:26:30 -08:00
|
|
|
./modules/system.nix
|
|
|
|
./modules/git.nix
|
|
|
|
./modules/sops.nix
|
|
|
|
./modules/docker.nix
|
|
|
|
./systems/fighter/stacks.nix
|
|
|
|
./modules/networking.nix
|
2025-02-16 02:43:07 -08:00
|
|
|
#./modules/iscsi.nix
|
2025-01-30 15:07:48 -08:00
|
|
|
];
|
|
|
|
inherit system pkgs;
|
2025-02-16 01:26:30 -08:00
|
|
|
specialArgs = {
|
|
|
|
sys = sys;
|
2025-02-16 02:43:07 -08:00
|
|
|
# iscsi = {
|
|
|
|
# iqn = "iqn.2020-03.net.jafner:fighter";
|
|
|
|
# portalIP = "192.168.1.12:3260";
|
|
|
|
# mountPath = "/mnt/iscsi";
|
|
|
|
# fsType = "ext4";
|
|
|
|
# };
|
2025-02-16 01:26:30 -08:00
|
|
|
networking = {
|
|
|
|
hostname = sys.hostname;
|
|
|
|
interface = "enp3s0";
|
|
|
|
mac = "00:02:c9:56:bf:9a";
|
|
|
|
ip = "192.168.1.23";
|
|
|
|
dns = [ "10.0.0.1" ];
|
|
|
|
};
|
|
|
|
stacks = {
|
|
|
|
appdata = "/appdata";
|
|
|
|
library = {
|
|
|
|
digitalModels = "/mnt/3DPrinting";
|
|
|
|
av = "/mnt/av";
|
|
|
|
books = "/mnt/books";
|
|
|
|
movies = "/mnt/movies";
|
|
|
|
music = "/mnt/music";
|
|
|
|
shows = "/mnt/shows";
|
|
|
|
torrenting = "/mnt/torrenting";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
docker = {
|
|
|
|
username = sys.username;
|
|
|
|
};
|
|
|
|
sops = {
|
|
|
|
username = sys.username;
|
|
|
|
sshPrivateKey = sys.sshPrivateKey;
|
|
|
|
repoRoot = "/home/admin/Jafner.net";
|
|
|
|
};
|
|
|
|
git = {
|
|
|
|
username = sys.username;
|
|
|
|
realname = sys.hostname;
|
|
|
|
email = "noreply@jafner.net";
|
|
|
|
sshPrivateKey = sys.sshPrivateKey;
|
|
|
|
signingKey = "";
|
|
|
|
};
|
2025-02-16 15:21:24 -08:00
|
|
|
smb = {
|
|
|
|
secretsFile = ./systems/fighter/smb.secrets;
|
|
|
|
automount_opts = "x-systemd.automount,noauto,x-systemd.idle-timeout=60,x-systemd.device-timeout=5s,x-systemd.mount-timeout=5s";
|
|
|
|
permissions_opts = "credentials=/run/secrets/smb,uid=1000,gid=1000";
|
|
|
|
};
|
|
|
|
iscsi = {
|
|
|
|
iqn = "iqn.2020-03.net.jafner:fighter";
|
|
|
|
portalIP = "192.168.1.12:3260";
|
|
|
|
mountPath = "/mnt/iscsi"; # Unused until I can figure out how to write a proper iscsi fileSystems block.
|
|
|
|
fsType = "ext4"; # Unused until I can figure out how to write a proper iscsi fileSystems block.
|
|
|
|
};
|
2025-02-16 01:26:30 -08:00
|
|
|
};
|
2025-01-30 15:07:48 -08:00
|
|
|
};
|
2025-01-23 22:48:53 -08:00
|
|
|
};
|
|
|
|
deploy = {
|
|
|
|
nodes = {
|
|
|
|
artificer = {
|
|
|
|
hostname = "143.198.68.202";
|
|
|
|
profilesOrder = [ "system" ];
|
|
|
|
profiles.system = {
|
|
|
|
user = "root";
|
|
|
|
sshUser = "admin";
|
|
|
|
path = deploy-rs.lib.x86_64-linux.activate.nixos self.nixosConfigurations.artificer;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
fastConnection = true;
|
|
|
|
interactiveSudo = false;
|
|
|
|
autoRollback = true;
|
|
|
|
magicRollback = true;
|
|
|
|
remoteBuild = true;
|
|
|
|
confirmTimeout = 60;
|
2024-09-16 13:45:18 -07:00
|
|
|
};
|
2025-01-23 22:48:53 -08:00
|
|
|
checks = builtins.mapAttrs (system: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib;
|
2024-09-13 14:55:27 -07:00
|
|
|
};
|
|
|
|
}
|