let pkgs = import <nixpkgs> { }; gridlib = import ../../lib; config = pkgs.lib.trivial.importJSON ./config.json; sshUsers = import ./secrets/users.nix; # Get absolute vpn key directory path, as a string: monitoringvpnKeyDir = toString ./. + "/${config.monitoringvpnKeyDir}"; payments = let publicIPv4 = "192.168.67.21"; in { imports = [ gridlib.issuer (import ./virtual-hardware.nix ({ inherit publicIPv4; })) (gridlib.customize-issuer config sshUsers monitoringvpnKeyDir "172.23.23.11" "19.03") ]; }; storage1 = let publicIPv4 = "192.168.67.22"; in { imports = [ gridlib.storage (import ./virtual-hardware.nix ({ inherit publicIPv4; })) (gridlib.customize-storage config sshUsers publicIPv4 monitoringvpnKeyDir "172.23.23.12" "19.09") ]; }; storage2 = let publicIPv4 = "192.168.67.23"; in { imports = [ gridlib.storage (import ./virtual-hardware.nix ({ inherit publicIPv4; })) (gridlib.customize-storage config sshUsers publicIPv4 monitoringvpnKeyDir "172.23.23.13" "19.09") ]; }; monitoring = let publicIPv4 = "192.168.67.24"; in { imports = [ gridlib.monitoring (import ./virtual-hardware.nix ({ inherit publicIPv4; })) (gridlib.customize-monitoring hostsMap monitoringvpnKeyDir publicIPv4 "172.23.23.1" vpnClientIPs nodeExporterTargets [] "19.09") ]; }; # TBD: derive these automatically: hostsMap = { "172.23.23.1" = [ "monitoring" "monitoring.monitoringvpn" ]; "172.23.23.11" = [ "payments" "payments.monitoringvpn" ]; "172.23.23.12" = [ "storage1" "storage1.monitoringvpn" ]; "172.23.23.13" = [ "storage2" "storage2.monitoringvpn" ]; }; vpnClientIPs = [ "172.23.23.11" "172.23.23.12" "172.23.23.13" ]; nodeExporterTargets = [ "monitoring" "payments" "storage1" "storage2" ]; in { network = { description = "PrivateStorage.io LocalDev Grid"; }; inherit payments monitoring storage1 storage2; }