87 lines
1.7 KiB
Nix
87 lines
1.7 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
apple-silicon,
|
|
...
|
|
}:
|
|
|
|
{
|
|
nixpkgs.overlays = [ apple-silicon.overlays.apple-silicon-overlay ];
|
|
|
|
boot.loader.systemd-boot.enable = true;
|
|
boot.loader.efi.canTouchEfiVariables = false;
|
|
|
|
hardware.asahi.useExperimentalGPUDriver = true;
|
|
hardware.asahi.extractPeripheralFirmware = true;
|
|
|
|
networking.hostName = "homeserver";
|
|
networking.networkmanager.enable = true;
|
|
|
|
fileSystems."/mnt/data" = {
|
|
device = "172.16.0.1:/volume1/data";
|
|
fsType = "nfs";
|
|
options = [
|
|
"noauto"
|
|
"x-systemd.automount"
|
|
"x-systemd.idle-timeout=600"
|
|
];
|
|
};
|
|
|
|
users.groups.media = { };
|
|
users.users.media = {
|
|
group = "media";
|
|
isNormalUser = true;
|
|
};
|
|
|
|
services.xserver.xkb.layout = "us";
|
|
|
|
services.audiobookshelf = {
|
|
enable = true;
|
|
group = "media";
|
|
host = "0.0.0.0";
|
|
openFirewall = true;
|
|
port = 8000;
|
|
user = "media";
|
|
};
|
|
|
|
services.avahi = {
|
|
enable = true;
|
|
publish = {
|
|
enable = true;
|
|
addresses = true;
|
|
workstation = true;
|
|
};
|
|
allowInterfaces = [
|
|
"end0"
|
|
"enp2s0u2"
|
|
];
|
|
};
|
|
|
|
services.calibre-server = {
|
|
enable = true;
|
|
extraFlags = [ "--enable-local-write" ];
|
|
group = "media";
|
|
libraries = [ "/srv/books" ];
|
|
openFirewall = true;
|
|
port = 8585;
|
|
user = "media";
|
|
};
|
|
|
|
services.openssh = {
|
|
enable = true;
|
|
settings.PasswordAuthentication = false;
|
|
settings.KbdInteractiveAuthentication = false;
|
|
settings.PermitRootLogin = "no";
|
|
};
|
|
|
|
services.tailscale = {
|
|
enable = true;
|
|
useRoutingFeatures = "server";
|
|
};
|
|
|
|
networking.firewall.allowedTCPPorts = [ 22 ];
|
|
networking.firewall.allowedUDPPorts = [ ];
|
|
|
|
system.stateVersion = "25.11";
|
|
}
|