Nix noob trying to build his system
Find a file
2024-04-08 17:58:22 -05:00
patches Updated system 2024-02-18 09:23:57 -06:00
profiles Fixes xournal++ 2024-04-06 19:39:27 -05:00
system Incorporate config updates from homelab 2024-04-06 08:32:34 -05:00
themes Changed uwunicorn-yt wallpaper link to be not dead 2024-03-08 21:34:00 -06:00
user Fixes rebuilding without phoenix.nix 2024-04-08 17:58:22 -05:00
desktop.png Updated main desktop screenshot 2024-03-09 17:08:22 -06:00
flake.lock Fixed home-manager version mismatch for servers 2024-04-06 08:48:57 -05:00
flake.nix Fixed home-manager version mismatch for servers 2024-04-06 08:48:57 -05:00
harden.sh Testing update system from git repo script 2024-04-06 13:58:01 -05:00
install.org Updated autoinstall notes and cleared some git todos 2024-03-09 16:44:33 -06:00
install.sh Testing update system from git repo script 2024-04-06 13:58:01 -05:00
LICENSE Add LICENSE 2023-04-22 20:48:09 +00:00
pull.sh Removed phoenix script, added and refactored some scripts 2024-04-08 17:55:51 -05:00
README.org Reverting *some autoinstall script changes 2024-03-09 11:28:18 -06:00
soften.sh Testing update system from git repo script 2024-04-06 13:58:01 -05:00
sync-posthook.sh Removed phoenix script, added and refactored some scripts 2024-04-08 17:55:51 -05:00
sync.sh Removed phoenix script, added and refactored some scripts 2024-04-08 17:55:51 -05:00
update.sh Removed phoenix script, added and refactored some scripts 2024-04-08 17:55:51 -05:00
upgrade.sh Removed phoenix script, added and refactored some scripts 2024-04-08 17:55:51 -05:00

NixOS Config

Main Repo Link (GitLab)

Mirror Repo Link (GitHub)

Mirror Repo Link (Codeberg)

What is this repository?

These are my dotfiles (configuration files) for my NixOS setup(s).

Here is my main setup: /byteio/nixos-config/media/commit/42d46ee2ccfab1ac7365fef4494171230da43c48/desktop.png

My Themes

Stylix (and base16.nix, of course) is amazing, allowing you to theme your entire system with base16-themes.

Using this I have 55+ themes (I add more sometimes) I can switch between on-the-fly. Visit the themes directory for more info and screenshots!

Install

I wrote some reinstall notes for myself here (install.org).

TLDR: You should™ be able to install my dotfiles to a fresh NixOS system with the following experimental script:

nix-shell -p git --command "nix run --experimental-features 'nix-command flakes' gitlab:librephoenix/nixos-config"

Disclaimer: Ultimately, I can't gaurantee this will work for anyone other than myself, so use this at your own discretion. Also my dotfiles are highly opinionated, which you will discover immediately if you try them out.

Potential Errors: I've only tested it working on UEFI with the default EFI mount point of /boot. I've added experimental legacy (BIOS) boot support, but it does rely on a quick and dirty script to find the grub device. If you are testing it using some weird boot configuration for whatever reason, try modifying bootMountPath (UEFI) or grubDevice (legacy BIOS) in flake.nix before install, or else it will complain about not being able to install the bootloader.

Note: If you're installing this to a VM, Hyprland won't work unless 3D acceleration is enabled.

Security Disclaimer: If you install or copy my homelab or worklab profiles, CHANGE THE PUBLIC SSH KEYS UNLESS YOU WANT ME TO BE ABLE TO SSH INTO YOUR SERVER. YOU CAN CHANGE OR REMOVE THE SSH KEY IN THE RELEVANT CONFIGURATION.NIX:

Modules

Separate Nix files can be imported as modules using an import block:

imports = [ ./import1.nix
            ./import2.nix
            ...
          ];

This conveniently allows configurations to be (*cough cough) modular (ba dum, tssss).

I have my modules separated into two groups:

More detailed information on these specific modules are in the system directory and user directory respectively.

Patches

In some cases, since I use nixpgs-unstable, I must patch nixpkgs. This can be done inside of a flake via:

    nixpkgs-patched = (import nixpkgs { inherit system; }).applyPatches {
      name = "nixpkgs-patched";
      src = nixpkgs;
      patches = [ ./example-patch.nix ];
    };

    # configure pkgs
    pkgs = import nixpkgs-patched { inherit system; };

    # configure lib
    lib = nixpkgs.lib;

Patches can either be local or remote, so you can even import unmerged pull requests by using fetchpatch and the raw patch url, i.e: https://github.com/NixOS/nixpkgs/pull/example.patch.

I currently curate patches local to this repo in the patches directory.

Profiles

I separate my configurations into profiles (essentially system templates), i.e:

  • Personal - What I would run on a personal laptop/desktop
  • Work - What I would run on a work laptop/desktop (if they let me bring my own OS :P)
  • Homelab - What I would run on a server or homelab
  • WSL - What I would run underneath Windows Subystem for Linux

My profile can be conveniently selected in my flake.nix by setting the profile variable.

More detailed information on these profiles is in the profiles directory.

Star History

Didn't think this would get that many stars on GitHub, yet here we are: https://api.star-history.com/svg?repos=librephoenix/nixos-config&type=Date.png