{ config, pkgs, inputs, ... }:

{
  imports = [
    ./hardware-configuration.nix
    ./hydra.nix
  ];

  services.avahi.enable = true;
  services.avahi.nssmdns4 = true;
  services.avahi.nssmdns6 = true;

  services.openssh.enable = true;
  users.users.stuebinm.openssh.authorizedKeys.keys = [
    "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIH8e9WrHsknoFwBm/YaigOSz9VI8dXRRR5G9BX4kKt9/ stuebinm@ilex"
  ];

  environment.systemPackages = with pkgs; [
    flatpak
    # for mounting samba
    cifs-utils
  ];

  # for nix-serve
  networking.firewall.allowedTCPPorts = [ 5000 ];

  networking = {
    hostName = "abbenay";
    useDHCP = false;
    interfaces.enp3s0.useDHCP = true;
    # networkmanager shouldn't handle nixos container
    networkmanager.unmanaged = [ "interface-name:ve-*" ];
  };

  # nixos containers should have internet access
  networking.nat = {
    enable = true;
    internalInterfaces = ["ve-+"];
    externalInterface = "eth0";
  };

  boot = {
    extraModulePackages = with config.boot.kernelPackages; [ v4l2loopback ];
    kernelModules = [ "v4l2loopback" ];
  };

  # Use the systemd-boot EFI boot loader.
  boot.loader.systemd-boot.enable = true;
  boot.loader.efi.canTouchEfiVariables = true;
  boot.binfmt.emulatedSystems = [ "aarch64-linux" ];

  # This value determines the NixOS release from which the default
  # settings for stateful data, like file locations and database versions
  # on your system were taken. It‘s perfectly fine and recommended to leave
  # this value at the release version of the first install of this system.
  # Before changing this value read the documentation for this option
  # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
  system.stateVersion = "20.03"; # Did you read the comment?

}