mirror of
https://gitlab.com/upRootNutrition/dotfiles.git
synced 2025-06-15 17:45:12 -05:00
feat: added phobos
This commit is contained in:
parent
ca0b96d147
commit
8549ffce2e
13 changed files with 290 additions and 1 deletions
12
flake.nix
12
flake.nix
|
@ -110,6 +110,18 @@
|
||||||
inputs.nur.modules.nixos.default
|
inputs.nur.modules.nixos.default
|
||||||
inputs.sops-nix.nixosModules.sops
|
inputs.sops-nix.nixosModules.sops
|
||||||
];
|
];
|
||||||
|
phobos = inputs.self.lib.mkLinuxSystem [
|
||||||
|
./systems/phobos
|
||||||
|
./profiles/user0
|
||||||
|
config.nixosModules.phobos
|
||||||
|
config.nixosModules.core
|
||||||
|
config.nixosModules.mantle
|
||||||
|
config.nixosModules.crust
|
||||||
|
inputs.home-manager.nixosModules.home-manager
|
||||||
|
inputs.lix-module.nixosModules.default
|
||||||
|
inputs.nur.modules.nixos.default
|
||||||
|
inputs.sops-nix.nixosModules.sops
|
||||||
|
];
|
||||||
charon = inputs.self.lib.mkLinuxSystem [
|
charon = inputs.self.lib.mkLinuxSystem [
|
||||||
./systems/charon
|
./systems/charon
|
||||||
./profiles/user1
|
./profiles/user1
|
||||||
|
|
20
modules/config/devices/config/phobos.nix
Normal file
20
modules/config/devices/config/phobos.nix
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
{ devicesFunctions }:
|
||||||
|
let
|
||||||
|
inherit (devicesFunctions)
|
||||||
|
ownerWriteOthersReadMask
|
||||||
|
phobosIP
|
||||||
|
;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
label = "Phobos";
|
||||||
|
name = "phobos";
|
||||||
|
sync = {
|
||||||
|
address0 = phobosIP;
|
||||||
|
};
|
||||||
|
ip = {
|
||||||
|
address0 = phobosIP;
|
||||||
|
};
|
||||||
|
boot = {
|
||||||
|
options = ownerWriteOthersReadMask;
|
||||||
|
};
|
||||||
|
}
|
|
@ -41,6 +41,7 @@ let
|
||||||
deimosIP = "192.168.50.142";
|
deimosIP = "192.168.50.142";
|
||||||
marsIP = "192.168.50.196";
|
marsIP = "192.168.50.196";
|
||||||
phoneIP = "192.168.50.243";
|
phoneIP = "192.168.50.243";
|
||||||
|
phobosIP = "192.168.50.180";
|
||||||
synologyIP = "192.168.50.209";
|
synologyIP = "192.168.50.209";
|
||||||
venusIP = "192.168.58.104";
|
venusIP = "192.168.58.104";
|
||||||
brotherIP = "192.168.50.195";
|
brotherIP = "192.168.50.195";
|
||||||
|
|
|
@ -12,6 +12,7 @@ in
|
||||||
venus
|
venus
|
||||||
deimos
|
deimos
|
||||||
ceres
|
ceres
|
||||||
|
phobos
|
||||||
;
|
;
|
||||||
inherit (config.people)
|
inherit (config.people)
|
||||||
user0
|
user0
|
||||||
|
@ -237,6 +238,35 @@ in
|
||||||
;
|
;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
"${phobos.name}-${user0}" = {
|
||||||
|
imports = builtins.attrValues {
|
||||||
|
inherit (modules)
|
||||||
|
cli
|
||||||
|
floorp
|
||||||
|
tor
|
||||||
|
ghostty
|
||||||
|
zed
|
||||||
|
feishin
|
||||||
|
obsidian
|
||||||
|
libreOffice
|
||||||
|
okular
|
||||||
|
imageViewing
|
||||||
|
mpv
|
||||||
|
vesktop
|
||||||
|
element
|
||||||
|
signal
|
||||||
|
bitwarden
|
||||||
|
emote
|
||||||
|
flameshot
|
||||||
|
gnomeCalculator
|
||||||
|
systemMonitor
|
||||||
|
usbImager
|
||||||
|
virtManager
|
||||||
|
theming
|
||||||
|
espanso
|
||||||
|
;
|
||||||
|
};
|
||||||
|
};
|
||||||
"${charon.name}-${user1}" = {
|
"${charon.name}-${user1}" = {
|
||||||
imports = builtins.attrValues {
|
imports = builtins.attrValues {
|
||||||
inherit (modules)
|
inherit (modules)
|
||||||
|
|
|
@ -14,6 +14,19 @@
|
||||||
];
|
];
|
||||||
keyword = "Pub";
|
keyword = "Pub";
|
||||||
}
|
}
|
||||||
|
{
|
||||||
|
name = "Cochrane";
|
||||||
|
url = "https://www.cochranelibrary.com/";
|
||||||
|
tags = [
|
||||||
|
"cochrane"
|
||||||
|
"collaboration"
|
||||||
|
"library"
|
||||||
|
"science"
|
||||||
|
"research"
|
||||||
|
"academic"
|
||||||
|
];
|
||||||
|
keyword = "Coch";
|
||||||
|
}
|
||||||
{
|
{
|
||||||
name = "Sci-Hub";
|
name = "Sci-Hub";
|
||||||
url = "https://sci-hub.ee";
|
url = "https://sci-hub.ee";
|
||||||
|
@ -43,12 +56,24 @@
|
||||||
name = "Zotero Bibliography";
|
name = "Zotero Bibliography";
|
||||||
url = "https://zbib.org";
|
url = "https://zbib.org";
|
||||||
tags = [
|
tags = [
|
||||||
"votero"
|
"zotero"
|
||||||
"bibliography"
|
"bibliography"
|
||||||
"bib"
|
"bib"
|
||||||
"zbib"
|
"zbib"
|
||||||
];
|
];
|
||||||
keyword = "Bib";
|
keyword = "Bib";
|
||||||
}
|
}
|
||||||
|
{
|
||||||
|
name = "Zotero Library";
|
||||||
|
url = "https://www.zotero.org/uprootnutrition/library";
|
||||||
|
tags = [
|
||||||
|
"zotero"
|
||||||
|
"library"
|
||||||
|
"science"
|
||||||
|
"research"
|
||||||
|
"academic"
|
||||||
|
];
|
||||||
|
keyword = "Zot";
|
||||||
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,17 @@ in
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
phobos = {
|
||||||
|
imports = builtins.attrValues {
|
||||||
|
inherit (modules)
|
||||||
|
plasma
|
||||||
|
sddm
|
||||||
|
xserver
|
||||||
|
wireGuard
|
||||||
|
;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
charon = {
|
charon = {
|
||||||
imports = builtins.attrValues {
|
imports = builtins.attrValues {
|
||||||
inherit (modules)
|
inherit (modules)
|
||||||
|
|
43
systems/phobos/config/boot.nix
Executable file
43
systems/phobos/config/boot.nix
Executable file
|
@ -0,0 +1,43 @@
|
||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
boot = {
|
||||||
|
extraModulePackages = [
|
||||||
|
config.boot.kernelPackages.v4l2loopback.out
|
||||||
|
];
|
||||||
|
supportedFilesystems = [
|
||||||
|
"ntfs"
|
||||||
|
];
|
||||||
|
initrd = {
|
||||||
|
availableKernelModules = [
|
||||||
|
"nvme"
|
||||||
|
"ahci"
|
||||||
|
"xhci_pci"
|
||||||
|
"usb_storage"
|
||||||
|
"usbhid"
|
||||||
|
"sd_mod"
|
||||||
|
];
|
||||||
|
kernelModules = [
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
kernelModules = [
|
||||||
|
"kvm-amd"
|
||||||
|
"vfio-pci"
|
||||||
|
"v4l2loopback"
|
||||||
|
];
|
||||||
|
|
||||||
|
kernelPackages = pkgs.linuxPackages_latest;
|
||||||
|
|
||||||
|
loader = {
|
||||||
|
efi = {
|
||||||
|
canTouchEfiVariables = true;
|
||||||
|
efiSysMountPoint = "/boot";
|
||||||
|
};
|
||||||
|
systemd-boot.enable = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
38
systems/phobos/config/filesystem.nix
Executable file
38
systems/phobos/config/filesystem.nix
Executable file
|
@ -0,0 +1,38 @@
|
||||||
|
{
|
||||||
|
flake,
|
||||||
|
config,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (flake.config.people)
|
||||||
|
user0
|
||||||
|
user1
|
||||||
|
;
|
||||||
|
inherit (flake.config.machines.devices)
|
||||||
|
phobos
|
||||||
|
;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
fileSystems = {
|
||||||
|
"/" = {
|
||||||
|
device = "/dev/disk/by-uuid/c9a82c93-1da4-4cd1-a1fa-26483271a2bb";
|
||||||
|
fsType = "ext4";
|
||||||
|
};
|
||||||
|
"/boot" = {
|
||||||
|
device = "/dev/disk/by-uuid/71CA-765A";
|
||||||
|
fsType = "vfat";
|
||||||
|
options = phobos.boot.options;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
swapDevices = [
|
||||||
|
{ device = "/dev/disk/by-uuid/74007bf1-6e2f-425e-99fa-d35990f4ea37"; }
|
||||||
|
];
|
||||||
|
|
||||||
|
systemd.tmpfiles.rules = [
|
||||||
|
"Z ${config.home-manager.users.${user0}.home.homeDirectory} 0755 ${user0} users -"
|
||||||
|
"Z ${config.home-manager.users.${user1}.home.homeDirectory} 0755 ${user1} users -"
|
||||||
|
];
|
||||||
|
|
||||||
|
services.udisks2.enable = true;
|
||||||
|
}
|
24
systems/phobos/config/graphics.nix
Executable file
24
systems/phobos/config/graphics.nix
Executable file
|
@ -0,0 +1,24 @@
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
hardware = {
|
||||||
|
graphics = {
|
||||||
|
enable = true;
|
||||||
|
extraPackages = builtins.attrValues {
|
||||||
|
inherit (pkgs)
|
||||||
|
amdvlk
|
||||||
|
;
|
||||||
|
inherit (pkgs.rocmPackages.clr)
|
||||||
|
icd
|
||||||
|
;
|
||||||
|
};
|
||||||
|
extraPackages32 = builtins.attrValues {
|
||||||
|
inherit (pkgs.driversi686Linux)
|
||||||
|
amdvlk
|
||||||
|
;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
boot.initrd.kernelModules = [
|
||||||
|
"amdgpu"
|
||||||
|
];
|
||||||
|
}
|
15
systems/phobos/config/hardware.nix
Executable file
15
systems/phobos/config/hardware.nix
Executable file
|
@ -0,0 +1,15 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
hardware = {
|
||||||
|
firmware = [
|
||||||
|
pkgs.rtl8761b-firmware
|
||||||
|
];
|
||||||
|
enableAllFirmware = true;
|
||||||
|
cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
|
||||||
|
};
|
||||||
|
}
|
37
systems/phobos/config/networking.nix
Executable file
37
systems/phobos/config/networking.nix
Executable file
|
@ -0,0 +1,37 @@
|
||||||
|
{
|
||||||
|
lib,
|
||||||
|
flake,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
inherit (flake.config.machines.devices)
|
||||||
|
phobos
|
||||||
|
;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
networking = {
|
||||||
|
hostName = phobos.name;
|
||||||
|
networkmanager.enable = true;
|
||||||
|
nftables.enable = true;
|
||||||
|
useDHCP = lib.mkDefault true;
|
||||||
|
firewall = {
|
||||||
|
enable = true;
|
||||||
|
allowedTCPPorts = [
|
||||||
|
22 # SSH
|
||||||
|
55771
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
services = {
|
||||||
|
avahi = {
|
||||||
|
enable = true;
|
||||||
|
openFirewall = true;
|
||||||
|
nssmdns4 = true;
|
||||||
|
};
|
||||||
|
sshd.enable = true;
|
||||||
|
openssh = {
|
||||||
|
enable = true;
|
||||||
|
settings.PasswordAuthentication = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
16
systems/phobos/config/sops.nix
Executable file
16
systems/phobos/config/sops.nix
Executable file
|
@ -0,0 +1,16 @@
|
||||||
|
{
|
||||||
|
sops = {
|
||||||
|
secrets = {
|
||||||
|
"network/synology" = {
|
||||||
|
path = "/var/lib/secrets/synology";
|
||||||
|
owner = "root";
|
||||||
|
mode = "600";
|
||||||
|
};
|
||||||
|
"network/server" = {
|
||||||
|
path = "/var/lib/secrets/server";
|
||||||
|
owner = "root";
|
||||||
|
mode = "600";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
17
systems/phobos/default.nix
Executable file
17
systems/phobos/default.nix
Executable file
|
@ -0,0 +1,17 @@
|
||||||
|
{ lib, ... }:
|
||||||
|
let
|
||||||
|
configPath = ./config;
|
||||||
|
|
||||||
|
deimosImports =
|
||||||
|
let
|
||||||
|
files = builtins.attrNames (builtins.readDir configPath);
|
||||||
|
in
|
||||||
|
map (name: configPath + "/${name}") (
|
||||||
|
builtins.filter (name: builtins.match ".*\\.nix$" name != null) files
|
||||||
|
);
|
||||||
|
in
|
||||||
|
{
|
||||||
|
imports = deimosImports;
|
||||||
|
nixpkgs.hostPlatform = lib.mkForce "x86_64-linux";
|
||||||
|
system.stateVersion = lib.mkForce "24.05";
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue