WIP: feat(machines/hypervisor0*): init #198

Draft
rlahfa wants to merge 1 commit from hypervisor into main
7 changed files with 152 additions and 7 deletions

2
.gitignore vendored
View file

@ -9,3 +9,5 @@ result-*
*.qcow2 *.qcow2
.gcroots .gcroots
.pre-commit-config.yaml .pre-commit-config.yaml
preseed*yml

View file

@ -2,15 +2,27 @@
# #
# SPDX-License-Identifier: EUPL-1.2 # SPDX-License-Identifier: EUPL-1.2
{ lib, ... }: { meta, lib, ... }:
Review

meta should go after lib as it is a custom arg

meta should go after lib as it is a custom arg
lib.extra.mkConfig { lib.extra.mkConfig {
enabledModules = [ ]; enabledModules = [
"dgn-hypervisor"
"dgn-cephfs"
];
enabledServices = [ ]; enabledServices = [ ];
extraConfig = { extraConfig = {
services.netbird.enable = true; services.netbird.enable = true;
dgn-cephfs = {
# Unique per cluster.
fsid = "d189c08e-300b-4ad9-8c95-b50fd0976758";
initialMembers = lib.genAttrs [
"hypervisor01"
"hypervisor02"
"hypervisor03"
] (name: builtins.head meta.network.${name}.addresses.ipv4);
};
}; };
root = ./.; root = ./.;

View file

@ -2,15 +2,27 @@
# #
# SPDX-License-Identifier: EUPL-1.2 # SPDX-License-Identifier: EUPL-1.2
{ lib, ... }: { meta, lib, ... }:
lib.extra.mkConfig { lib.extra.mkConfig {
enabledModules = [ ]; enabledModules = [
"dgn-hypervisor"
"dgn-cephfs"
Review

Pls sort the modules

Pls sort the modules
];
enabledServices = [ ]; enabledServices = [ ];
extraConfig = { extraConfig = {
services.netbird.enable = true; services.netbird.enable = true;
dgn-cephfs = {
# Unique per cluster.
fsid = "d189c08e-300b-4ad9-8c95-b50fd0976758";
initialMembers = lib.genAttrs [
"hypervisor01"
"hypervisor02"
"hypervisor03"
] (name: builtins.head meta.network.${name}.addresses.ipv4);
};
}; };
root = ./.; root = ./.;

View file

@ -2,15 +2,27 @@
# #
# SPDX-License-Identifier: EUPL-1.2 # SPDX-License-Identifier: EUPL-1.2
{ lib, ... }: { meta, lib, ... }:
lib.extra.mkConfig { lib.extra.mkConfig {
enabledModules = [ ]; enabledModules = [
"dgn-hypervisor"
"dgn-cephfs"
];
enabledServices = [ ]; enabledServices = [ ];
extraConfig = { extraConfig = {
services.netbird.enable = true; services.netbird.enable = true;
dgn-cephfs = {
# Unique per cluster.
fsid = "d189c08e-300b-4ad9-8c95-b50fd0976758";
initialMembers = lib.genAttrs [
"hypervisor01"
"hypervisor02"
"hypervisor03"
] (name: builtins.head meta.network.${name}.addresses.ipv4);
};
}; };
root = ./.; root = ./.;

View file

@ -18,10 +18,12 @@
"dgn-access-control" "dgn-access-control"
"dgn-acme" "dgn-acme"
"dgn-backups" "dgn-backups"
"dgn-console" "dgn-cephfs"
"dgn-chatops" "dgn-chatops"
"dgn-console"
"dgn-firewall" "dgn-firewall"
"dgn-hardware" "dgn-hardware"
"dgn-hypervisor"
"dgn-netbox-agent" "dgn-netbox-agent"
"dgn-network" "dgn-network"
"dgn-node-monitoring" "dgn-node-monitoring"

View file

@ -0,0 +1,84 @@
# SPDX-FileCopyrightText: 2024 Ryan Lahfa <ryan@dgnum.eu>
# SPDX-FileContributor: Elias Coppens <elias@dgnum.eu>
#
# SPDX-License-Identifier: EUPL-1.2
{
meta,
pkgs,
config,
lib,
Review
{
  config,
  lib,
  pkgs,
  meta,
  ...
}:
```nix { config, lib, pkgs, meta, ... }: ```
...
}:
let
inherit (lib)
mkEnableOption
mkIf
types
mkOption
concatStringsSep
;
cfg = config.dgn-cephfs;
in
{
options.dgn-cephfs = {
enable = mkEnableOption "the CephFS module for our hypervisors";
fsid = mkOption {
type = types.str;
Review

Needs a description

Needs a description
};
initialMembers = mkOption {
type = types.attrsOf types.str;
default = { };
example = {
"hypervisor01" = "10.0.0.254";
"hypervisor02" = "10.0.0.253";
};
};
};
config = mkIf cfg.enable {
networking.firewall.allowedTCPPorts = [
6789
3300
];
networking.firewall.allowedTCPPortRanges = [
{
from = 6800;
to = 7300;
}
];
environment.systemPackages = [
pkgs.ceph
pkgs.gdb
];
environment.enableDebugInfo = true;
services.ceph = {
enable = true;
global = {
inherit (cfg) fsid;
monInitialMembers = concatStringsSep ", " (builtins.attrNames cfg.initialMembers);
monHost = concatStringsSep ", " (builtins.attrValues cfg.initialMembers);
# TODO: change it
clusterName = "ceph";
clusterNetwork = "10.0.254.0/24";
publicNetwork = "10.0.254.0/24";
};
extraConfig.public_addr = builtins.head meta.network.${config.networking.hostName}.addresses.ipv4;
Review

Colmena gives name as an argument, no need for hostName

Colmena gives `name` as an argument, no need for hostName
osd = {
enable = true;
daemons = [ config.networking.hostName ];
};
mon = {
enable = true;
daemons = [ config.networking.hostName ];
Review

Same as above, plus, if the config for mon, osd and mgr is the same, it can be factorized

Same as above, plus, if the config for mon, osd and mgr is the same, it can be factorized
};
mgr = {
enable = true;
daemons = [ config.networking.hostName ];
};
};
};
}

View file

@ -0,0 +1,21 @@
# SPDX-FileCopyrightText: 2024 Ryan Lahfa <ryan@dgnum.eu>
# SPDX-FileContributor: Elias Coppens <elias@dgnum.eu>
#
# SPDX-License-Identifier: EUPL-1.2
{ config, lib, ... }:
let
cfg = config.dgn-hypervisor;
inherit (lib) mkEnableOption mkIf;
in
{
options.dgn-hypervisor.enable = mkEnableOption "the Incus hypervisor";
config = mkIf cfg.enable {
networking.firewall.allowedTCPPorts = [ 8443 ];
virtualisation.incus = {
enable = true;
ui.enable = true;
};
};
}