aboutsummaryrefslogblamecommitdiff
path: root/cluster/prod/cluster.nix
blob: 3d960e4052253a4500bb36543516ae5a30137fd5 (plain) (tree)
1
2
3
4
5
6
7
8
9



                                   
 


                                                                 
 
























                                                                 





                                                                 
                                      






                                                                 
                                      






                                                                 


                                      
                          
                           
                                                                 








                                                                 
                                           








                                                                 
     
    

                                     
                                          
                                            
                            
                         
                         
    
 



                                                                                                 
                                                                                                     
      




                                                                                                                                                                                                                                                                                                                                                                                                                          
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 

                  

                                                                                                                                                                                                                                                                                                                                                                                                                     
      
    


                                                 
 
{ config, pkgs, ... } @ args:

{
  deuxfleurs.cluster_name = "prod";

  # The IP range to use for the Wireguard overlay of this cluster
  deuxfleurs.cluster_prefix = "10.83.0.0";
  deuxfleurs.cluster_prefix_length = 16;

  deuxfleurs.cluster_nodes = [
    {
      hostname = "concombre";
      site_name = "neptune";
      publicKey = "VvXT0fPDfWsHxumZqVShpS33dJQAdpJ1E79ZbCBJP34=";
      IP = "10.83.1.1";
      lan_endpoint = "192.168.1.31:33799";
      endpoint = "77.207.15.215:33731";
    }
    {
      hostname = "courgette";
      site_name = "neptune";
      publicKey = "goTkBJGmzrGDOAjUcdH9G0JekipqSMoaYQdB6IHnzi0=";
      IP = "10.83.1.2";
      lan_endpoint = "192.168.1.32:33799";
      endpoint = "77.207.15.215:33732";
    }
    {
      hostname = "celeri";
      site_name = "neptune";
      publicKey = "oZDAb8LoLW87ktUHyFFec0VaIar97bqq47mGbdVqJ0U=";
      IP = "10.83.1.3";
      lan_endpoint = "192.168.1.33:33799";
      endpoint = "77.207.15.215:33733";
    }
    {
      hostname = "dahlia";
      site_name = "orion";
      publicKey = "EtRoWBYCdjqgXX0L+uWLg8KxNfIK8k9OTh30tL19bXU=";
      IP = "10.83.2.1";
      lan_endpoint = "192.168.1.11:33799";
      endpoint = "82.66.80.201:33731";
    }
    {
      hostname = "diplotaxis";
      site_name = "orion";
      publicKey = "HbLC938mysadMSOxWgq8+qrv+dBKzPP/43OMJp/3phA=";
      IP = "10.83.2.2";
      lan_endpoint = "192.168.1.12:33799";
      endpoint = "82.66.80.201:33732";
    }
    {
      hostname = "doradille";
      site_name = "orion";
      publicKey = "e1C8jgTj9eD20ywG08G1FQZ+Js3wMK/msDUE1wO3l1Y=";
      IP = "10.83.2.3";
      lan_endpoint = "192.168.1.13:33799";
      endpoint = "82.66.80.201:33733";
    }
    {
      hostname = "df-ykl";
      site_name = "bespin";
      publicKey = "bIjxey/VhBgVrLa0FxN/KISOt2XFmQeSh1MPivUq9gg=";
      IP = "10.83.3.1";
      lan_endpoint = "192.168.5.117:33799";
      endpoint = "bespin.site.deuxfleurs.fr:33731";
    }
    {
      hostname = "df-ymf";
      site_name = "bespin";
      publicKey = "pUIKv8UBl586O7DBrHBsb9BgNU7WlYQ2r2RSNkD+JAQ=";
      IP = "10.83.3.2";
      lan_endpoint = "192.168.5.134:33799";
      endpoint = "bespin.site.deuxfleurs.fr:33732";
    }
    {
      hostname = "df-ymk";
      site_name = "bespin";
      publicKey = "VBmpo15iIJP7250NAsF+ryhZc3j+8TZFnE1Djvn5TXI=";
      IP = "10.83.3.3";
      lan_endpoint = "192.168.5.116:33799";
      endpoint = "bespin.site.deuxfleurs.fr:33733";
    }
  ];

  # Bootstrap IPs for Consul cluster,
  # these are IPs on the Wireguard overlay
  services.consul.extraConfig.retry_join = [
    "10.83.1.1"  # concombre
    "10.83.1.3"  # celeri
    "19.83.2.1"  # dahlia
  ];

  deuxfleurs.admin_accounts = {
    lx = [
      # Keys for accessing nodes from outside
      "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIJpaBZdYxHqMxhv2RExAOa7nkKhPBOHupMP3mYaZ73w9 lx@lindy"
      "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIw+IIX8+lZX9RrHAbwi/bncLYStXpI4EmK3AUcqPY2O lx@kusanagi "
    ];
    quentin = [
      "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDT1+H08FdUSvdPpPKdcafq4+JRHvFVjfvG5Id97LAoROmFRUb/ZOMTLdNuD7FqvW0Da5CPxIMr8ZxfrFLtpGyuG7qdI030iIRZPlKpBh37epZHaV+l9F4ZwJQMIBO9cuyLPXgsyvM/s7tDtrdK1k7JTf2EVvoirrjSzBaMhAnhi7//to8zvujDtgDZzy6aby75bAaDetlYPBq2brWehtrf9yDDG9WAMYJqp//scje/WmhbRR6eSdim1HaUcWk5+4ZPt8sQJcy8iWxQ4jtgjqTvMOe5v8ZPkxJNBine/ZKoJsv7FzKem00xEH7opzktaGukyEqH0VwOwKhmBiqsX2yN quentin@dufour.io"
      "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDBu+KUebaWwlugMC5fGbNhHc6IaQDAC6+1vMc4Ww7nVU1rs2nwI7L5qcWxOwNdhFaorZQZy/fJuCWdFbF61RCKGayBWPLZHGPsfqDuggYNEi1Qil1kpeCECfDQNjyMTK058ZBBhOWNMHBjlLWXUlRJDkRBBECY0vo4jRv22SvSaPUCAnkdJ9rbAp/kqb497PTIb2r1l1/ew8YdhINAlpYQFQezZVfkZdTKxt22n0QCjhupqjfh3gfNnbBX0z/iO+RvAOWRIZsjPFLC+jXl+n7cnu2cq1nvST5eHiYfXXeIgIwmeENLKqp+2Twr7PIdv22PnJkh6iR5kx7eTRxkNZdN quentin@deuxfleurs.fr"
    ];
    adrien = [
      "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDs9v4tU1F7rqEJFfLjGAOWeGPi3DMgDCtj0mNine/J4GKgDR0KrWIQgT4jE8VdMXRXpaiKZjOabIczvR7INCQryGwb24NzielB5m98dx+OVoWHoFCb3xFgGkk3TIsJp0+8RuGFTPFh5GA1uQB4aHZs6YP56Y/bkr8Ap6sbOfKgg4mfHuVuhME2pOFe4q0YxWFE6Lq/4ysC/87xwjAhQwRyC+vyDxDVUVPKRCRoPxLg0htV6eOY0fJB+9fKrhdeW+yOu4GlxoMxrZfUKjVeCEtbtgOXzNayVRWQNkCZsAgEBD5gmMfBG25vur60d9dCekVOVmaTc0F56DRjaGOOB0WFPZrf16TBs99XlMMbnkhf8z0IPn/L+Q/jJEL4QjhZZ2mrQhZsHVAOPEATKgaYMw2FRUrwyoUJfNIku0e8YmkJR5vEwHoG0o1A0PCACWCRQ1zcac9uYjMADoSsSMjrCQ8FVUT6enPe+g36MtWEaBxUpfqFx0xvw2bvbWFm5xk0uMM= adrien@pratchett"
    ];
    maximilien = [
      "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDHMMR6zNzz8NQU80wFquhUCeiXJuGphjP+zNouKbn228GyESu8sfNBwnuZq86vblR11Lz8l2rtCM73GfAKg29qmUWUHRKWvRIYWv2vaUJcCdy0bAxIzcvCvjZX0SpnIKxe9y3Rp0LGO5WLYfw0ZFaavwFZP0Z8w1Kj9/zBmL2X2avbhkaYHi/C1yXhbvESYQysmqLa48EX/TS616MBrgR9zbI9AoTQ9NOHnR14Tve/AP/khcZoBJdm4hTttMbNkEc0wonzdylTDew263SPRs/uoqnQIpUtErdPHqU10Yup8HjXjEyFJsSwcZcM5sZOw5JKckKJwmcd0yjO/x/4/Mk5 maximilien@icare"
      "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGioTNbjGE3KblbqhnkEWUfGkYZ2p5UAVqPdQJaUBWoo maximilien@athena"
    ];
  };

  # For Garage external communication
  networking.firewall.allowedTCPPorts = [ 3901 ];
}