Merge remote-tracking branch 'origin/main'
This commit is contained in:
commit
d72f1d31c3
5 changed files with 46 additions and 95 deletions
|
@ -21,20 +21,12 @@ set --export --universal XDG_PICTURES_DIR $NICE_HOME/img
|
||||||
set --export --universal XDG_VIDEOS_DIR $NICE_HOME/video
|
set --export --universal XDG_VIDEOS_DIR $NICE_HOME/video
|
||||||
set --export --universal XDG_GAMES_DIR $NICE_HOME/games
|
set --export --universal XDG_GAMES_DIR $NICE_HOME/games
|
||||||
|
|
||||||
set --export --universal DOTFILES_PATH $XDG_CONFIG_HOME/lytedev-dotfiles
|
|
||||||
set --export --universal ENV_PATH $XDG_CONFIG_HOME/lytedev-env
|
|
||||||
set --export --universal FISH_PATH $XDG_CONFIG_HOME/fish
|
|
||||||
|
|
||||||
set --export --universal NOTES_PATH $NICE_HOME/doc/notes
|
set --export --universal NOTES_PATH $NICE_HOME/doc/notes
|
||||||
set --export --universal SCROTS_PATH $NICE_HOME/img/scrots
|
set --export --universal SCROTS_PATH $NICE_HOME/img/scrots
|
||||||
set --export --universal USER_LOGS_PATH $NICE_HOME/doc/logs
|
set --export --universal USER_LOGS_PATH $NICE_HOME/doc/logs
|
||||||
|
|
||||||
set --export --universal CDPATH $NICE_HOME
|
set --export --universal CDPATH $NICE_HOME
|
||||||
|
|
||||||
for s in $ENV_PATH/*/config.d.fish
|
|
||||||
source $s (dirname $s)
|
|
||||||
end
|
|
||||||
|
|
||||||
# vars
|
# vars
|
||||||
set --export --universal LS_COLORS 'ow=01;36;40'
|
set --export --universal LS_COLORS 'ow=01;36;40'
|
||||||
set --export --universal EXA_COLORS '*=0'
|
set --export --universal EXA_COLORS '*=0'
|
||||||
|
@ -79,3 +71,7 @@ end
|
||||||
if has_command rtx
|
if has_command rtx
|
||||||
rtx activate fish | source
|
rtx activate fish | source
|
||||||
end
|
end
|
||||||
|
|
||||||
|
for dir in $HOME/.cargo/bin
|
||||||
|
fish_add_path $dir
|
||||||
|
end
|
||||||
|
|
|
@ -544,8 +544,6 @@ in
|
||||||
lC = "lc --reverse";
|
lC = "lc --reverse";
|
||||||
lD = "la --only-dirs";
|
lD = "la --only-dirs";
|
||||||
"cd.." = "d ..";
|
"cd.." = "d ..";
|
||||||
"cdd" = "d $DOTFILES_PATH";
|
|
||||||
"cde" = "d $XDG_CONFIG_HOME/lytedev-env";
|
|
||||||
"cdc" = "d $XDG_CONFIG_HOME";
|
"cdc" = "d $XDG_CONFIG_HOME";
|
||||||
"cdn" = "d $NOTES_PATH";
|
"cdn" = "d $NOTES_PATH";
|
||||||
"cdl" = "d $XDG_DOWNLOAD_DIR";
|
"cdl" = "d $XDG_DOWNLOAD_DIR";
|
||||||
|
|
101
readme.md
101
readme.md
|
@ -1,99 +1,80 @@
|
||||||
# Nix
|
# Nix
|
||||||
|
|
||||||
The grand unification of configuration.
|
My grand, declarative, and unified application, service, environment, and
|
||||||
|
machine configuration, secret, and package management in a single flake. ❤️ ❄️
|
||||||
|
|
||||||
## Not on NixOS?
|
**NOTE**: Everything in here is highly specific to my personal preference. I
|
||||||
|
can't recommend you actually use this in any way, but hopefully some stuff in
|
||||||
|
here is useful inspiration.
|
||||||
|
|
||||||
Install Nix using Determinate Systems's installer:
|
# Quick Start
|
||||||
|
|
||||||
```bash
|
You don't have even have to clone this crap yourself. How cool is that!
|
||||||
curl --proto '=https' --tlsv1.2 -sSf -L https://install.determinate.systems/nix | sh -s -- install
|
|
||||||
```
|
|
||||||
|
|
||||||
And [install Home Manager in standalone mode](https://nix-community.github.io/home-manager/index.html#sec-install-standalone):
|
## NixOS
|
||||||
|
|
||||||
# NixOS
|
```shell_session
|
||||||
|
|
||||||
```bash
|
|
||||||
nixos-rebuild --flake git+https://git.lyte.dev/lytedev/nix switch
|
nixos-rebuild --flake git+https://git.lyte.dev/lytedev/nix switch
|
||||||
```
|
```
|
||||||
|
|
||||||
## Remotely
|
## Not NixOS
|
||||||
|
|
||||||
|
```shell_session
|
||||||
|
$ curl --proto '=https' --tlsv1.2 -sSf -L https://install.determinate.systems/nix | sh -s -- install
|
||||||
|
$ nix profile install github:nix-community/home-manager
|
||||||
|
$ home-manager switch --flake git+https://git.lyte.dev/lytedev/nix
|
||||||
|
```
|
||||||
|
|
||||||
|
# Advanced Usage
|
||||||
|
|
||||||
|
## Push NixOS Config
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
nixos-rebuild --flake git+https://git.lyte.dev/lytedev/nix#host \
|
nix run nixpkgs#nixos-rebuild -- --flake 'git+https://git.lyte.dev/lytedev/nix#host' \
|
||||||
--target-host root@host --build-host root@host \
|
--target-host root@host --build-host root@host \
|
||||||
switch
|
switch --show-trace
|
||||||
```
|
```
|
||||||
|
|
||||||
# Home Manager
|
<!-- TODO: how to do this with rollbacks if I don't confirm things? -->
|
||||||
|
|
||||||
This can be used on non-NixOS hosts:
|
## Provisioning New NixOS Hosts
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
home-manager switch --flake .#daniel
|
# establish network access
|
||||||
```
|
# plug in ethernet or do the wpa_cli song and dance for wifi
|
||||||
|
wpa_cli scan
|
||||||
## Remotely
|
|
||||||
|
|
||||||
```bash
|
|
||||||
ssh daniel@host 'home-manager switch --flake git+https://git.lyte.dev/lytedev/nix#daniel'
|
|
||||||
```
|
|
||||||
|
|
||||||
# Provisioning New NixOS Hosts
|
|
||||||
|
|
||||||
Documented below is my process for standing up a new NixOS node configured and
|
|
||||||
managed by this flake from scratch.
|
|
||||||
|
|
||||||
## Network Access
|
|
||||||
|
|
||||||
Boot a NixOS ISO and establish network access:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
# plug in ethernet or do the wpa_cli song and dance for wifi access
|
|
||||||
wpa_cli scan # if you need to
|
|
||||||
wpa_cli scan_results
|
wpa_cli scan_results
|
||||||
|
|
||||||
wpa_cli add_network 0
|
wpa_cli add_network 0
|
||||||
wpa_cli set_network 0 ssid "MY_SSID"
|
wpa_cli set_network 0 ssid "MY_SSID"
|
||||||
wpa_cli set_network 0 psk "MY_WIFI_PASSWORD"
|
wpa_cli set_network 0 psk "MY_WIFI_PASSWORD"
|
||||||
wpa_cli enable_network 0
|
wpa_cli enable_network 0
|
||||||
wpa_cli save_config
|
wpa_cli save_config
|
||||||
```
|
|
||||||
|
|
||||||
Partition disk(s) and mount up however you like. Preferably, though, use a
|
# partition disks
|
||||||
[disko configuration](./disko.nix) from this flake like so:
|
nix-shell --packages git --run "sudo nix run \
|
||||||
|
|
||||||
```bash
|
|
||||||
# TODO: I'm relatively certain this can be simplified to a single `nix run` command
|
|
||||||
sudo nix-shell --packages git --run "nix run \
|
|
||||||
--extra-experimental-features nix-command \
|
--extra-experimental-features nix-command \
|
||||||
--extra-experimental-features flakes \
|
--extra-experimental-features flakes \
|
||||||
github:nix-community/disko -- \
|
github:nix-community/disko -- \
|
||||||
--flake 'git+https://git.lyte.dev/lytedev/nix#standard' \
|
--flake 'git+https://git.lyte.dev/lytedev/nix#${PARTITION_SCHEME}' \
|
||||||
--mode disko \
|
--mode disko \
|
||||||
--arg disks '[ \"/dev/your_disk\" ]'"
|
--arg disks '[ \"/dev/${DISK}\" ]'"
|
||||||
```
|
|
||||||
|
|
||||||
And finally install NixOS (optionally using my cache) as specified by this flake:
|
# install
|
||||||
|
|
||||||
```bash
|
|
||||||
nix-shell --packages git \
|
nix-shell --packages git \
|
||||||
--run "sudo nixos-install \
|
--run "sudo nixos-install \
|
||||||
--flake 'git+https://git.lyte.dev/lytedev/nix#yourNixosConfig' \
|
--flake 'git+https://git.lyte.dev/lytedev/nix#${FLAKE_ATTR}' \
|
||||||
--option substituters 'https://nix.h.lyte.dev' \
|
--option substituters 'https://nix.h.lyte.dev' \
|
||||||
--option trusted-public-keys 'h.lyte.dev:HeVWtne31ZG8iMf+c15VY3/Mky/4ufXlfTpT8+4Xbs0='"
|
--option trusted-public-keys 'h.lyte.dev:HeVWtne31ZG8iMf+c15VY3/Mky/4ufXlfTpT8+4Xbs0='"
|
||||||
```
|
```
|
||||||
|
|
||||||
**NOTE**: This takes a while, mostly due to building Helix myself on each box. I
|
# To Do
|
||||||
really need to figure out a good local caching setup.
|
|
||||||
|
|
||||||
**NOTE**: since the disko setup _should_ be included in the nixosConfiguration,
|
|
||||||
I would like to know how to do this all in one go -- maybe even building my own
|
|
||||||
live media?
|
|
||||||
|
|
||||||
# Other To Dos
|
|
||||||
|
|
||||||
- Port configuration (lytedev/dotfiles) to home manager where applicable?
|
- Port configuration (lytedev/dotfiles) to home manager where applicable?
|
||||||
- Sway, Kitty, and Helix, come to mind
|
- Sway, Kitty, and Helix, come to mind
|
||||||
- Pre-commit checks with `nix flake check`?
|
- Installation from a live ISO does not fully work yet
|
||||||
|
- I don't understand Nix well enough to know why stuff is being compiled even when I have a binary cache
|
||||||
|
- Maybe it detects different CPUs and will recompile certain packages for per-CPU optimizations?
|
||||||
|
- How does this factor in with "pureness"?
|
||||||
|
- Custom pre-configured live ISO
|
||||||
|
- Unify standalone home manager module with NixOS home manager module
|
||||||
|
- Pre-commit checks with stuff like `nix flake check` and formatting checkers
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
#!/usr/bin/env fish
|
|
||||||
|
|
||||||
set profile_dirs $HOME/.mozilla/firefox/*.dev-edition-default $HOME/.mozilla/firefox/*.default-release
|
|
||||||
if test (uname) = Darwin
|
|
||||||
set profile_dirs $HOME/Library/Application\ Support/Firefox/Profiles/*.dev-edition-default $HOME/.mozilla/firefox/*.default-release
|
|
||||||
end
|
|
||||||
|
|
||||||
for p in $profile_dirs
|
|
||||||
mkdir -p $p/chrome
|
|
||||||
set user_chrome_css_file $p/chrome/userChrome.css
|
|
||||||
echo '/* Generated by '(status -f)' -- do not edit manually! */' > $user_chrome_css_file
|
|
||||||
cat $DOTFILES_PATH/common/firefox/userChrome.d.css >> $user_chrome_css_file
|
|
||||||
echo >> $user_chrome_css_file
|
|
||||||
for file_part in $ENV_PATH/*/firefox/userChrome.d.css
|
|
||||||
cat $file_part >> $user_chrome_css_file
|
|
||||||
echo >> $user_chrome_css_file
|
|
||||||
end
|
|
||||||
echo Built $user_chrome_css_file
|
|
||||||
end
|
|
||||||
|
|
||||||
echo Make sure you set 'toolkit.legacyUserProfileCustomizations.stylesheets' to true in about:config
|
|
|
@ -1,3 +0,0 @@
|
||||||
#!/usr/bin/env sh
|
|
||||||
d="$(command ls "$ENV_PATH" | sk)" && \
|
|
||||||
tmux-lyte-session "env-$d" "$ENV_PATH/$d"
|
|
Loading…
Reference in a new issue