1
Fork 0
satellite/hosts/nixos/common/global/default.nix

58 lines
1.2 KiB
Nix

# Configuration pieces included on all (nixos) hosts
{
inputs,
lib,
outputs,
pkgs,
...
}:
let
# {{{ Imports
imports = [
# {{{ flake inputs
inputs.disko.nixosModules.default
inputs.stylix.nixosModules.stylix
inputs.sops-nix.nixosModules.sops
# }}}
# {{{ Satellite subprojects
../../../../dns/implementation/nixos-module.nix
../../../../dns/implementation/nixos-module-assertions.nix
# }}}
# {{{ global configuration
./cli/fish.nix
./services/openssh.nix
./nix.nix
./locale.nix
./unicode.nix
./persistence.nix
./ports.nix
../../../../common
# }}}
];
in
# }}}
{
# Import all modules defined in modules/nixos
imports = builtins.attrValues outputs.nixosModules ++ imports;
# Tell sops-nix to use the host keys for decrypting secrets
sops.age.sshKeyPaths = [ "/persist/state/etc/ssh/ssh_host_ed25519_key" ];
# {{{ ad-hoc options
# Customize tty colors
stylix.targets.console.enable = true;
# Reduce the amount of storage spent for logs
services.journald.extraConfig = lib.mkDefault ''
SystemMaxUse=256M
'';
# Boot using systemd
boot.initrd.systemd.enable = true;
# }}}
# Root domain used throughout my config
satellite.dns.domain = "moonythm.dev";
}