2024-10-08 23:50:47 +02:00
|
|
|
{ lib, pkgs, ... }:
|
|
|
|
|
|
|
|
{
|
2024-10-09 00:04:46 +02:00
|
|
|
imports = [
|
|
|
|
./hardware.nix
|
|
|
|
|
|
|
|
./photoprism.nix
|
|
|
|
./immich.nix
|
|
|
|
];
|
2024-10-08 23:50:47 +02:00
|
|
|
|
|
|
|
# Bootloader.
|
|
|
|
boot.loader.systemd-boot.enable = true;
|
|
|
|
|
|
|
|
networking.hostName = "photoprism";
|
|
|
|
|
|
|
|
disko.devices = import ./disko.nix;
|
|
|
|
|
|
|
|
# TODO: ipv6 address
|
|
|
|
deployment.targetHost = "";
|
|
|
|
|
|
|
|
# Set your time zone.
|
|
|
|
time.timeZone = "Europe/Paris";
|
|
|
|
|
|
|
|
environment.systemPackages = with pkgs; [ neovim ];
|
|
|
|
|
|
|
|
services.openssh.enable = true;
|
|
|
|
users.users.root.openssh.authorizedKeys.keys = [
|
|
|
|
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDMBW7rTtfZL9wtrpCVgariKdpN60/VeAzXkh9w3MwbO julien@enigma"
|
|
|
|
# TODO: add cst1's SSH key
|
|
|
|
];
|
|
|
|
|
|
|
|
security.acme.acceptTerms = true;
|
|
|
|
security.acme.defaults.email = "webmaster@nixos.org";
|
|
|
|
|
|
|
|
networking.firewall.allowedTCPPorts = [
|
|
|
|
80
|
|
|
|
443
|
|
|
|
8007
|
|
|
|
];
|
|
|
|
networking.firewall.allowedUDPPorts = [ ];
|
|
|
|
|
|
|
|
networking.useNetworkd = true;
|
|
|
|
|
|
|
|
# TODO:
|
|
|
|
systemd.network.networks."10-wan" = {
|
|
|
|
matchConfig.Name = "ens18";
|
|
|
|
networkConfig = {
|
|
|
|
DHCP = "ipv4";
|
|
|
|
Address = "2a01:e0a:de4:a0e1:eb2:caa1::4";
|
|
|
|
};
|
|
|
|
# make routing on this interface a dependency for network-online.target
|
|
|
|
linkConfig.RequiredForOnline = "routable";
|
|
|
|
};
|
|
|
|
|
|
|
|
system.stateVersion = "23.11";
|
|
|
|
}
|