2025-03-12 22:30:33 -07:00
|
|
|
{ config, ... }:
|
2025-03-18 14:09:25 -07:00
|
|
|
let
|
|
|
|
|
email = "admin@woach.me";
|
|
|
|
|
in {
|
2025-03-12 22:30:33 -07:00
|
|
|
imports = [
|
|
|
|
|
./hardware.nix
|
|
|
|
|
];
|
|
|
|
|
system.stateVersion = "24.11";
|
|
|
|
|
system.timezone = "America/Los_Angeles";
|
|
|
|
|
system.users.bigWheels = [ "pan" ];
|
|
|
|
|
|
2025-03-17 16:18:17 -07:00
|
|
|
sops-nix = {
|
|
|
|
|
enable = true;
|
|
|
|
|
keyFile = "/etc/sops/age/keys.txt";
|
|
|
|
|
sopsFile = ./secrets.yaml;
|
|
|
|
|
secrets = {
|
|
|
|
|
pdsEnv = {};
|
2025-03-24 12:36:15 -07:00
|
|
|
forgejoPassword = {
|
|
|
|
|
owner = "forgejo";
|
|
|
|
|
};
|
2025-03-17 16:18:17 -07:00
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2025-03-18 14:09:25 -07:00
|
|
|
caddy = {
|
|
|
|
|
enable = true;
|
|
|
|
|
adminEmail = email;
|
|
|
|
|
vhosts = {
|
|
|
|
|
"juri.woach.me" = {
|
|
|
|
|
extraConfig = ''
|
|
|
|
|
reverse_proxy :3000
|
|
|
|
|
'';
|
|
|
|
|
serverAliases = [ "*.juri.woach.me" ];
|
|
|
|
|
};
|
2025-03-24 12:36:15 -07:00
|
|
|
"winry.woach.me" = {
|
|
|
|
|
extraConfig = ''
|
|
|
|
|
reverse_proxy :${builtins.toString config.forgejo.server.port}
|
|
|
|
|
'';
|
|
|
|
|
};
|
2025-03-18 14:09:25 -07:00
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2025-03-17 16:18:17 -07:00
|
|
|
pds = {
|
|
|
|
|
enable = true;
|
|
|
|
|
hostname = "juri.woach.me";
|
2025-03-18 14:09:25 -07:00
|
|
|
adminEmail = email;
|
2025-03-17 16:18:17 -07:00
|
|
|
environmentFile = config.sops.secrets.pdsEnv.path;
|
|
|
|
|
};
|
|
|
|
|
|
2025-03-24 12:36:15 -07:00
|
|
|
forgejo = {
|
|
|
|
|
enable = true;
|
|
|
|
|
server.domain = "winry.woach.me";
|
|
|
|
|
users.admin = {
|
|
|
|
|
enable = true;
|
|
|
|
|
username = "Julia";
|
|
|
|
|
passwordFile = config.sops.secrets.forgejoPassword.path;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2025-04-09 14:06:04 -07:00
|
|
|
postgres.enable = true;
|
|
|
|
|
|
2025-03-12 22:30:33 -07:00
|
|
|
shell.enabledShells = [ "fish" ];
|
|
|
|
|
shell.defaultShell = "fish";
|
|
|
|
|
|
|
|
|
|
sshd.enable = true;
|
|
|
|
|
}
|