nixos/hosts/FredOS-Mediaserver.nix

81 lines
1.9 KiB
Nix
Raw Normal View History

2026-01-20 09:59:20 +00:00
{ config, pkgs, lib, ... }:
{
2026-01-20 14:35:20 +00:00
config = lib.mkIf (config.networking.hostName == "FredOS-Mediaserver") {
2026-01-20 14:42:21 +00:00
# Individual Data Disks
fileSystems."/mnt/disk1" = {
device = "/dev/disk/by-uuid/90ae3493-38c1-4473-b409-e9d99c3b315e";
fsType = "ext4";
};
fileSystems."/mnt/disk2" = {
device = "/dev/disk/by-uuid/7145223e-f285-424a-a114-cb0b1b64e068";
fsType = "ext4";
};
2026-01-20 09:59:20 +00:00
2026-01-20 14:42:21 +00:00
fileSystems."/mnt/disk3" = {
device = "/dev/disk/by-uuid/58cecfd5-2fd7-4c4b-b3a1-0bf5e9d0beab";
fsType = "ext4";
};
2026-01-20 09:59:20 +00:00
2026-03-30 21:34:12 +01:00
#fileSystems."/mnt/disk4" = {
# device = "/dev/disk/by-uuid/317660ef-bd75-4fa4-bd20-f96a3926bf7b";
# fsType = "ext4";
#};
2026-03-30 20:49:30 +01:00
2026-01-20 14:42:21 +00:00
# The Combined MergerFS Pool
fileSystems."/mnt/storage" = {
2026-03-30 20:49:30 +01:00
device = "/mnt/disk1:/mnt/disk2:/mnt/disk3:/mnt/disk4";
2026-01-20 14:42:21 +00:00
fsType = "fuse.mergerfs";
options = [
"defaults"
"allow_other"
"use_ino"
"cache.files=partial"
"dropcacheonclose=true"
"category.create=mfs"
];
};
# Create symlink from home to storage
systemd.tmpfiles.rules = [
"L+ /home/fred/storage - - - - /mnt/storage"
];
2026-01-20 09:59:20 +00:00
2026-01-20 14:42:21 +00:00
# Basic system packages
2026-01-20 14:35:20 +00:00
environment.systemPackages = with pkgs; [
mergerfs
wget
btop
util-linux
2026-01-25 16:01:40 +00:00
javaPackages.compiler.temurin-bin.jre-25
2026-01-25 16:06:34 +00:00
unzip
2026-01-25 16:40:19 +00:00
screen
2026-01-26 15:22:01 +00:00
yt-dlp
2026-01-20 14:35:20 +00:00
];
2026-01-20 09:59:20 +00:00
2026-02-09 19:32:08 +00:00
services.fail2ban.enable = true;
2026-01-20 21:38:23 +00:00
# Enable Docker
2026-01-20 14:35:20 +00:00
virtualisation.docker.enable = true;
2026-01-20 14:42:21 +00:00
# Basic networking
networking.useDHCP = lib.mkDefault true;
2026-01-20 21:38:23 +00:00
# Open firewall for SSH
networking.firewall.allowedTCPPorts = [ 22 ];
2026-01-20 14:42:21 +00:00
services.openssh = {
enable = true;
settings.PermitRootLogin = "no";
};
# Boot loader
2026-01-20 14:35:20 +00:00
boot.loader.grub = {
enable = true;
2026-01-20 14:42:21 +00:00
# Includes all 4 physical disks for redundancy
2026-03-30 21:34:12 +01:00
devices = [ "/dev/sda" "/dev/sdb" "/dev/sdc" "/dev/sdd" #"/dev/sde"
];
2026-01-20 14:35:20 +00:00
useOSProber = true;
};
};
2026-01-20 09:59:20 +00:00
}