Compare commits

..

14 commits

Author SHA1 Message Date
Nick
1b0e09b029 feat: added readme 2025-03-01 16:00:09 -06:00
Nick
24d0da7823 feat: added readme 2025-03-01 15:58:36 -06:00
Nick
1b36918ced feat: changed system naming convention 2025-03-01 15:58:02 -06:00
Nick
33455dccd9 chore: removed tablet 2025-03-01 15:57:19 -06:00
Nick
b33bbbc746 chore: removed bluetooth enhancements 2025-03-01 15:56:58 -06:00
Nick
c3c08490dd chore: unfucked fire tablet compatibility 2025-03-01 15:56:02 -06:00
Nick
aca3a1f3c8 feat: added other systems 2025-03-01 15:55:23 -06:00
Nick
9c41180795 chore: unfucked wallpaper folder 2025-03-01 15:54:09 -06:00
Nick
640d9793cc chore: unfucked volume commands 2025-03-01 15:53:37 -06:00
Nick
a6f4433601 feat: updated binds 2025-03-01 15:52:49 -06:00
Nick
f3b90e759f feat: added razer packages 2025-03-01 15:52:10 -06:00
Nick
62bbd3a0d5 feat: tweaked the UI 2025-03-01 15:50:36 -06:00
Nick
45c0ede406 feat: added usbUtils 2025-03-01 15:49:51 -06:00
Nick
68138fdb01 feat: changed naming convention 2025-03-01 15:49:07 -06:00
53 changed files with 283 additions and 138 deletions

67
README.md Executable file
View file

@ -0,0 +1,67 @@
# My NixOS Dotfiles
This is my current multi-system NixOS configuration.
## File Structure
### `lib/`
This defines two helper functions that make it easier to create configurations in the `flake`:
1. `mkHome`: Creates a Home Manager configuration (for managing user-specific settings and packages)
2. `mkLinuxSystem`: Creates a NixOS system configuration (for managing system-wide settings)
Both functions take some modules (configuration files) as input and set up the necessary environment with some default settings, like allowing unfree packages and passing through important variables (inputs, config, etc.).
### `modules/config/`
This defines a configuration schema or template for managing various aspects of the system:
1. `people`: Creates records for user accounts, their SSH keys, emails, etc.
2. `services`: Creates records for various services with their domains, hostnames, SSL certificates, etc.
3. `machines`: Creates records for different devices with their mount points, IP addresses, and storage configurations
4. `aesthetics`: Creates records for visual appearance settings like fonts, colours, and cursor properties
It's essentially creating a structured way to organize abstracted configuration data that is declared in multiple places throughout the system configuration.
### `modules/home/`
This defines home environment configurations for different users across different machines in a multi-user, multi-device setup. It's using NixOS's home-manager functionality to manage user-specific configurations. Essentially, this is a configuration file that determines which software and configurations each user gets on each machine, allowing for personalized but reproducible user environments across the system.
### `modules/nixos/`
This defines a set of NixOS modules that are used to configure different systems. Each system has its own set of module imports that define what features or services are enabled on that system, as well as some shared modules. The file uses a helper function `directoryImport` (imported from ../helpers.nix) to import all the module definitions from the current directory. This allows for modular system configuration where different machines can easily inherit different sets of features and services. These modules are used in the `flake`.
### `parts/`
This defines the development environment configuration for the project, which includes:
1. `devshells`: Creates a default development shell with several development tools.
2. `pre-commit`: Creates pre-commit hooks that run before git commits.
This setup ensures that anyone working on this project has access to the same development tools and follows the same code formatting and commit message standards.
### `profiles/`
This defines NIxOS user configurations and their respective homes. Each profile is designed to be imported into each system configuration via the `flake`, with different settings and tools based on the user's needs and preferences. It also uses `systemd.tmpfiles` to declare custom home folder structures.
### `secrets/`
This contains encrypted secrets and credentials using `sops-nix`. This is a security-sensitive file that should be handled carefully as it contains encrypted credentials for multiple services and systems.
### `systems/`
This defines the system configurations for different machines. Each machine has similar configuration structure but with specific customizations. The system naming schema follows a celestial convention, with desktops being named after planets, laptops after moons, and servers after dwarf planets. The `fileSystems` configurations include helper functions for easily configuring mounts for internal storage, Synology, and samba drives.
### `templates/`
This defines flake-based development environment templates for projects written in different programming languages, such as Elm and Haskell. This setup also makes use of `devshells` and is designed for developers who want to quickly bootstrap projects with a complete development environment using Nix for reproducibility and dependency management.
### `flake.nix`
This defines the core of the NixOS configuration using helper functions from `lib/`, which is organized as a flake-parts-based structure for better modularity:
1. `inputs`: Declares all external dependencies including, such as core Nix components (`nixpkgs`, `flake-parts`, `systems`) and user environment components (`home-manager`, `sops-nix`).
2. `outputs`: Uses flake-parts to organize system configurations for multiple machines (`mars`, `venus`, `deimos`, `charon`, and `ceres`) and shared modules (`core`, `mantle`, `crust`) imported across systems.
Each system imports specialized modules and user profiles based on its intended purpose and users, creating a flexible but consistent configuration framework across multiple machines.

View file

@ -74,11 +74,11 @@
{ config, ... }: { config, ... }:
{ {
nixosConfigurations = { nixosConfigurations = {
jupiter = inputs.self.lib.mkLinuxSystem [ mars = inputs.self.lib.mkLinuxSystem [
./systems/jupiter ./systems/mars
./profiles/user0 ./profiles/user0
./profiles/user1 ./profiles/user1
config.nixosModules.jupiter config.nixosModules.mars
config.nixosModules.core config.nixosModules.core
config.nixosModules.mantle config.nixosModules.mantle
config.nixosModules.crust config.nixosModules.crust
@ -89,10 +89,10 @@
inputs.sops-nix.nixosModules.sops inputs.sops-nix.nixosModules.sops
inputs.nixvim.nixosModules.nixvim inputs.nixvim.nixosModules.nixvim
]; ];
saturn = inputs.self.lib.mkLinuxSystem [ venus = inputs.self.lib.mkLinuxSystem [
./systems/saturn ./systems/venus
./profiles/user2 ./profiles/user2
config.nixosModules.saturn config.nixosModules.venus
config.nixosModules.core config.nixosModules.core
config.nixosModules.mantle config.nixosModules.mantle
config.nixosModules.crust config.nixosModules.crust
@ -100,11 +100,11 @@
inputs.lix-module.nixosModules.default inputs.lix-module.nixosModules.default
inputs.sops-nix.nixosModules.sops inputs.sops-nix.nixosModules.sops
]; ];
ganymede = inputs.self.lib.mkLinuxSystem [ deimos = inputs.self.lib.mkLinuxSystem [
./systems/ganymede ./systems/deimos
./profiles/user0 ./profiles/user0
./profiles/user1 ./profiles/user1
config.nixosModules.ganymede config.nixosModules.deimos
config.nixosModules.core config.nixosModules.core
config.nixosModules.mantle config.nixosModules.mantle
config.nixosModules.crust config.nixosModules.crust
@ -113,10 +113,10 @@
inputs.nur.modules.nixos.default inputs.nur.modules.nixos.default
inputs.sops-nix.nixosModules.sops inputs.sops-nix.nixosModules.sops
]; ];
callisto = inputs.self.lib.mkLinuxSystem [ charon = inputs.self.lib.mkLinuxSystem [
./systems/callisto ./systems/charon
./profiles/user1 ./profiles/user1
config.nixosModules.callisto config.nixosModules.charon
config.nixosModules.core config.nixosModules.core
config.nixosModules.crust config.nixosModules.crust
inputs.home-manager.nixosModules.home-manager inputs.home-manager.nixosModules.home-manager

View file

@ -5,8 +5,8 @@ let
; ;
in in
{ {
label = "Callisto"; label = "Charon";
name = "callisto"; name = "charon";
sync = { sync = {
address0 = ""; address0 = "";
}; };

View file

@ -5,8 +5,8 @@ let
; ;
in in
{ {
label = "Ganymede"; label = "Deimos";
name = "ganymede"; name = "deimos";
sync = { sync = {
address0 = ""; address0 = "";
}; };

View file

@ -6,8 +6,8 @@ let
; ;
in in
{ {
label = "Jupiter"; label = "Mars";
name = "jupiter"; name = "mars";
sync = { sync = {
address0 = ""; address0 = "";
}; };

View file

@ -11,7 +11,7 @@ let
user0Name = "Nick"; user0Name = "Nick";
user1Name = "Garnet"; user1Name = "Garnet";
synologyName = "synology"; synologyName = "synology";
synologyIP = "192.168.50.209"; synologyIP = "192.168.50.210";
in in
{ {
label = "Synology"; label = "Synology";

View file

@ -1,16 +0,0 @@
{ devicesFunctions }:
let
inherit (devicesFunctions)
dummy
;
in
{
name = "tablet";
label = dummy;
sync = {
address0 = "I2ZSCZU-T4JMUJJ-XCUQ3MY-G5EUFZ5-KRG2DRY-XIBJZZM-FQW3UMY-CBCTUQU";
};
ip = {
address0 = "192.168.50.189";
};
}

View file

@ -8,8 +8,8 @@ let
in in
{ {
label = "Saturn"; label = "Venus";
name = "saturn"; name = "venus";
ip = { ip = {
address0 = "192.168.58.104"; address0 = "192.168.58.104";
}; };

View file

@ -0,0 +1,11 @@
{
pkgs,
...
}:
{
home.packages = builtins.attrValues {
inherit (pkgs)
usbutils
;
};
}

View file

@ -7,16 +7,16 @@ in
flake.homeModules = flake.homeModules =
let let
inherit (config.machines.devices) inherit (config.machines.devices)
callisto charon
jupiter mars
saturn venus
ganymede deimos
ceres ceres
; ;
inherit (config.people) user0 user1 user2; inherit (config.people) user0 user1 user2;
in in
{ {
"${jupiter.name}-${user0}" = { "${mars.name}-${user0}" = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
cli cli
@ -52,10 +52,11 @@ in
hypr hypr
wayland wayland
theming theming
polychromatic
; ;
}; };
}; };
"${jupiter.name}-${user1}" = { "${mars.name}-${user1}" = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
cli cli
@ -76,7 +77,7 @@ in
; ;
}; };
}; };
"${saturn.name}-${user2}" = { "${venus.name}-${user2}" = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
cli cli
@ -106,7 +107,7 @@ in
; ;
}; };
}; };
"${ganymede.name}-${user0}" = { "${deimos.name}-${user0}" = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
cli cli
@ -123,7 +124,7 @@ in
; ;
}; };
}; };
"${ganymede.name}-${user1}" = { "${deimos.name}-${user1}" = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
cli cli
@ -144,7 +145,7 @@ in
; ;
}; };
}; };
"${callisto.name}-${user1}" = { "${charon.name}-${user1}" = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
cli cli

View file

@ -32,7 +32,7 @@
"floorp.browser.tabs.openNewTabPosition" = 1; "floorp.browser.tabs.openNewTabPosition" = 1;
"services.sync.prefs.sync.floorp.browser.note.memos" = false; "services.sync.prefs.sync.floorp.browser.note.memos" = false;
"floorp.disable.fullscreen.notification" = true; "floorp.disable.fullscreen.notification" = true;
"floorp.browser.user.interface" = 8; "floorp.browser.user.interface" = 1;
"browser.newtabpage.activity-stream.floorp.background.type" = 0; "browser.newtabpage.activity-stream.floorp.background.type" = 0;
"browser.startup.homepage" = "chrome://browser/content/blanktab.html"; "browser.startup.homepage" = "chrome://browser/content/blanktab.html";
"browser.newtabpage.enabled" = false; "browser.newtabpage.enabled" = false;

View file

@ -93,3 +93,78 @@
visibility: visible !important; visibility: visible !important;
opacity: 1 !important; opacity: 1 !important;
} }
/* One-Line Tweak */
:root {
--navbarWidth: clamp(300px, 30vw, 30vw);
--animationSpeed: 0.15s;
}
/* Oneline tweak */
#TabsToolbar {
margin-left: var(--navbarWidth) !important;
}
#nav-bar {
margin-right: calc(100vw - var(--navbarWidth)) !important;
}
#urlbar-container {
min-width: 0px !important;
}
:root[uidensity="compact"] #nav-bar {
margin-top: -37px !important;
height: 37px !important;
}
:root:not([uidensity="compact"]):not([uidensity="touch"]) #nav-bar {
margin-top: -44px !important;
height: 44px !important;
}
:root[uidensity="touch"] #nav-bar {
margin-top: -49px !important;
height: 49px !important;
}
/* Dragging space */
:root[sizemode="maximized"] #TabsToolbar {
margin-top: 1px;
}
#TabsToolbar {
margin-top: 5px;
}
/* Simplifying interface */
#nav-bar {
background: none !important;
box-shadow: none !important;
}
#navigator-toolbox {
border: none !important;
}
.titlebar-spacer {
display: none !important;
}
#urlbar-background {
border: none !important;
}
#urlbar:not(:hover):not([breakout][breakout-extend])>#urlbar-background {
box-shadow: none !important;
background: none !important;
}
/* Add tab width constraints */
.tabbrowser-tab {
min-width: 80px !important;
max-width: 150px !important;
}

View file

@ -0,0 +1,11 @@
{
pkgs,
...
}:
{
home.packages = builtins.attrValues {
inherit (pkgs)
polychromatic
;
};
}

View file

@ -43,7 +43,7 @@ let
"PageUp, exec, playerctl next" "PageUp, exec, playerctl next"
"PageDown, exec, playerctl previous" "PageDown, exec, playerctl previous"
"Home, exec, playerctl play-pause" "Home, exec, playerctl play-pause"
"Space, workspace, previous" "Space, exec, rm -r /home/$USER/.cache/tofi* ; tofi-drun"
]; ];
superShiftBinds = builtins.map (x: "SUPER SHIFT, " + x) [ superShiftBinds = builtins.map (x: "SUPER SHIFT, " + x) [
@ -57,15 +57,14 @@ let
"T, exec, ghostty" "T, exec, ghostty"
"S, exec, flameshot gui" "S, exec, flameshot gui"
"period, exec, emote" "period, exec, emote"
"Space, exec, rm -r /home/$USER/.cache/tofi* ; tofi-drun"
"Tab, fullscreen, 0" "Tab, fullscreen, 0"
"Backspace, layoutmsg, togglesplit" "Backspace, layoutmsg, togglesplit"
"P, pin, enable" "P, pin, enable"
"F, togglefloating" "F, togglefloating"
# "Print, exec, grim -g \"$(slurp)\"" # "Print, exec, grim -g \"$(slurp)\""
# Utility # Utility
"End, exec, hyprctl dispatch exit" "End, exec, shutdown now"
"Insert, exec, reboot now" "Insert, exec, systemctl reboot"
"Home, exec, swaylock" "Home, exec, swaylock"
]; ];
superCtrlBinds = builtins.map (x: "SUPER CTRL, " + x) [ superCtrlBinds = builtins.map (x: "SUPER CTRL, " + x) [

View file

@ -105,8 +105,8 @@ in
tooltip = false; tooltip = false;
format-muted = " Muted"; format-muted = " Muted";
on-click = "easyeffects"; on-click = "easyeffects";
on-scroll-up = "wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+"; on-scroll-up = "pactl set-sink-volume alsa_output.usb-Focusrite_Scarlett_2i2_USB_Y818KFJ0C671CE-00.HiFi__Line1__sink +5% ; pamixer -i 5";
on-scroll-down = "wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-"; on-scroll-down = "pactl set-sink-volume alsa_output.usb-Focusrite_Scarlett_2i2_USB_Y818KFJ0C671CE-00.HiFi__Line1__sink -5% ; pamixer -d 5";
scroll-step = 5; scroll-step = 5;
format-icons = { format-icons = {
headphone = ""; headphone = "";

View file

@ -3,7 +3,7 @@
enable = true; enable = true;
settings = { settings = {
"default" = { "default" = {
path = "~/Files/Projects/dotfiles/home/modules/gui/desktop/wayland/wpaperd/wallpaper"; path = "~/Files/Projects/dotfiles/modules/home/gui/desktop/wayland/wpaperd/wallpaper";
apply-shadow = true; apply-shadow = true;
duration = "1m"; duration = "1m";
sorting = "random"; sorting = "random";

View file

@ -9,10 +9,10 @@ let
devices devices
; ;
hostname = config.networking.hostName; hostname = config.networking.hostName;
jupiter = devices.jupiter.name; mars = devices.mars.name;
ceres = devices.ceres.name; ceres = devices.ceres.name;
saturn = devices.saturn.names; venus = devices.venus.names;
callisto = devices.callisto.name; charon = devices.charon.name;
in in
{ {
security = { security = {
@ -24,13 +24,13 @@ in
noPass = true; noPass = true;
users = [ users = [
( (
if hostname == jupiter then if hostname == mars then
user0 user0
else if hostname == ceres then else if hostname == ceres then
user0 user0
else if hostname == callisto then else if hostname == charon then
user1 user1
else if hostname == saturn then else if hostname == venus then
user2 user2
else else
"" ""

View file

@ -16,24 +16,24 @@ let
devices devices
; ;
hostname = config.networking.hostName; hostname = config.networking.hostName;
jupiter = devices.jupiter.name; mars = devices.mars.name;
ceres = devices.ceres.name; ceres = devices.ceres.name;
saturn = devices.saturn.name; venus = devices.venus.name;
callisto = devices.callisto.name; charon = devices.charon.name;
userLogic = userLogic =
if hostname == jupiter then if hostname == mars then
user0 user0
else if hostname == ceres then else if hostname == ceres then
user0 user0
else if hostname == saturn then else if hostname == venus then
user2 user2
else else
""; "";
in in
{ {
users.users = users.users =
if hostname == callisto then if hostname == charon then
{ } { }
else else
{ {

View file

@ -4,7 +4,7 @@ let
in in
{ {
flake.nixosModules = { flake.nixosModules = {
jupiter = { mars = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
mullvad mullvad
@ -17,7 +17,7 @@ in
}; };
}; };
saturn = { venus = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
plasma plasma
@ -27,7 +27,7 @@ in
}; };
}; };
ganymede = { deimos = {
imports = builtins.attrValues { imports = builtins.attrValues {
inherit (modules) inherit (modules)
gnome gnome

View file

@ -4,9 +4,22 @@
adb.enable = true; adb.enable = true;
droidcam.enable = true; droidcam.enable = true;
}; };
services.udev.packages = builtins.attrValues { services.udev = {
inherit (pkgs) enable = true;
android-udev-rules packages = builtins.attrValues {
; inherit (pkgs)
android-udev-rules
;
};
extraRules = ''
# Amazon Fire Tablet
SUBSYSTEM=="usb", ATTR{idVendor}=="1949", ATTR{idProduct}=="0632", MODE="0666", GROUP="adbusers"
SUBSYSTEM=="usb", ATTR{idVendor}=="1949", ATTR{idProduct}=="0632", SYMLINK+="android_adb"
SUBSYSTEM=="usb", ATTR{idVendor}=="1949", ATTR{idProduct}=="0632", SYMLINK+="android_fastboot"
# General Android rules
SUBSYSTEM=="usb", ENV{DEVTYPE}=="usb_device", MODE="0666"
SUBSYSTEM=="usb", ATTR{idVendor}=="1949", MODE="0666", GROUP="adbusers"
'';
}; };
} }

View file

@ -7,19 +7,6 @@
alsa.support32Bit = true; alsa.support32Bit = true;
pulse.enable = true; pulse.enable = true;
jack.enable = true; jack.enable = true;
wireplumber.extraConfig.bluetoothEnhancements = {
"monitor.bluez.properties" = {
"bluez5.enable-sbc-xq" = true;
"bluez5.enable-msbc" = true;
"bluez5.enable-hw-volume" = true;
"bluez5.roles" = [
"hsp_hs"
"hsp_ag"
"hfp_hf"
"hfp_ag"
];
};
};
}; };
pulseaudio.enable = false; pulseaudio.enable = false;
}; };

View file

@ -0,0 +1,3 @@
{
hardware.openrazer.enable = true;
}

View file

@ -6,7 +6,7 @@
}: }:
let let
inherit (flake.config.machines.devices) inherit (flake.config.machines.devices)
jupiter mars
ceres ceres
; ;
inherit (flake.config.services.instances) inherit (flake.config.services.instances)
@ -63,7 +63,7 @@ in
user = service.name; user = service.name;
} }
// ( // (
if hostname == jupiter.name then if hostname == mars.name then
{ {
models = service.paths.path1; models = service.paths.path1;
# acceleration = "rocm"; # acceleration = "rocm";
@ -98,7 +98,7 @@ in
systemd.tmpfiles.rules = [ systemd.tmpfiles.rules = [
( (
if hostname == jupiter.name then if hostname == mars.name then
"Z ${service.paths.path1} 0777 ${service.name} ${service.name} -" "Z ${service.paths.path1} 0777 ${service.name} ${service.name} -"
else else
"Z ${service.paths.path0} 0755 ${service.name} ${service.name} -" "Z ${service.paths.path0} 0755 ${service.name} ${service.name} -"

View file

@ -39,14 +39,6 @@ in
]; ];
id = phone.sync.address0; id = phone.sync.address0;
}; };
${tablet.name} = {
autoAcceptFolders = true;
name = tablet.name;
addresses = [
"tcp://${tablet.ip.address0}:${toString service.ports.port2}"
];
id = tablet.sync.address0;
};
}; };
}; };
}; };

View file

@ -8,17 +8,17 @@ let
devices devices
; ;
hostname = config.networking.hostName; hostname = config.networking.hostName;
jupiter = devices.jupiter.name; mars = devices.mars.name;
ceres = devices.ceres.name; ceres = devices.ceres.name;
saturn = devices.saturn.name; venus = devices.venus.name;
callisto = devices.callisto.name; charon = devices.charon.name;
userLogic = userLogic =
if hostname == jupiter then if hostname == mars then
user0 user0
else if hostname == ceres then else if hostname == ceres then
user0 user0
else if hostname == saturn then else if hostname == venus then
user2 user2
else else
""; "";
@ -32,7 +32,7 @@ in
generateKey = false; generateKey = false;
}; };
secrets = secrets =
if hostname == callisto then if hostname == charon then
{ } { }
else else
{ {

View file

@ -31,6 +31,7 @@ in
"networkmanager" "networkmanager"
"nextcloud" "nextcloud"
"ollama" "ollama"
"plugdev"
"postgres" "postgres"
"redis-mastodon" "redis-mastodon"
"samba" "samba"

View file

@ -5,7 +5,7 @@ vpnoff:
sudo protonvpn d sudo protonvpn d
rebuild: rebuild:
nixos-rebuild switch --use-remote-sudo --flake ~/Files/Projects/dotfiles#jupiter --show-trace nixos-rebuild switch --use-remote-sudo --flake ~/Files/Projects/dotfiles#mars --show-trace
elm: elm:
cd ~/Files/Projects/website/frontend; elm-land server cd ~/Files/Projects/website/frontend; elm-land server

View file

@ -5,7 +5,7 @@
}: }:
let let
inherit (flake.config.people) user1; inherit (flake.config.people) user1;
inherit (flake.config.machines.devices) callisto; inherit (flake.config.machines.devices) charon;
in in
{ {
fileSystems = { fileSystems = {
@ -16,7 +16,7 @@ in
"/boot" = { "/boot" = {
device = "/dev/disk/by-uuid/1703-D452"; device = "/dev/disk/by-uuid/1703-D452";
fsType = "vfat"; fsType = "vfat";
options = callisto.boot.options; options = charon.boot.options;
}; };
}; };

View file

@ -5,12 +5,12 @@
}: }:
let let
inherit (flake.config.machines.devices) inherit (flake.config.machines.devices)
callisto charon
; ;
in in
{ {
networking = { networking = {
hostName = callisto.name; hostName = charon.name;
networkmanager.enable = true; networkmanager.enable = true;
nftables.enable = true; nftables.enable = true;
useDHCP = lib.mkDefault true; useDHCP = lib.mkDefault true;

View file

@ -9,7 +9,7 @@ let
user1 user1
; ;
inherit (flake.config.machines.devices) inherit (flake.config.machines.devices)
ganymede deimos
synology synology
ceres ceres
; ;
@ -63,7 +63,7 @@ in
"/boot" = { "/boot" = {
device = "/dev/disk/by-uuid/C506-9E18"; device = "/dev/disk/by-uuid/C506-9E18";
fsType = "vfat"; fsType = "vfat";
options = ganymede.boot.options; options = deimos.boot.options;
}; };
} }
// (builtins.listToAttrs (map synologyMounts synologyDrives)) // (builtins.listToAttrs (map synologyMounts synologyDrives))

View file

@ -5,12 +5,12 @@
}: }:
let let
inherit (flake.config.machines.devices) inherit (flake.config.machines.devices)
ganymede deimos
; ;
in in
{ {
networking = { networking = {
hostName = ganymede.name; hostName = deimos.name;
networkmanager.enable = true; networkmanager.enable = true;
nftables.enable = true; nftables.enable = true;
useDHCP = lib.mkDefault true; useDHCP = lib.mkDefault true;

View file

@ -2,7 +2,7 @@
let let
configPath = ./config; configPath = ./config;
jupiterImports = deimosImports =
let let
files = builtins.attrNames (builtins.readDir configPath); files = builtins.attrNames (builtins.readDir configPath);
in in
@ -11,7 +11,7 @@ let
); );
in in
{ {
imports = jupiterImports; imports = deimosImports;
nixpkgs.hostPlatform = lib.mkForce "x86_64-linux"; nixpkgs.hostPlatform = lib.mkForce "x86_64-linux";
system.stateVersion = lib.mkForce "24.05"; system.stateVersion = lib.mkForce "24.05";
} }

View file

@ -9,7 +9,7 @@ let
user1 user1
; ;
inherit (flake.config.machines.devices) inherit (flake.config.machines.devices)
jupiter mars
ceres ceres
synology synology
; ;
@ -50,11 +50,11 @@ in
}; };
storageMounts = storageDrive: { storageMounts = storageDrive: {
name = "${jupiter.${storageDrive}.mount}"; name = "${mars.${storageDrive}.mount}";
value = { value = {
device = jupiter.${storageDrive}.device; device = mars.${storageDrive}.device;
fsType = "ext4"; fsType = "ext4";
options = jupiter.${storageDrive}.options; options = mars.${storageDrive}.options;
}; };
}; };
@ -77,7 +77,7 @@ in
"/boot" = { "/boot" = {
device = "/dev/disk/by-uuid/F095-17B7"; device = "/dev/disk/by-uuid/F095-17B7";
fsType = "vfat"; fsType = "vfat";
options = jupiter.boot.options; options = mars.boot.options;
}; };
} }
// (builtins.listToAttrs (map synologyMounts synologyDrives)) // (builtins.listToAttrs (map synologyMounts synologyDrives))
@ -91,8 +91,8 @@ in
systemd.tmpfiles.rules = [ systemd.tmpfiles.rules = [
"Z ${config.home-manager.users.${user0}.home.homeDirectory} 0755 ${user0} users -" "Z ${config.home-manager.users.${user0}.home.homeDirectory} 0755 ${user0} users -"
"Z ${config.home-manager.users.${user1}.home.homeDirectory} 0755 ${user1} users -" "Z ${config.home-manager.users.${user1}.home.homeDirectory} 0755 ${user1} users -"
"Z ${jupiter.storage0.mount} 0755 ${user0} users -" "Z ${mars.storage0.mount} 0755 ${user0} users -"
"Z ${jupiter.storage1.mount} 0755 ${user0} users -" "Z ${mars.storage1.mount} 0755 ${user0} users -"
]; ];
services.udisks2.enable = true; services.udisks2.enable = true;

View file

@ -5,12 +5,12 @@
}: }:
let let
inherit (flake.config.machines.devices) inherit (flake.config.machines.devices)
jupiter mars
; ;
in in
{ {
networking = { networking = {
hostName = jupiter.name; hostName = mars.name;
networkmanager.enable = true; networkmanager.enable = true;
nftables.enable = true; nftables.enable = true;
useDHCP = lib.mkDefault true; useDHCP = lib.mkDefault true;
@ -22,7 +22,8 @@ in
2234 # Soulseek 2234 # Soulseek
3131 # Deskreen 3131 # Deskreen
1234 # Elm-land server 1234 # Elm-land server
55473 5037 # ADB Server
52006
]; ];
}; };
}; };

View file

@ -2,7 +2,7 @@
let let
configPath = ./config; configPath = ./config;
ganymedeImports = marsImports =
let let
files = builtins.attrNames (builtins.readDir configPath); files = builtins.attrNames (builtins.readDir configPath);
in in
@ -11,7 +11,7 @@ let
); );
in in
{ {
imports = ganymedeImports; imports = marsImports;
nixpkgs.hostPlatform = lib.mkForce "x86_64-linux"; nixpkgs.hostPlatform = lib.mkForce "x86_64-linux";
system.stateVersion = lib.mkForce "24.05"; system.stateVersion = lib.mkForce "24.05";
} }

View file

@ -5,7 +5,7 @@
}: }:
let let
inherit (flake.config.people) user2; inherit (flake.config.people) user2;
inherit (flake.config.machines.devices) saturn; inherit (flake.config.machines.devices) venus;
in in
{ {
imports = [ ]; imports = [ ];
@ -18,11 +18,11 @@ in
]; ];
storageMounts = storage: { storageMounts = storage: {
name = "${saturn.${storage}.mount}"; name = "${venus.${storage}.mount}";
value = { value = {
device = saturn.${storage}.device; device = venus.${storage}.device;
fsType = "ext4"; fsType = "ext4";
options = saturn.${storage}.options; options = venus.${storage}.options;
}; };
}; };
in in
@ -34,7 +34,7 @@ in
"/boot" = { "/boot" = {
device = "/dev/disk/by-uuid/22BD-5A25"; device = "/dev/disk/by-uuid/22BD-5A25";
fsType = "vfat"; fsType = "vfat";
options = saturn.boot.options; options = venus.boot.options;
}; };
} }
// (builtins.listToAttrs (map storageMounts storageDrives)); // (builtins.listToAttrs (map storageMounts storageDrives));
@ -45,8 +45,8 @@ in
systemd.tmpfiles.rules = [ systemd.tmpfiles.rules = [
"Z ${config.home-manager.users.${user2}.home.homeDirectory} 0755 ${user2} users -" "Z ${config.home-manager.users.${user2}.home.homeDirectory} 0755 ${user2} users -"
"Z ${saturn.storage0.mount} 0755 ${user2} users -" "Z ${venus.storage0.mount} 0755 ${user2} users -"
"Z ${saturn.storage1.mount} 0755 ${user2} users -" "Z ${venus.storage1.mount} 0755 ${user2} users -"
]; ];
services.udisks2.enable = true; services.udisks2.enable = true;

View file

@ -4,11 +4,11 @@
... ...
}: }:
let let
inherit (flake.config.machines.devices) saturn; inherit (flake.config.machines.devices) venus;
in in
{ {
networking = { networking = {
hostName = saturn.name; hostName = venus.name;
networkmanager.enable = true; networkmanager.enable = true;
useDHCP = lib.mkDefault true; useDHCP = lib.mkDefault true;
firewall = { firewall = {

View file

@ -5,7 +5,7 @@
let let
configPath = ./config; configPath = ./config;
saturnImports = venusImports =
let let
files = builtins.attrNames (builtins.readDir configPath); files = builtins.attrNames (builtins.readDir configPath);
in in
@ -14,7 +14,7 @@ let
); );
in in
{ {
imports = saturnImports; imports = venusImports;
nixpkgs.hostPlatform = lib.mkForce "x86_64-linux"; nixpkgs.hostPlatform = lib.mkForce "x86_64-linux";
system.stateVersion = lib.mkForce "24.05"; system.stateVersion = lib.mkForce "24.05";
} }