2023-05-28 05:24:36 +02:00
# Welcome to _the Satellite_
2023-01-11 10:19:49 +01:00
2023-07-21 18:30:48 +02:00
In case you are not familiar with nix/nixos, this is a collection of configuration files which build all my systems in a declarative manner. The tool used to configure the global system is called [nixos ](https://nixos.org/ ), and the one used to configure the individual users is called [home-manager ](https://github.com/nix-community/home-manager ).
2023-01-11 10:19:49 +01:00
2023-11-13 04:31:54 +01:00
> A [visual history](./docs/history.md) of my setup is in the works!
2023-11-08 07:16:48 +01:00
2023-07-21 18:30:48 +02:00
## Features this repository includes:
2023-01-11 10:19:49 +01:00
2023-11-16 05:43:52 +01:00
- Sets up all the apps I use — including git, neovim, fish, tmux, starship, hyprland, anyrun, discord, zathura, wezterm & much more.
2024-02-24 03:51:35 +01:00
- Sets up my entire homelab — including zfs-based [impermanence ](https://grahamc.com/blog/erase-your-darlings ), automatic let's-encrypt certificates, tailscale, syncthing, vaultwarden, whoogle, pounce, calico, smos, intray, actual & more.
2024-02-20 00:51:01 +01:00
- Consistent base16 theming using [stylix ](https://github.com/danth/stylix )
- Declarative secret management using [sops-nix ](https://github.com/Mic92/sops-nix )
2023-01-11 10:19:49 +01:00
The current state of this repo is a refactor of my old, messy nixos config, based on the structure of [this template ](https://github.com/Misterio77/nix-starter-configs ).
2023-07-21 18:30:48 +02:00
## Hosts
2023-01-11 10:19:49 +01:00
2023-05-28 05:24:36 +02:00
This repo's structure is based on the concept of hosts - individual machines configured by me. I'm naming each host based on things in space/mythology (_they are the same picture_). The hosts I have right now are:
2023-01-11 10:19:49 +01:00
2024-02-20 00:51:01 +01:00
- [tethys ](./hosts/nixos/tethys/ ) — my personal laptop
- [lapetus ](./hosts/nixos/lapetus/ ) — older laptop running as a server
- [euporie ](./hosts/nixos/euporie/ ) — barebones host for testing things insdie a VM
- enceladus — my android phone. Although not configured using nix, this name gets referenced in some places
2023-01-11 10:19:49 +01:00
2023-07-21 18:30:48 +02:00
## File structure
2023-05-28 05:24:36 +02:00
2023-12-12 14:32:06 +01:00
| Location | Description |
| ---------------------------- | --------------------------------------------------- |
| [common ](./common ) | Configuration loaded on both nixos and home-manager |
| [devshells ](./devshells ) | Nix shells |
| [docs ](./docs ) | Additional documentation regarding my setup |
| [home ](./home ) | Home manager configurations |
| [hosts/nixos ](./hosts/nixos ) | Nixos configurations |
| [modules ](./modules ) | Custom generic/nixos/home-manager modules |
| [overlays ](./overlays ) | Nix overlays |
| [pkgs ](./pkgs ) | Nix packages |
| [flake.nix ](./flake.nix ) | Nix flake entrypoint! |
2024-02-01 00:04:04 +01:00
| [scripts ](./scripts ) | Bash scripts that come in handy when on a live cd |
2024-01-31 20:03:00 +01:00
| [.sops.yaml ](./.sops.yaml ) | Sops entrypoint |
2023-12-12 14:32:06 +01:00
| [stylua.toml ](./stylua.toml ) | Lua formatter config for the repo |
2023-05-28 05:24:36 +02:00
2023-07-21 18:30:48 +02:00
## Points of interest
2023-01-11 10:19:49 +01:00
Here's some things you might want to check out:
2023-12-12 14:38:20 +01:00
- My [neovim config ](./home/features/neovim )
2023-01-11 10:19:49 +01:00
- The [flake ](./flake.nix ) entrypoint for this repository
2023-01-12 20:49:08 +01:00
2023-07-21 18:30:48 +02:00
## Things I use
2023-12-12 14:38:20 +01:00
> This does not include links to every plugin I use for every program here. You can see more details in the respective configurations.
2023-07-21 18:30:48 +02:00
### Fundamentals
- [Nixos ](http://nixos.org/ ) — nix based operating system
- [Home-manager ](https://github.com/nix-community/home-manager ) — manage user configuration using nix
- [Impernanence ](https://github.com/nix-community/impermanence ) — see the article about [erasing your darlings ](https://grahamc.com/blog/erase-your-darlings )
2024-01-31 20:03:00 +01:00
- [Sops-nix ](https://github.com/Mic92/sops-nix ) — secret management
2023-07-21 18:30:48 +02:00
- [disko ](https://github.com/nix-community/disko ) — format disks using nix
- [zfs ](https://openzfs.org/wiki/Main_Page ) — filesystem
2024-02-20 00:51:01 +01:00
### Input handling
- [kanta ](https://github.com/jtroo/kanata ) — software-level keyboard layout customizer. One of the few such programs with support for chording
- [opentabletdriver ](https://opentabletdriver.net/ )
2023-07-21 18:30:48 +02:00
### Graphical
- [Stylix ](https://github.com/danth/stylix ) — base16 module for nix
- [Base16 templates ](https://github.com/chriskempson/base16-templates-source ) — list of base16 theme templates
- [Catpuccin ](https://github.com/catppuccin/catppuccin ) — base16 theme I use
- [Rosepine ](https://rosepinetheme.com/ ) — another theme I use
- [Hyprland ](https://hyprland.org/ ) — wayland compositor
- [Wlogout ](https://github.com/ArtsyMacaw/wlogout ) — wayland logout menu
- [Hyprpicker ](https://github.com/hyprwm/hyprpicker ) — hyprland color picker
- [Grimblast ](https://github.com/hyprwm/contrib/tree/main/grimblast ) — screenshot tool
- [Dunst ](https://dunst-project.org/ ) — notification daemon
- [Wlsunset ](https://sr.ht/~kennylevinsen/wlsunset/ ) — day/night screen gamma adjustements
2023-08-19 21:31:22 +02:00
- [Anyrun ](https://github.com/Kirottu/anyrun ) — program launcher
2023-07-21 18:30:48 +02:00
- [Wezterm ](https://wezfurlong.org/wezterm/ ) — terminal emulator
- [Zathura ](https://pwmt.org/projects/zathura/ ) — pdf viewer
- [Firefox ](https://www.mozilla.org/en-US/firefox/ ) — web browser
- [Tesseract ](https://github.com/tesseract-ocr/tesseract ) — OCR engine
- [Obsidian ](https://obsidian.md/ ) — note taking software
2024-02-20 00:51:01 +01:00
- [Bitwarden ](https://bitwarden.com/ ) — client for self-hosted password manager
2023-07-21 18:30:48 +02:00
### Terminal
> There are many clis I use which I did not include here, for the sake of brevity.
- [Neovim ](https://neovim.io/ ) — my editor
- [Neovide ](https://neovide.dev/index.html ) — neovim gui client
- [Vimclip ](https://github.com/hrantzsch/vimclip ) — vim anywhere!
- [Firenvim ](https://github.com/glacambre/firenvim ) — embed neovim in web browsers
- [Tmux ](https://github.com/tmux/tmux/wiki ) — terminal multiplexer
- [Fish ](https://fishshell.com/ ) — user friendly shell
- [Starship ](https://starship.rs/ ) — shell prompt
- [Ranger ](https://github.com/ranger/ranger ) — file manager
2024-02-01 00:04:04 +01:00
- [Catgirl ](https://git.causal.agency/catgirl/about/ ) — irc client
2023-09-10 17:20:36 +02:00
- Self management:
2024-02-24 03:51:35 +01:00
- [Smos ](https://github.com/NorfairKing/smos ) — selfhosted comprehensive self-management system
2024-02-20 00:51:01 +01:00
- [Intray ](https://github.com/NorfairKing/intray ) — selfhosted GTD capture tool
2023-07-21 18:30:48 +02:00
### Services
2024-02-01 00:04:04 +01:00
Most services are served over [tailscale ](https://tailscale.com/ ), using certificates generated by [let's encrypt ](https://letsencrypt.org/ ).
2023-07-21 18:30:48 +02:00
- [Syncthing ](https://syncthing.net/ ) — file synchronization
2024-02-01 00:04:04 +01:00
- [Whoogle ](https://github.com/benbusby/whoogle-search#manual-docker ) — search engine
- [Pounce ](https://git.causal.agency/pounce/about/ ) & [calico ](https://git.causal.agency/pounce/about/calico.1 ) — irc bouncer
2024-02-20 00:51:01 +01:00
- [Vaultwarden ](https://github.com/dani-garcia/vaultwarden/ ) — password manager
2024-02-24 03:51:35 +01:00
- [Smos ](https://github.com/NorfairKing/smos ) — a comprehensive self-management system.
2024-02-20 00:51:01 +01:00
- [Intray ](https://github.com/NorfairKing/intray ) — GTD capture tool.
2024-02-24 03:51:35 +01:00
- [Actual ](https://actualbudget.org/ ) — budgeting tool.
2023-07-21 18:30:48 +02:00
## Hall of fame
2023-06-04 09:12:06 +02:00
2023-09-10 17:20:36 +02:00
Includes links to stuff which used to be in the previous section but is not used anymore. Only created this section in June 2023, so stuff I used earlier might not be here. Sorted with the most recently dropped things at the top.
2023-06-04 09:12:06 +02:00
2024-02-20 00:51:01 +01:00
- [Slambda ](https://github.com/Mateiadrielrafael/slambda ) — custom keyboard chording utility. I retired the project in favour of [kanta ](https://github.com/jtroo/kanata )
- [GPG ](https://gnupg.org/ ) + [pass ](https://www.passwordstore.org/ ) — I switched to [vaultwarden ](https://github.com/dani-garcia/vaultwarden/ )
2024-01-31 20:03:00 +01:00
- [Agenix ](https://github.com/ryantm/agenix ) & [homeage ](https://github.com/jordanisaacs/homeage ) — I switched to [sops-nix ](https://github.com/Mic92/sops-nix )
2023-09-10 17:20:36 +02:00
- [Mind.nvim ](https://github.com/phaazon/mind.nvim ) — self management tree editor. The project got archived, so I switched to [Smos ](https://github.com/NorfairKing/smos ).
- [Null-ls ](https://github.com/jose-elias-alvarez/null-ls.nvim ) — general purpose neovim LSP. The project got archived, so I switched to [formatter.nvim ](https://github.com/mhartington/formatter.nvim ).
- [Wofi ](https://sr.ht/~scoopta/wofi/ ) — program launcher. I switched to [Anyrun ](https://github.com/Kirottu/anyrun ).
2023-11-16 05:43:52 +01:00
- [Alacritty ](https://github.com/alacritty/alacritty ) — terminal emulator. I switched to [Wezterm ](https://wezfurlong.org/wezterm/ ).
2023-09-10 17:20:36 +02:00
- [Xmonad ](https://xmonad.org/ ) — xorg window manager. I switched to [Hyprland ](https://hyprland.org/ ).
2023-07-21 18:30:48 +02:00
- [Polybar ](https://github.com/polybar/polybar ) — desktop bar
2023-09-10 17:20:36 +02:00
- [Rofi ](https://github.com/davatorium/rofi ) — program launcher. I switched to [Wofi ](https://sr.ht/~scoopta/wofi/ ).
- [Spectacle ](https://apps.kde.org/spectacle/ ) — screenshot tool. I switched to [Grimblast ](https://github.com/hyprwm/contrib/tree/main/grimblast ).
- [Chrome ](https://www.google.com/chrome/ ) — web browser. I switched to `firefox` because it offers a better HM module.
2023-07-21 18:30:48 +02:00
## Future
2023-06-04 09:12:06 +02:00
Tooling I might use in the future:
2023-07-21 18:30:48 +02:00
2023-06-04 09:12:06 +02:00
- [nix-darwin ](https://github.com/LnL7/nix-darwin ) - like nixos but for macs
- [eww ](https://github.com/elkowar/eww ) - widget framework