mirror of
https://github.com/tuxdotrs/tawm.git
synced 2025-07-05 20:56:33 +05:30
102 lines
1.9 KiB
Nix
102 lines
1.9 KiB
Nix
{
|
|
pkgs,
|
|
username,
|
|
config,
|
|
email,
|
|
inputs,
|
|
...
|
|
}: {
|
|
imports = [
|
|
./hardware.nix
|
|
../common
|
|
../../modules/nixos/uptime-kuma.nix
|
|
../../modules/nixos/upstream-proxy.nix
|
|
];
|
|
|
|
tux.services.openssh.enable = true;
|
|
|
|
sops.secrets = {
|
|
borg_encryption_key = {
|
|
sopsFile = ./secrets.yaml;
|
|
};
|
|
|
|
"cloudflare_credentials/email" = {
|
|
sopsFile = ./secrets.yaml;
|
|
};
|
|
|
|
"cloudflare_credentials/dns_api_token" = {
|
|
sopsFile = ./secrets.yaml;
|
|
};
|
|
};
|
|
|
|
boot = {
|
|
kernelPackages = pkgs.linuxPackages_zen;
|
|
initrd.systemd.enable = true;
|
|
|
|
loader = {
|
|
grub.device = "/dev/sda";
|
|
timeout = 1;
|
|
};
|
|
};
|
|
|
|
networking = {
|
|
hostName = "alpha";
|
|
|
|
firewall = {
|
|
enable = true;
|
|
allowedTCPPorts = [80 443 22];
|
|
};
|
|
};
|
|
|
|
security = {
|
|
acme = {
|
|
acceptTerms = true;
|
|
defaults.email = "${email}";
|
|
certs = {
|
|
"tux.rs" = {
|
|
domain = "*.tux.rs";
|
|
extraDomainNames = ["tux.rs"];
|
|
dnsProvider = "cloudflare";
|
|
credentialFiles = {
|
|
CLOUDFLARE_EMAIL_FILE = config.sops.secrets."cloudflare_credentials/email".path;
|
|
CLOUDFLARE_DNS_API_TOKEN_FILE = config.sops.secrets."cloudflare_credentials/dns_api_token".path;
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
users.users.nginx.extraGroups = ["acme"];
|
|
|
|
tux.services.nginxStreamProxy = {
|
|
enable = true;
|
|
upstreamServers = inputs.nix-secrets.proxy-servers;
|
|
};
|
|
|
|
services = {
|
|
nginx = {
|
|
recommendedGzipSettings = true;
|
|
recommendedOptimisation = true;
|
|
recommendedProxySettings = true;
|
|
recommendedTlsSettings = true;
|
|
};
|
|
};
|
|
|
|
programs = {
|
|
zsh.enable = true;
|
|
dconf.enable = true;
|
|
};
|
|
|
|
environment.persistence."/persist" = {
|
|
enable = false;
|
|
};
|
|
|
|
home-manager.users.${username} = {
|
|
imports = [
|
|
./home.nix
|
|
];
|
|
};
|
|
|
|
system.stateVersion = "23.11";
|
|
}
|