64 lines
1.8 KiB
Nix
64 lines
1.8 KiB
Nix
{ pkgs, nixos-hardware, ... }:
|
|
|
|
{
|
|
imports = [
|
|
# Include the results of the hardware scan.
|
|
./hardware-configuration.nix
|
|
nixos-hardware.nixosModules.raspberry-pi-4
|
|
|
|
../../modules/base
|
|
../../modules/ipfs/cluster.nix
|
|
../../modules/sops
|
|
];
|
|
|
|
boot = {
|
|
# Use the extlinux boot loader. (NixOS wants to enable GRUB by default)
|
|
loader.grub.enable = false;
|
|
# Enables the generation of /boot/extlinux/extlinux.conf
|
|
loader.generic-extlinux-compatible.enable = true;
|
|
kernelPackages = pkgs.linuxKernel.packages.linux_rpi4;
|
|
};
|
|
|
|
hardware = {
|
|
enableRedistributableFirmware = true;
|
|
raspberry-pi."4".poe-hat.enable = true;
|
|
};
|
|
|
|
networking = {
|
|
# networking.hostName = "nixos"; # Define your hostname.
|
|
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
|
|
|
|
# The global useDHCP flag is deprecated, therefore explicitly set to false here.
|
|
# Per-interface useDHCP will be mandatory in the future, so this generated config
|
|
# replicates the default behaviour.
|
|
useDHCP = false;
|
|
interfaces.eth0.useDHCP = true;
|
|
interfaces.wlan0.useDHCP = true;
|
|
firewall.enable = false;
|
|
};
|
|
|
|
# Enable the OpenSSH daemon.
|
|
services.openssh.enable = true;
|
|
users.users.root.openssh.authorizedKeys.keys = [
|
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJ0mE4MyMnfd1b2nlBJT7kpZ6Vov+ILuGNfzdp5ZBNQe walkah@walkah.net"
|
|
];
|
|
|
|
environment.systemPackages = with pkgs; [ libraspberrypi raspberrypi-eeprom ];
|
|
|
|
services = {
|
|
prometheus = {
|
|
enable = true;
|
|
port = 9090;
|
|
exporters = {
|
|
node = {
|
|
enable = true;
|
|
enabledCollectors = [ "systemd" ];
|
|
openFirewall = true;
|
|
port = 9100;
|
|
};
|
|
};
|
|
};
|
|
tailscale = { enable = true; };
|
|
};
|
|
}
|