2023-06-01 14:39:07 -05:00
|
|
|
{
|
2023-06-09 14:24:51 -05:00
|
|
|
inputs = {
|
2023-06-25 20:54:15 -05:00
|
|
|
nixpkgs.url = "nixpkgs/nixos-23.05";
|
2023-06-25 20:49:00 -05:00
|
|
|
agenix = {
|
|
|
|
url = "github:ryantm/agenix";
|
2023-06-09 14:24:51 -05:00
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
2023-06-25 20:49:00 -05:00
|
|
|
inputs.darwin.follows = "";
|
2023-06-09 14:24:51 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-06-25 20:49:00 -05:00
|
|
|
outputs = { self, nixpkgs, agenix, ... }@attrs:
|
2023-06-09 14:24:51 -05:00
|
|
|
let
|
2023-06-25 13:27:19 -05:00
|
|
|
containerDef = import ./containers.nix;
|
|
|
|
serviceContainers = containerDef.containers;
|
|
|
|
|
2023-06-09 14:24:51 -05:00
|
|
|
pkgs = import nixpkgs { inherit system; };
|
|
|
|
system = "x86_64-linux";
|
|
|
|
in {
|
|
|
|
devShell.x86_64-linux = pkgs.mkShell {
|
2023-06-25 20:49:00 -05:00
|
|
|
buildInputs = [
|
|
|
|
agenix.packages.x86_64-linux.default
|
|
|
|
(pkgs.nixos { }).nixos-rebuild
|
|
|
|
pkgs.terraform
|
|
|
|
];
|
2023-06-25 13:27:19 -05:00
|
|
|
shellHook = ''
|
|
|
|
alias deploy="nixos-rebuild switch --target-host root@matri.cx --build-host root@matri.cx --flake .#eve-psr-nix0"
|
|
|
|
'';
|
2023-06-09 14:24:51 -05:00
|
|
|
};
|
2023-06-25 13:27:19 -05:00
|
|
|
|
|
|
|
formatter.x86_64-linux = nixpkgs.legacyPackages.x86_64-linux.nixfmt;
|
|
|
|
|
2023-06-09 14:24:51 -05:00
|
|
|
nixosConfigurations = {
|
|
|
|
eve-psr-nix0 = nixpkgs.lib.nixosSystem {
|
|
|
|
inherit system;
|
|
|
|
specialArgs = attrs;
|
|
|
|
modules = [
|
|
|
|
({ modulesPath, ... }: {
|
2023-06-25 13:27:19 -05:00
|
|
|
|
2023-06-25 20:49:00 -05:00
|
|
|
imports = [ agenix.nixosModules.default ./hardware-configuration.nix ];
|
2023-06-09 14:24:51 -05:00
|
|
|
|
|
|
|
nix = {
|
|
|
|
buildMachines = [ ];
|
|
|
|
distributedBuilds = false;
|
2023-06-26 12:37:11 -05:00
|
|
|
settings = {
|
2023-06-26 12:43:25 -05:00
|
|
|
auto-optimise-store = false; # https://github.com/NixOS/nix/issues/7273
|
2023-06-26 12:37:11 -05:00
|
|
|
experimental-features = [ "nix-command" "flakes" ];
|
|
|
|
};
|
2023-06-09 14:24:51 -05:00
|
|
|
};
|
|
|
|
|
2023-06-25 13:27:19 -05:00
|
|
|
boot = {
|
|
|
|
loader.systemd-boot.enable = true;
|
|
|
|
loader.efi.canTouchEfiVariables = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
time.timeZone = "America/Chicago";
|
2023-06-09 14:24:51 -05:00
|
|
|
networking = {
|
|
|
|
hostName = "eve-psr-nix0";
|
|
|
|
firewall = {
|
2023-06-21 20:09:36 -05:00
|
|
|
allowedTCPPorts = [ 22 80 443 3034 ];
|
2023-06-09 14:24:51 -05:00
|
|
|
allowedUDPPorts = [ 22 80 443 ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-06-25 13:27:19 -05:00
|
|
|
environment.systemPackages = with pkgs; [ git pciutils vim wget ];
|
2023-06-01 14:39:07 -05:00
|
|
|
|
2023-06-21 19:33:22 -05:00
|
|
|
services = {
|
2023-06-25 13:27:19 -05:00
|
|
|
openssh = {
|
|
|
|
enable = true;
|
|
|
|
};
|
|
|
|
|
2023-06-21 19:33:22 -05:00
|
|
|
hydra = {
|
|
|
|
enable = true;
|
2023-06-21 20:09:36 -05:00
|
|
|
hydraURL = "https://hydra.matri.cx";
|
|
|
|
listenHost = "192.168.0.130";
|
|
|
|
port = 3034;
|
|
|
|
|
|
|
|
extraConfig = ''
|
|
|
|
using_frontend_proxy = 1
|
|
|
|
base_uri = "https://hydra.matri.cx"
|
|
|
|
'';
|
|
|
|
|
2023-06-21 19:33:22 -05:00
|
|
|
useSubstitutes = true;
|
2023-06-21 20:09:36 -05:00
|
|
|
|
|
|
|
notificationSender = "hydra@matri.cx";
|
2023-06-25 13:27:19 -05:00
|
|
|
buildMachinesFiles = [ ];
|
2023-06-21 19:33:22 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-06-25 13:27:19 -05:00
|
|
|
virtualisation = {
|
|
|
|
oci-containers = {
|
|
|
|
backend = "podman";
|
|
|
|
containers = serviceContainers;
|
|
|
|
};
|
2023-06-09 14:24:51 -05:00
|
|
|
};
|
|
|
|
|
2023-06-25 13:27:19 -05:00
|
|
|
security.sudo.wheelNeedsPassword = false;
|
2023-06-09 14:24:51 -05:00
|
|
|
users = {
|
|
|
|
users = {
|
|
|
|
sezycei = {
|
|
|
|
isNormalUser = true;
|
|
|
|
initialPassword = "bootMaster";
|
2023-06-25 13:27:19 -05:00
|
|
|
extraGroups = [ "wheel" ];
|
2023-06-09 14:24:51 -05:00
|
|
|
packages = with pkgs; [ byobu tmux stack ];
|
|
|
|
};
|
|
|
|
torrent = {
|
|
|
|
isNormalUser = true;
|
|
|
|
initialPassword = "torrentUserTemp";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2023-06-25 20:49:00 -05:00
|
|
|
age.secrets.keys.file = ./secrets/keys.age;
|
|
|
|
|
|
|
|
#sops = {
|
|
|
|
# age = { sshKeyPaths = [ "/etc/ssh/ssh_host_ed25519_key" ]; };
|
|
|
|
# defaultSopsFile = ./secrets/keys.yaml;
|
|
|
|
# secrets = {
|
|
|
|
# hostname = { };
|
|
|
|
# };
|
|
|
|
#};
|
2023-06-09 14:24:51 -05:00
|
|
|
|
|
|
|
system.stateVersion = "22.11";
|
|
|
|
})
|
|
|
|
];
|
|
|
|
};
|
2023-06-01 14:39:07 -05:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|