350 lines
7.9 KiB
Nix
350 lines
7.9 KiB
Nix
{ lib, pkgs, inputs, secretsDir, config, ... }:
|
|
{
|
|
|
|
#system.stateVersion = "23.05"; # Did you read the comment?
|
|
|
|
imports = [
|
|
"${inputs.nixpkgs}/nixos/modules/installer/sd-card/sd-image-aarch64.nix"
|
|
#inputs.nixos-hardware.nixosModules.raspberry-pi-4
|
|
inputs.networkmanager.nixosModules.networkmanager
|
|
|
|
../common/all.nix
|
|
|
|
inputs.home-manager.nixosModules.home-manager
|
|
../users/me/headless.nix
|
|
|
|
##### project modules #####
|
|
|
|
# the module for the zwave setup
|
|
#"${workDir}/htl/labor/hackl/zwave.nix"
|
|
|
|
# labor nas project
|
|
# with this moduel it does not boot, it waits for /dev/disk/by-label/nas-storage
|
|
# "${workDir}/htl/labor/nas/nixos/lush-module.nix"
|
|
];
|
|
|
|
#nixpkgs.config.allowUnsupportedSystem = true;
|
|
#nixpkgs.hostPlatform.system = "aarch64-linux";
|
|
#nixpkgs.buildPlatform.system = "x86_64-linux";
|
|
|
|
# fix bluetooth
|
|
hardware = {
|
|
bluetooth = {
|
|
package = pkgs.bluez;
|
|
enable = true;
|
|
powerOnBoot = true;
|
|
};
|
|
};
|
|
|
|
# get usbip working
|
|
boot.extraModulePackages = [
|
|
config.boot.kernelPackages.usbip
|
|
];
|
|
|
|
|
|
#boot.kernelParams = lib.mkForce ["console=ttyS0,115200n8" "console=ttyAMA0,115200n8" "console=tty0" "nohibernate" "loglevel=7" ];
|
|
|
|
|
|
/* for cross compiling
|
|
#nixpkgs.hostPlatform.system = "aarch64-linux";
|
|
#nixpkgs.buildPlatform.system = "x86_64-linux";
|
|
nixpkgs.overlays = [
|
|
|
|
(outerFinal: outerPrev: {
|
|
#https://github.com/adrienverge/openfortivpn/issues/446
|
|
#https://github.com/NixOS/nixpkgs/blob/nixos-23.05/pkgs/tools/networking/openfortivpn/default.nix#L47
|
|
openfortivpn = outerPrev.openfortivpn.overrideAttrs (final: prev: {
|
|
configureFlags = prev.configureFlags or [] ++ [
|
|
"--disable-proc"
|
|
"--with-rt_dst=yes"
|
|
"--with-pppd=/usr/sbin/pppd"
|
|
];
|
|
});
|
|
})
|
|
];
|
|
*/
|
|
|
|
services.blueman.enable = true;
|
|
hardware.enableRedistributableFirmware = true;
|
|
|
|
services.tailscale.enable = true;
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
linuxPackages.usbip
|
|
vim
|
|
bluez
|
|
git
|
|
];
|
|
|
|
# "${nixpkgs}/nixos/modules/installer/sd-card/sd-image-aarch64.nix" creates a
|
|
# disk with this label on first boot. Therefore, we need to keep it. It is the
|
|
# only information from the installer image that we need to keep persistent
|
|
fileSystems."/" = {
|
|
device = "/dev/disk/by-label/NIXOS_SD";
|
|
noCheck = true;
|
|
fsType = "ext4";
|
|
};
|
|
|
|
boot = {
|
|
loader = {
|
|
generic-extlinux-compatible.enable = lib.mkDefault true;
|
|
grub.enable = lib.mkDefault false;
|
|
};
|
|
};
|
|
|
|
########################### ssh ############################
|
|
services.openssh = {
|
|
enable = true;
|
|
ports = [ 22 ];
|
|
|
|
settings.PasswordAuthentication = false;
|
|
settings.KbdInteractiveAuthentication = false;
|
|
settings.PermitRootLogin = "no";
|
|
settings.X11Forwarding = true;
|
|
extraConfig = ''
|
|
X11UseLocalhost no
|
|
'';
|
|
};
|
|
|
|
|
|
####################################### networking ##########################
|
|
|
|
networking.firewall.allowedUDPPorts = [
|
|
3702 # wsdd
|
|
51820 # wireguard
|
|
67 # allow DHCP traffic
|
|
53 # allow dns
|
|
];
|
|
|
|
networking.firewall.allowedTCPPorts = [
|
|
8888 # general use
|
|
9999 # general use
|
|
3240 # usbip
|
|
];
|
|
|
|
networking.hostName = "ti";
|
|
|
|
networking.networkmanager.enable = true;
|
|
|
|
networking.networkmanager.profiles = {
|
|
pw = {
|
|
connection = {
|
|
id = "pw";
|
|
uuid = "e0103dac-7da0-4e32-a01b-487b8c4c813c";
|
|
type = "wifi";
|
|
interface-name = "wlan0";
|
|
autoconnect = true;
|
|
autoconnect-priority = "-200";
|
|
};
|
|
|
|
wifi = {
|
|
hidden = "true";
|
|
mode = "infrastructure";
|
|
ssid = builtins.readFile "${secretsDir}/wifi-ssid";
|
|
};
|
|
|
|
wifi-security = {
|
|
key-mgmt = "wpa-psk";
|
|
psk = builtins.readFile "${secretsDir}/wifi-password";
|
|
};
|
|
|
|
ipv4 = {
|
|
address1 = "192.168.20.21/24";
|
|
method = "auto";
|
|
};
|
|
};
|
|
|
|
gw = {
|
|
connection = {
|
|
id = "gw";
|
|
uuid = "de655c52-1af2-4b46-b7b2-8ddad9edb52f";
|
|
type = "wifi";
|
|
interface-name = "wlp2s0";
|
|
autoconnect-priority = "300";
|
|
};
|
|
|
|
wifi = {
|
|
hidden = "false";
|
|
mode = "infrastructure";
|
|
ssid = builtins.readFile "${secretsDir}/gw-ssid";
|
|
};
|
|
|
|
wifi-security = {
|
|
key-mgmt = "wpa-psk";
|
|
psk = builtins.readFile "${secretsDir}/gw-password";
|
|
};
|
|
|
|
ipv4 = {
|
|
#address1 = "192.168.20.11/24";
|
|
dns = "1.1.1.1;8.8.8.8;";
|
|
method = "auto";
|
|
};
|
|
};
|
|
|
|
hh40 = {
|
|
connection = {
|
|
id = "hh40";
|
|
uuid = "73a61cef-8f7b-4f42-ab3f-0066e0295bbc";
|
|
type = "wifi";
|
|
interface-name = "wlan0";
|
|
autoconnect = true;
|
|
autoconnect-priority = "-999";
|
|
};
|
|
|
|
wifi = {
|
|
hidden = "false";
|
|
mode = "infrastructure";
|
|
ssid = builtins.readFile "${secretsDir}/home-wifi-ssid";
|
|
};
|
|
|
|
wifi-security = {
|
|
key-mgmt = "wpa-psk";
|
|
psk = builtins.readFile "${secretsDir}/home-wifi-password";
|
|
};
|
|
|
|
ipv4 = {
|
|
method = "auto";
|
|
address1 = "192.168.1.37/24";
|
|
};
|
|
};
|
|
|
|
dhcp = {
|
|
connection = {
|
|
id = "dhcp";
|
|
uuid = "c006389a-1697-4f77-91c3-95b466f85f13";
|
|
type = "ethernet";
|
|
autoconnect = "true";
|
|
interface-name = "eth0";
|
|
};
|
|
|
|
ethernet = {
|
|
mac-address = "DC:A6:32:CB:4D:5E";
|
|
};
|
|
|
|
ipv4 = {
|
|
address1 = "192.168.1.44/24,192.168.1.1";
|
|
method = "auto";
|
|
};
|
|
};
|
|
|
|
share = {
|
|
connection = {
|
|
id = "share";
|
|
uuid = "f55f34e3-4595-4642-b1f6-df3185bc0a04";
|
|
type = "ethernet";
|
|
autoconnect = false;
|
|
interface-name = "eth0";
|
|
};
|
|
|
|
ethernet = {
|
|
mac-address = "DC:A6:32:CB:4D:5E";
|
|
};
|
|
|
|
ipv4 = {
|
|
address1 = "192.168.4.1/24";
|
|
method = "shared";
|
|
};
|
|
|
|
ipv6 = {
|
|
addr-gen-mode = "stable-privacy";
|
|
method = "auto";
|
|
};
|
|
};
|
|
|
|
pt = {
|
|
connection = {
|
|
id = "pt";
|
|
uuid = "f028117e-9eef-47c1-8483-574f7ee798a4";
|
|
type = "bluetooth";
|
|
autoconnect = true;
|
|
};
|
|
|
|
bluetooth = {
|
|
bdaddr = "E8:78:29:C4:BA:7C";
|
|
type = "panu";
|
|
};
|
|
|
|
ipv4 = {
|
|
address1 = "192.168.44.22/24";
|
|
method = "auto";
|
|
};
|
|
};
|
|
|
|
|
|
/*
|
|
me = {
|
|
connection = {
|
|
id = "me";
|
|
uuid = "fe45d3bc-21c6-41ff-bc06-c936017c6e02";
|
|
type = "wireguard";
|
|
autoconnect = "true";
|
|
interface-name = "me0";
|
|
};
|
|
wireguard = {
|
|
listen-port = "51820";
|
|
private-key = builtins.readFile "${secretsDir}/wg-private-lush";
|
|
};
|
|
ipv4 = {
|
|
address1 = "10.1.1.4/24";
|
|
method = "manual";
|
|
};
|
|
} // (import ../common/wg-peers.nix { inherit secretsDir; });
|
|
*/
|
|
};
|
|
|
|
|
|
systemd.services.iwd.serviceConfig.Restart = "always";
|
|
/*
|
|
networking = {
|
|
interfaces."wlan0".useDHCP = true;
|
|
|
|
interfaces."eth0" = {
|
|
#name = "eth0";
|
|
ipv4.addresses = [
|
|
{ address = "192.168.5.5"; prefixLength = 24;}
|
|
];
|
|
};
|
|
*/
|
|
|
|
/*
|
|
wireless = {
|
|
interfaces = [ "wlan0" ];
|
|
enable = true;
|
|
networks = {
|
|
seb-phone.psk = "hellogello";
|
|
};
|
|
};
|
|
};
|
|
|
|
*/
|
|
|
|
|
|
####################################### wireguard ##########################
|
|
/*
|
|
systemd.network.netdevs.me0 = {
|
|
enable = true;
|
|
wireguardPeers = import ../common/wg-peers.nix { inherit secretsDir; };
|
|
wireguardConfig = {
|
|
ListenPort = 51820;
|
|
PrivateKeyFile = "/etc/wireguard/secret.key";
|
|
};
|
|
};
|
|
networking.wireguard.interfaces = {
|
|
me = {
|
|
ips = [ "10.1.1.11/24" ];
|
|
};
|
|
*/
|
|
|
|
/*
|
|
boot = {
|
|
kernelPackages = pkgs.linuxKernel.packages.linux_rpi4;
|
|
initrd.availableKernelModules = [ "xhci_pci" "usbhid" "usb_storage" ];
|
|
loader = {
|
|
grub.enable = false;
|
|
generic-extlinux-compatible.enable = true;
|
|
};
|
|
};
|
|
*/
|
|
|
|
}
|