Skip to content
Snippets Groups Projects
Select Git revision
  • 114e4d797a852bb3a8916e531ffc1fe3adf8c794
  • develop default protected
  • production protected
  • nixpkgs-upgrade-2025-06-16
  • nixpkgs-upgrade-2024-12-23
  • 190-our-regular-updates-fill-up-the-servers-boot-partitions
  • nixpkgs-upgrade-2024-10-14
  • hro-cloud protected
  • 162.flexible-grafana-module
  • nixpkgs-upgrade-2024-05-13
  • nixpkgs-upgrade-2024-04-22
  • nixpkgs-upgrade-2024-03-25
  • nixpkgs-upgrade-2024-03-18
  • nixpkgs-upgrade-2024-03-11
  • nixpkgs-upgrade-2024-03-04
  • 163.jp-to-ben-for-prod
  • nixpkgs-upgrade-2024-02-26
  • 164.grafana-alert-rules
  • 157.authorize-new-hro-key
  • nixpkgs-upgrade-2024-02-19
  • nixpkgs-upgrade-2024-02-12
21 results

tahoe.nix

Blame
  • grid.nix 1.71 KiB
    # See morph/grid/local/grid.nix for additional commentary.
    let
      pkgs = import <nixpkgs> { };
    
      gridlib = import ../../lib;
      rawConfig = pkgs.lib.trivial.importJSON ./config.json;
      config = rawConfig // {
        sshUsers = import ./public-keys/users.nix;
    
        # Convert relative paths to absolute so library code can resolve names
        # correctly.
        publicKeyPath = toString ./. + "/${rawConfig.publicKeyPath}";
        privateKeyPath = toString ./. + "/${rawConfig.privateKeyPath}";
      };
    
      payments = {
        imports = [
          gridlib.issuer
          gridlib.hardware-aws
          (gridlib.customize-issuer (config // {
            monitoringvpnIPv4 = "172.23.23.11";
          }))
        ];
      };
    
      storage001 = {
        imports = [
          gridlib.storage
          ./testing001-hardware.nix
          (gridlib.customize-storage (config // {
            monitoringvpnIPv4 = "172.23.23.12";
            stateVersion = "19.03";
          }))
        ];
      };
    
      monitoring = {
        imports = [
          gridlib.monitoring
          gridlib.hardware-aws
          (gridlib.customize-monitoring {
            inherit hostsMap vpnClientIPs nodeExporterTargets;
            inherit (config) domain publicKeyPath privateKeyPath;
            monitoringvpnIPv4 = "172.23.23.1";
            stateVersion = "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" = [ "storage001" "storage001.monitoringvpn" ];
      };
      vpnClientIPs = [ "172.23.23.11" "172.23.23.12" ];
      nodeExporterTargets = [ "monitoring" "payments" "storage001" ];
    
    in {
      network = {
        description = "PrivateStorage.io Testing Grid";
      };
      inherit payments monitoring storage001;
    }