First pass for steven

This commit is contained in:
Annika Merris 2024-11-28 09:53:24 -05:00
parent 64499f2c1b
commit 8997f6cf9c
3 changed files with 152 additions and 0 deletions

View file

@ -76,6 +76,9 @@
virt-nix = import ./hosts/virt-nix {
inherit inputs globals;
};
steven = import ./hosts/steven {
inherit inputs globals;
};
};
homeConfigurations = {
@ -83,6 +86,7 @@
envy = nixosConfigurations.envy.config.home-manager.users.${globals.user}.home;
parents = nixosConfigurations.parents.config.home-manager.users.${globals.user}.home;
virt-nix = nixosConfigurations.virt-nix.config.home-manager.users.${globals.user}.home;
steven = nixosConfigurations.virt-nix.config.home-manager.users.${globals.user}.home;
};
permittedInsecurePackages = [

108
hosts/steven/default.nix Normal file
View file

@ -0,0 +1,108 @@
# virt-nix
# System configuration for a vm on my desktop
{ inputs, globals, ... }:
with inputs;
inputs.nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
modules = [
globals
lix-module.nixosModules.default
home-manager.nixosModules.home-manager
sops-nix.nixosModules.sops
./hardware-configuration.nix
../../modules/common
../../modules/nixos
{
# something with overlays, I don't get those yet.
# Hardware
physical = true;
networking.hostName = "steven";
networking.useDHCP = nixpkgs.lib.mkDefault true;
# TODO: identityFile = "/home/${globals.user}/.ssh/id_ed2519";
# TODO: passwordHash = nixpkgs.lib.fileContents ../../password.sha512;
# Theming?
sops = {
defaultSopsFile = ../../secrets/secrets.yaml;
defaultSopsFormat = "yaml";
age.keyFile = "/home/annika/.config/sops/age/keys.txt";
age.sshKeyPaths = [
"/etc/ssh/ssh_host_ed25519_key"
];
};
# TODO: Temporary, remove eventually!
time.timeZone = "America/New_York";
nix.settings.experimental-features = [ "nix-command" "flakes" ];
nixpkgs.config.allowUnfree = true;
system.stateVersion = "23.11";
home-manager.backupFileExtension = "backup";
hardware.bluetooth.enable = true;
hardware.bluetooth.powerOnBoot = true;
# Enable hardware features
audio.enable = true;
gui.enable = true;
services.openssh.enable = true;
services.flatpak.enable = true;
# Apps
discord.enable = true;
element.enable = true;
firefox.enable = true;
kitty.enable = true;
# netbird.enable = true; See netbird.nix (I can't access the sops stuff from here?)
openrgb.enable = true;
prusa-slicer.enable = true;
spotifyd.enable = true;
thunderbird.enable = true;
# Gaming
steam.enable = true;
# Programming Stuff
nixpkgs-fmt.enable = true;
python3.enable = true;
vscode.enable = true;
# Utilities
# git is not optional
docker.enable = true;
yubikey.enable = true;
kdeconnect.enable = true;
tailscale.enable = true;
# TODO: Move this out
home-manager.users.annika = {
programs = {
direnv = {
enable = true;
enableBashIntegration = true;
nix-direnv.enable = true;
};
bash = {
enable = true;
shellAliases = {
s = "kitten ssh";
la = "ls -a";
ll = "ls -l";
lal = "ls -la";
cls = "clear && ls";
};
};
};
};
nix.gc = {
automatic = true;
randomizedDelaySec = "14m";
options = "--delete-older-than 10d";
};
}
];
}

View file

@ -0,0 +1,40 @@
# Do not modify this file! It was generated by nixos-generate-config
# and may be overwritten by future invocations. Please make changes
# to /etc/nixos/configuration.nix instead.
{ config, lib, pkgs, modulesPath, ... }:
{
imports =
[ (modulesPath + "/installer/scan/not-detected.nix")
];
boot.initrd.availableKernelModules = [ "ahci" "xhci_pci" "usb_storage" "sd_mod" "sdhci_pci" "rtsx_usb_sdmmc" ];
boot.initrd.kernelModules = [ ];
boot.kernelModules = [ "kvm-intel" ];
boot.extraModulePackages = [ ];
fileSystems."/" =
{ device = "/dev/disk/by-uuid/fad4b5f4-b316-411e-ad44-fe48c4f50313";
fsType = "ext4";
};
fileSystems."/boot" =
{ device = "/dev/disk/by-uuid/DE67-DFD6";
fsType = "vfat";
};
swapDevices =
[ { device = "/dev/disk/by-uuid/1832b450-9f1d-4953-bdd4-18d38e90f903"; }
];
# Enables DHCP on each ethernet and wireless interface. In case of scripted networking
# (the default) this is the recommended approach. When using systemd-networkd it's
# still possible to use this option, but it's recommended to use it in conjunction
# with explicit per-interface declarations with `networking.interfaces.<interface>.useDHCP`.
networking.useDHCP = lib.mkDefault true;
# networking.interfaces.bnep0.useDHCP = lib.mkDefault true;
# networking.interfaces.wwp0s21f0u3i4.useDHCP = lib.mkDefault true;
nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
}