system
This commit is contained in:
parent
836a7e0e2c
commit
c4eed0e32f
9 changed files with 205 additions and 0 deletions
9
system/audio.nix
Normal file
9
system/audio.nix
Normal file
|
|
@ -0,0 +1,9 @@
|
||||||
|
{...}: {
|
||||||
|
security.rtkit.enable = true;
|
||||||
|
services.pipewire = {
|
||||||
|
enable = true;
|
||||||
|
alsa.enable = true;
|
||||||
|
alsa.support32Bit = true;
|
||||||
|
pulse.enable = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
19
system/networking.nix
Normal file
19
system/networking.nix
Normal file
|
|
@ -0,0 +1,19 @@
|
||||||
|
{...}: {
|
||||||
|
networking.networkmanager = {
|
||||||
|
enable = true;
|
||||||
|
wifi.macAddress = "random";
|
||||||
|
ethernet.macAddress = "random";
|
||||||
|
};
|
||||||
|
|
||||||
|
networking.nftables = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
networking.firewall = {
|
||||||
|
enable = true;
|
||||||
|
allowedTCPPorts = [
|
||||||
|
22 # ssh
|
||||||
|
22000 # syncthing
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
||||||
13
system/nfs.nix
Normal file
13
system/nfs.nix
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
{ ... }: {
|
||||||
|
fileSystems."/mnt/nas" = {
|
||||||
|
device = "nixserver:/share";
|
||||||
|
fsType = "nfs";
|
||||||
|
options = [
|
||||||
|
"nfsvers=4.2"
|
||||||
|
"noauto"
|
||||||
|
"x-systemd.automount"
|
||||||
|
"x-systemd.idle-timeout=600"
|
||||||
|
"_netdev"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
||||||
15
system/nix.nix
Normal file
15
system/nix.nix
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
{...}: {
|
||||||
|
nix = {
|
||||||
|
gc = {
|
||||||
|
automatic = true;
|
||||||
|
dates = "05:30";
|
||||||
|
options = "--delete-older-than 7d";
|
||||||
|
};
|
||||||
|
settings = {
|
||||||
|
keep-outputs = true;
|
||||||
|
auto-optimise-store = true;
|
||||||
|
experimental-features = ["nix-command" "flakes"];
|
||||||
|
trusted-users = ["root" "@wheel"];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
60
system/persistence.nix
Normal file
60
system/persistence.nix
Normal file
|
|
@ -0,0 +1,60 @@
|
||||||
|
{impermanence, conf, lib, config, ...}: {
|
||||||
|
imports = [impermanence.nixosModule];
|
||||||
|
|
||||||
|
environment.persistence."/persist/data" = {
|
||||||
|
hideMounts = true;
|
||||||
|
directories = [
|
||||||
|
"/etc/NetworkManager/system-connections"
|
||||||
|
"/var/lib/bluetooth"
|
||||||
|
];
|
||||||
|
files = [];
|
||||||
|
|
||||||
|
users.lilith = {
|
||||||
|
directories = [
|
||||||
|
".config/syncthing"
|
||||||
|
".config/sops"
|
||||||
|
".config/keepassxc"
|
||||||
|
".config/obsidian"
|
||||||
|
".config/vesktop"
|
||||||
|
".gnupg"
|
||||||
|
".ssh"
|
||||||
|
|
||||||
|
".thunderbird"
|
||||||
|
".mozilla"
|
||||||
|
|
||||||
|
"nixos"
|
||||||
|
"sync"
|
||||||
|
"obsidian"
|
||||||
|
"code"
|
||||||
|
".keepass"
|
||||||
|
];
|
||||||
|
files = [];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.persistence."/persist/cache" = {
|
||||||
|
hideMounts = true;
|
||||||
|
directories = [
|
||||||
|
"/root/.cache/nix"
|
||||||
|
"/var/lib/btrfs"
|
||||||
|
"/var/lib/nixos"
|
||||||
|
"/var/lib/systemd/backlight"
|
||||||
|
"/var/lib/systemd/timers"
|
||||||
|
"/var/log"
|
||||||
|
];
|
||||||
|
files = [
|
||||||
|
"/etc/machine-id"
|
||||||
|
];
|
||||||
|
|
||||||
|
users.lilith = {
|
||||||
|
directories = [
|
||||||
|
".cache/nix"
|
||||||
|
".cache/keepassxc"
|
||||||
|
".cargo"
|
||||||
|
".local/state/wireplumber"
|
||||||
|
"tmp"
|
||||||
|
];
|
||||||
|
files = [];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
11
system/ssh.nix
Normal file
11
system/ssh.nix
Normal file
|
|
@ -0,0 +1,11 @@
|
||||||
|
{...}: {
|
||||||
|
networking.firewall.allowedTCPPorts = [22];
|
||||||
|
services.openssh = {
|
||||||
|
enable = true;
|
||||||
|
ports = [22];
|
||||||
|
settings = {
|
||||||
|
PermitRootLogin = "no";
|
||||||
|
PasswordAuthentication = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
5
system/steam.nix
Normal file
5
system/steam.nix
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
{...}: {
|
||||||
|
programs.steam.enable = true;
|
||||||
|
|
||||||
|
programs.steam.remotePlay.openFirewall = true;
|
||||||
|
}
|
||||||
49
system/syncthing.nix
Normal file
49
system/syncthing.nix
Normal file
|
|
@ -0,0 +1,49 @@
|
||||||
|
{ config, ...}: let
|
||||||
|
host = networking.hostName;
|
||||||
|
in {
|
||||||
|
|
||||||
|
sops.secrets."syncthing/key.pem" = {
|
||||||
|
sopsFile = ../hosts/${host}/secrets/default.yaml;
|
||||||
|
};
|
||||||
|
sops.secrets."syncthing/cert.pem" = {
|
||||||
|
sopsFile = ../hosts/${host}/secrets/default.yaml;
|
||||||
|
};
|
||||||
|
|
||||||
|
services.syncthing = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
user = lilith;
|
||||||
|
dataDir = "/home/lilith";
|
||||||
|
configDir = "/home/lilith/.config/syncthing";
|
||||||
|
|
||||||
|
overrideDevices = true;
|
||||||
|
overrideFolders = true;
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
key = config.sops.secrets."syncthing/key.pem".path;
|
||||||
|
cert = config.sops.secrets."syncthing/cert.pem".path;
|
||||||
|
|
||||||
|
devices = {
|
||||||
|
"phone" = {id = "C2CKYRP-72UNJRX-MUPZIUY-CCHQYGF-6T4NA6B-MO7AEZB-RSN5EAG-CN2JCAF";};
|
||||||
|
"nixserver" = {id = "DW6GTZ3-3JPAHLO-UEB3LBL-AWOX3BT-QPI7ODT-OZ6Q4YR-K3KK22C-5RY3XQZ";};
|
||||||
|
"lilith-pc" = {id = "37HHP4Q-NNQRQPQ-MVSIHAX-BK2A3GL-O6K4WXA-Y7ZQ5GZ-BY4UTFH-LG4HYAY";};
|
||||||
|
"lilith-pad" = {id = "GQJA6WA-G5YZZSN-4OOQMVE-JPIR22N-VFHPY4O-XMRG37D-DALH4R2-7DCTMQK";};
|
||||||
|
"lilith-old" = {id = "MSUZJ6K-4CIFE5D-ILO6FE4-SPRPTZI-VEWZQ7F-ECARCCF-2VLVMDQ-2HQUAAS";};
|
||||||
|
};
|
||||||
|
folders = {
|
||||||
|
"rdcj2-mfyb4" = {
|
||||||
|
path = "/home/lilith/sync";
|
||||||
|
devices = ["phone" "nixserver" "lilith-pad" "lilith-pc" "lilith-old"];
|
||||||
|
};
|
||||||
|
"sdpfs-2beqd" = {
|
||||||
|
path = "/home/lilith/.keepass";
|
||||||
|
devices = ["phone" "nixserver" "lilith-pad" "lilith-pc" "lilith-old"];
|
||||||
|
};
|
||||||
|
"7qim7-yzqpn" = {
|
||||||
|
path = "/home/lilith/obsidian";
|
||||||
|
devices = ["phone" "nixserver" "lilith-pad" "lilith-pc" "lilith-old"];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
24
system/wayland.nix
Normal file
24
system/wayland.nix
Normal file
|
|
@ -0,0 +1,24 @@
|
||||||
|
{...}: {
|
||||||
|
hardware.graphics.enable = true;
|
||||||
|
|
||||||
|
security.polkit.enable = true;
|
||||||
|
security.pam.services.hyprlock = {};
|
||||||
|
|
||||||
|
services.dbus.enable = true;
|
||||||
|
|
||||||
|
programs.hyprland.enable = true;
|
||||||
|
|
||||||
|
services.greetd = {
|
||||||
|
enable = true;
|
||||||
|
settings = {
|
||||||
|
default_session = {
|
||||||
|
user = "lilith";
|
||||||
|
command = "Hyprland";
|
||||||
|
};
|
||||||
|
initial_session = {
|
||||||
|
user = "lilith";
|
||||||
|
command = "Hyprland";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue