mirror of
https://git.pvv.ntnu.no/Drift/pvv-nixos-config.git
synced 2025-12-31 20:58:23 +01:00
Compare commits
6 Commits
nix-topolo
...
alps
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
843f8d6a02 | ||
|
|
c0000a1eb6 | ||
|
|
243b665eae | ||
|
|
ab5be48b1c | ||
|
|
f671db8a12 | ||
|
|
ad61336a20 |
32
.gitea/workflows/build-topology-graph.yml
Normal file
32
.gitea/workflows/build-topology-graph.yml
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
name: "Build topology graph"
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
jobs:
|
||||||
|
evals:
|
||||||
|
runs-on: debian-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v6
|
||||||
|
|
||||||
|
- name: Install sudo
|
||||||
|
run: apt-get update && apt-get -y install sudo
|
||||||
|
|
||||||
|
- uses: https://github.com/cachix/install-nix-action@v31
|
||||||
|
|
||||||
|
- name: Configure Nix
|
||||||
|
run: echo -e "show-trace = true\nmax-jobs = auto\ntrusted-users = root\nexperimental-features = nix-command flakes\nbuild-users-group =" > /etc/nix/nix.conf
|
||||||
|
|
||||||
|
- name: Build topology graph
|
||||||
|
run: nix build .#topology -L
|
||||||
|
|
||||||
|
- name: Upload topology graph
|
||||||
|
uses: https://git.pvv.ntnu.no/Projects/rsync-action@v2
|
||||||
|
with:
|
||||||
|
source: result/*.svg
|
||||||
|
quote-source: false
|
||||||
|
target: ${{ gitea.ref_name }}/topology_graph/
|
||||||
|
username: gitea-web
|
||||||
|
ssh-key: ${{ secrets.WEB_SYNC_SSH_KEY }}
|
||||||
|
host: pages.pvv.ntnu.no
|
||||||
|
known-hosts: "pages.pvv.ntnu.no ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIH2QjfFB+city1SYqltkVqWACfo1j37k+oQQfj13mtgg"
|
||||||
24
flake.lock
generated
24
flake.lock
generated
@@ -273,11 +273,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1764806471,
|
"lastModified": 1767043167,
|
||||||
"narHash": "sha256-Qk0SArnS83KqyS9wNt1YoTkkYKDraNrjRWKUtB9DKoM=",
|
"narHash": "sha256-wN04/SL+8tV0D2HBIgt9dpX/03U18xoJ+8PT+dcn30E=",
|
||||||
"rev": "6707b1809330d0f912f5813963bb29f6f194ee81",
|
"rev": "0b43a6ee07997a6e319e92dcbf276c2736506944",
|
||||||
"type": "tarball",
|
"type": "tarball",
|
||||||
"url": "https://releases.nixos.org/nixos/25.11-small/nixos-25.11.896.6707b1809330/nixexprs.tar.xz"
|
"url": "https://releases.nixos.org/nixos/25.11-small/nixos-25.11.2789.0b43a6ee0799/nixexprs.tar.xz"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"type": "tarball",
|
"type": "tarball",
|
||||||
@@ -286,11 +286,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs-unstable": {
|
"nixpkgs-unstable": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1764854611,
|
"lastModified": 1767031366,
|
||||||
"narHash": "sha256-MVzFp4ZKwdh6U1wy4fJe/GY3Hb4cvvyJbAZOhaeBQoo=",
|
"narHash": "sha256-SJz8tVEnXusU8OzN5ixAXQgzXv8fNIzp9ztzUyobh4s=",
|
||||||
"rev": "3a4b875aef660bbd148e86b92cffea2a360c3275",
|
"rev": "d23fedd87fcd067b1d160323fae0d0e4f995527d",
|
||||||
"type": "tarball",
|
"type": "tarball",
|
||||||
"url": "https://releases.nixos.org/nixos/unstable-small/nixos-26.05pre906534.3a4b875aef66/nixexprs.tar.xz"
|
"url": "https://releases.nixos.org/nixos/unstable-small/nixos-26.05pre918279.d23fedd87fcd/nixexprs.tar.xz"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"type": "tarball",
|
"type": "tarball",
|
||||||
@@ -352,11 +352,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1765978548,
|
"lastModified": 1767080188,
|
||||||
"narHash": "sha256-VDSPpw+/Mgo+JujoW12CRlkTs9o0tX/FEL2AR5kl5+Q=",
|
"narHash": "sha256-BmyPuWeSQ9XREyi0KSerWRfJndmyzHNJLysBJld/KwA=",
|
||||||
"ref": "main",
|
"ref": "main",
|
||||||
"rev": "961f021d27f86b2aedd16290dbf85bdd9d50fd42",
|
"rev": "08a216f4473e26aa2a5349e72633c0ab24e8ffbd",
|
||||||
"revCount": 532,
|
"revCount": 534,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://git.pvv.ntnu.no/Projects/nettsiden.git"
|
"url": "https://git.pvv.ntnu.no/Projects/nettsiden.git"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -264,6 +264,10 @@
|
|||||||
overlays = [ inputs.nix-topology.overlays.default ];
|
overlays = [ inputs.nix-topology.overlays.default ];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
specialArgs = {
|
||||||
|
values = import ./values.nix;
|
||||||
|
};
|
||||||
|
|
||||||
modules = [
|
modules = [
|
||||||
./topology
|
./topology
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
(fp /base)
|
(fp /base)
|
||||||
|
|
||||||
|
./services/alps.nix
|
||||||
./services/bluemap.nix
|
./services/bluemap.nix
|
||||||
./services/idp-simplesamlphp
|
./services/idp-simplesamlphp
|
||||||
./services/kerberos.nix
|
./services/kerberos.nix
|
||||||
|
|||||||
22
hosts/bekkalokk/services/alps.nix
Normal file
22
hosts/bekkalokk/services/alps.nix
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
{ config, lib, ... }:
|
||||||
|
let
|
||||||
|
cfg = config.services.alps;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
services.alps = {
|
||||||
|
enable = true;
|
||||||
|
theme = "sourcehut";
|
||||||
|
smtps.host = "smtp.pvv.ntnu.no";
|
||||||
|
imaps.host = "imap.pvv.ntnu.no";
|
||||||
|
bindIP = "127.0.0.1";
|
||||||
|
};
|
||||||
|
|
||||||
|
services.nginx.virtualHosts."alps.pvv.ntnu.no" = lib.mkIf cfg.enable {
|
||||||
|
enableACME = true;
|
||||||
|
forceSSL = true;
|
||||||
|
kTLS = true;
|
||||||
|
locations."/" = {
|
||||||
|
proxyPass = "http://${cfg.bindIP}:${toString cfg.port}";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
{ lib, config, ... }:
|
{ config, pkgs, lib, values, ... }:
|
||||||
let
|
let
|
||||||
inherit
|
inherit
|
||||||
(config.lib.topology)
|
(config.lib.topology)
|
||||||
@@ -8,8 +8,11 @@ let
|
|||||||
mkDevice
|
mkDevice
|
||||||
mkConnection
|
mkConnection
|
||||||
mkConnectionRev;
|
mkConnectionRev;
|
||||||
values = import ../values.nix;
|
|
||||||
in {
|
in {
|
||||||
|
imports = [
|
||||||
|
./non-nixos-machines.nix
|
||||||
|
];
|
||||||
|
|
||||||
### Networks
|
### Networks
|
||||||
|
|
||||||
networks.pvv = {
|
networks.pvv = {
|
||||||
@@ -29,6 +32,8 @@ in {
|
|||||||
|
|
||||||
networks.ntnu = {
|
networks.ntnu = {
|
||||||
name = "NTNU";
|
name = "NTNU";
|
||||||
|
cidrv4 = values.ntnu.ipv4-space;
|
||||||
|
cidrv6 = values.ntnu.ipv6-space;
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.internet = mkInternet {
|
nodes.internet = mkInternet {
|
||||||
@@ -47,84 +52,162 @@ in {
|
|||||||
|
|
||||||
nodes.ntnu-pvv-router = mkRouter "NTNU PVV Gateway" {
|
nodes.ntnu-pvv-router = mkRouter "NTNU PVV Gateway" {
|
||||||
interfaceGroups = [ ["wan1"] ["eth1"] ];
|
interfaceGroups = [ ["wan1"] ["eth1"] ];
|
||||||
connections.eth1 = mkConnection "brus-switch" "eth1";
|
connections.eth1 = mkConnection "knutsen" "em1";
|
||||||
interfaces.eth1.network = "pvv";
|
interfaces.eth1.network = "pvv";
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.brus-switch = mkSwitch "Brus Switch" {
|
|
||||||
interfaceGroups = [ (lib.genList (i: "eth${toString i}") 16) ];
|
|
||||||
|
|
||||||
connections.eth2 = mkConnection "bekkalokk" "enp2s0";
|
|
||||||
# connections.eth3 = mkConnection "bicep" "enp6s0f0";
|
|
||||||
connections.eth4 = mkConnection "buskerud" "eth1";
|
|
||||||
connections.eth5 = mkConnection "knutsen" "eth1";
|
|
||||||
connections.eth6 = mkConnection "powerpuff-cluster" "eth1";
|
|
||||||
|
|
||||||
connections.eth8 = mkConnection "lupine-1" "enp0s31f6";
|
|
||||||
connections.eth9 = mkConnection "lupine-2" "enp0s31f6";
|
|
||||||
connections.eth11 = mkConnection "lupine-3" "enp0s31f6";
|
|
||||||
connections.eth10 = mkConnection "lupine-4" "enp0s31f6";
|
|
||||||
connections.eth12 = mkConnection "lupine-5" "enp0s31f6";
|
|
||||||
};
|
|
||||||
|
|
||||||
nodes.knutsen = mkRouter "knutsen" {
|
nodes.knutsen = mkRouter "knutsen" {
|
||||||
interfaceGroups = [ ["eth1"] ["eth2"] ["vpn1"] ];
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/freebsd.svg";
|
||||||
connections.eth2 = mkConnectionRev "brus-switch" "eth6";
|
|
||||||
|
interfaceGroups = [ ["em0"] ["em1"] ["vpn1"] ];
|
||||||
|
|
||||||
|
connections.em0 = mkConnection "nintendo" "eth0";
|
||||||
|
|
||||||
# connections.vpn1 = mkConnection "ludvigsen" "vpn1";
|
# connections.vpn1 = mkConnection "ludvigsen" "vpn1";
|
||||||
interfaces.vpn1.network = "site-vpn";
|
interfaces.vpn1.network = "site-vpn";
|
||||||
interfaces.vpn1.virtual = true;
|
interfaces.vpn1.virtual = true;
|
||||||
|
interfaces.vpn1.icon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/openvpn.svg";
|
||||||
|
|
||||||
|
interfaces.em0.network = "pvv";
|
||||||
|
interfaces.em1.network = "ntnu";
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.nintendo = mkSwitch "Nintendo (brus switch)" {
|
||||||
|
interfaceGroups = [ (lib.genList (i: "eth${toString i}") 16) ];
|
||||||
|
|
||||||
|
connections = let
|
||||||
|
connections' = [
|
||||||
|
(mkConnection "bekkalokk" "enp2s0")
|
||||||
|
# (mkConnection "bicep" "enp6s0f0") # NOTE: physical machine is dead at the moment
|
||||||
|
(mkConnection "buskerud" "eth1")
|
||||||
|
# (mkConnection "knutsen" "eth1")
|
||||||
|
(mkConnection "powerpuff-cluster" "eth1")
|
||||||
|
(mkConnection "lupine-1" "enp0s31f6")
|
||||||
|
(mkConnection "lupine-2" "enp0s31f6")
|
||||||
|
(mkConnection "lupine-3" "enp0s31f6")
|
||||||
|
(mkConnection "lupine-4" "enp0s31f6")
|
||||||
|
(mkConnection "lupine-5" "enp0s31f6")
|
||||||
|
(mkConnection "innovation" "em0")
|
||||||
|
(mkConnection "microbel" "eth0")
|
||||||
|
(mkConnection "isvegg" "eth0")
|
||||||
|
(mkConnection "ameno" "eth0")
|
||||||
|
(mkConnection "sleipner" "eno0")
|
||||||
|
];
|
||||||
|
in
|
||||||
|
assert (lib.length connections' <= 15);
|
||||||
|
builtins.listToAttrs (
|
||||||
|
lib.zipListsWith
|
||||||
|
(a: b: lib.nameValuePair a b)
|
||||||
|
(lib.genList (i: "eth${toString (i + 1)}") 15)
|
||||||
|
connections'
|
||||||
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.buskerud = mkDevice "buskerud" {
|
nodes.buskerud = mkDevice "buskerud" {
|
||||||
|
deviceIcon = ./icons/proxmox.svg;
|
||||||
interfaceGroups = [ [ "eth1" ] ];
|
interfaceGroups = [ [ "eth1" ] ];
|
||||||
|
|
||||||
|
interfaces.eth1.network = "pvv";
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.shark = {
|
nodes.shark = {
|
||||||
guestType = "proxmox";
|
guestType = "proxmox";
|
||||||
parent = config.nodes.buskerud.id;
|
parent = config.nodes.buskerud.id;
|
||||||
|
|
||||||
|
interfaces.ens18.network = "pvv";
|
||||||
};
|
};
|
||||||
|
|
||||||
### Powerpuff
|
### Powerpuff
|
||||||
|
|
||||||
nodes.powerpuff-cluster = mkDevice "powerpuff-cluster" {
|
nodes.powerpuff-cluster = mkDevice "Powerpuff Cluster" {
|
||||||
|
deviceIcon = ./icons/proxmox.svg;
|
||||||
|
|
||||||
|
hardware.info = "Dell PowerEdge R730 x 3";
|
||||||
|
|
||||||
interfaceGroups = [ [ "eth1" ] ];
|
interfaceGroups = [ [ "eth1" ] ];
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.kommode = {
|
nodes.kommode = {
|
||||||
guestType = "proxmox";
|
guestType = "proxmox";
|
||||||
parent = config.nodes.powerpuff-cluster.id;
|
parent = config.nodes.powerpuff-cluster.id;
|
||||||
|
|
||||||
|
interfaces.ens18.network = "pvv";
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.bicep = {
|
nodes.bicep = {
|
||||||
guestType = "proxmox";
|
guestType = "proxmox";
|
||||||
parent = config.nodes.powerpuff-cluster.id;
|
parent = config.nodes.powerpuff-cluster.id;
|
||||||
|
|
||||||
|
# hardware.info = "HP Proliant DL370G6";
|
||||||
|
|
||||||
|
interfaces.ens18.network = "pvv";
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.ustetind = {
|
nodes.ustetind = {
|
||||||
guestType = "proxmox";
|
guestType = "proxmox LXC";
|
||||||
parent = config.nodes.powerpuff-cluster.id;
|
parent = config.nodes.powerpuff-cluster.id;
|
||||||
|
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
# interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
network = "pvv";
|
||||||
|
# mac = "";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.234"
|
||||||
|
"2001:700:300:1900::234"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
### PVV
|
### PVV
|
||||||
|
|
||||||
nodes.ntnu-veggen = mkRouter "NTNU-Veggen" {
|
nodes.ntnu-veggen = mkRouter "NTNU-Veggen" {
|
||||||
interfaceGroups = [ ["wan1"] ["eth1"] ];
|
interfaceGroups = [ ["wan1"] ["eth1"] ];
|
||||||
connections.eth1 = mkConnection "ludvigsen" "eth1";
|
connections.eth1 = mkConnection "ludvigsen" "re0";
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.ludvigsen = mkRouter "ludvigsen" {
|
nodes.ludvigsen = mkRouter "ludvigsen" {
|
||||||
interfaceGroups = [ ["eth1"] ["eth2"] ["vpn1"] ];
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/freebsd.svg";
|
||||||
connections.eth2 = mkConnection "pvv-switch" "eth1";
|
|
||||||
|
interfaceGroups = [ [ "re0" ] [ "em0" ] [ "vpn1" ] ];
|
||||||
|
|
||||||
|
connections.em0 = mkConnection "pvv-switch" "eth0";
|
||||||
|
|
||||||
interfaces.vpn1.network = "site-vpn";
|
interfaces.vpn1.network = "site-vpn";
|
||||||
interfaces.vpn1.virtual = true;
|
interfaces.vpn1.virtual = true;
|
||||||
interfaces.eth1.network = "ntnu";
|
interfaces.vpn1.icon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/openvpn.svg";
|
||||||
interfaces.eth2.network = "pvv";
|
|
||||||
|
interfaces.re0.network = "ntnu";
|
||||||
|
interfaces.em0.network = "pvv";
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.pvv-switch = mkSwitch "PVV Switch (Terminalrommet)" {
|
nodes.pvv-switch = mkSwitch "PVV Switch (Terminalrommet)" {
|
||||||
interfaceGroups = [ ["eth1" "eth2" "eth3"] ];
|
interfaceGroups = [ (lib.genList (i: "eth${toString i}") 16) ];
|
||||||
connections.eth2 = mkConnection "brzeczyszczykiewicz" "eno1";
|
connections = let
|
||||||
connections.eth3 = mkConnection "georg" "eno1";
|
connections' = [
|
||||||
|
(mkConnection "brzeczyszczykiewicz" "eno1")
|
||||||
|
(mkConnection "georg" "eno1")
|
||||||
|
(mkConnection "wegonke" "enp4s0")
|
||||||
|
(mkConnection "demiurgen" "eno1")
|
||||||
|
(mkConnection "sanctuary" "ethernet_0")
|
||||||
|
(mkConnection "torskas" "eth0")
|
||||||
|
(mkConnection "skrott" "eth0")
|
||||||
|
(mkConnection "homeassistant" "eth0")
|
||||||
|
(mkConnection "orchid" "eth0")
|
||||||
|
(mkConnection "principal" "em0")
|
||||||
|
];
|
||||||
|
in
|
||||||
|
assert (lib.length connections' <= 15);
|
||||||
|
builtins.listToAttrs (
|
||||||
|
lib.zipListsWith
|
||||||
|
(a: b: lib.nameValuePair a b)
|
||||||
|
(lib.genList (i: "eth${toString (i + 1)}") 15)
|
||||||
|
connections'
|
||||||
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -132,18 +215,26 @@ in {
|
|||||||
|
|
||||||
nodes.stackit = mkDevice "stackit" {
|
nodes.stackit = mkDevice "stackit" {
|
||||||
interfaceGroups = [ [ "*" ] ];
|
interfaceGroups = [ [ "*" ] ];
|
||||||
|
|
||||||
|
interfaces."*".network = "ntnu";
|
||||||
};
|
};
|
||||||
|
|
||||||
nodes.ildkule = {
|
nodes.ildkule = {
|
||||||
guestType = "openstack";
|
guestType = "openstack";
|
||||||
parent = config.nodes.stackit.id;
|
parent = config.nodes.stackit.id;
|
||||||
|
|
||||||
|
interfaces.ens4.network = "ntnu";
|
||||||
};
|
};
|
||||||
nodes.wenche = {
|
nodes.wenche = {
|
||||||
guestType = "openstack";
|
guestType = "openstack";
|
||||||
parent = config.nodes.stackit.id;
|
parent = config.nodes.stackit.id;
|
||||||
|
|
||||||
|
interfaces.ens18.network = "pvv";
|
||||||
};
|
};
|
||||||
nodes.bakke = {
|
nodes.bakke = {
|
||||||
guestType = "openstack";
|
guestType = "openstack";
|
||||||
parent = config.nodes.stackit.id;
|
parent = config.nodes.stackit.id;
|
||||||
|
|
||||||
|
interfaces.enp2s0.network = "pvv";
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
BIN
topology/icons/bind9.png
Normal file
BIN
topology/icons/bind9.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 13 KiB |
5
topology/icons/proxmox.svg
Normal file
5
topology/icons/proxmox.svg
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?><!-- Uploaded to: SVG Repo, www.svgrepo.com, Generator: SVG Repo Mixer Tools -->
|
||||||
|
<svg width="800px" height="800px" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<circle cx="512" cy="512" r="512" style="fill:#e57000"/>
|
||||||
|
<path d="M512 497.8 342.7 311.6c6.6-6.6 14.2-11.7 22.9-15.5 8.7-3.8 18.1-5.7 28.1-5.7 10.7.1 20.4 2.2 29.3 6.3 8.9 4.1 16.6 9.8 23.1 17l65.8 71.9 65.4-71.9c6.8-7.2 14.7-12.9 23.6-17 9-4.1 18.7-6.2 29.2-6.3 10 .1 19.4 2 28.1 5.7 8.7 3.8 16.4 8.9 22.9 15.5L512 497.8m0 28.4L342.7 712.4c6.6 6.6 14.2 11.7 22.9 15.5 8.7 3.8 18.1 5.7 28.1 5.7 10.5-.1 20.2-2.2 29.2-6.3s16.9-9.8 23.6-17l65.4-71.9 65.8 71.9c6.5 7.2 14.2 12.9 23.1 17 8.9 4.1 18.6 6.2 29.3 6.3 10-.1 19.4-2 28.1-5.7 8.7-3.8 16.4-8.9 22.9-15.5L512 526.2M497.8 512 370.3 372.2c-7.4-7.9-16-14.1-25.9-18.7-9.8-4.5-20.5-6.8-31.9-6.9-11 .1-21.3 2.2-30.8 6.3-9.6 4.1-17.9 9.8-25.1 16.9L385.9 512 256.5 654.2c7.2 7.4 15.6 13.2 25.1 17.4 9.6 4.2 19.8 6.3 30.8 6.3 11.5-.1 22.2-2.4 32.1-6.9 9.9-4.5 18.5-10.8 25.7-18.7L497.8 512m28.4 0 127.5 140.3c7.2 7.9 15.8 14.1 25.7 18.7 9.9 4.5 20.6 6.8 32.1 6.9 11-.1 21.3-2.2 30.8-6.3 9.6-4.2 17.9-9.9 25.1-17.4L638.1 512l129.4-142.2c-7.2-7.2-15.6-12.8-25.1-16.9-9.6-4.1-19.8-6.2-30.8-6.3-11.4.1-22.1 2.4-31.9 6.9-9.8 4.5-18.5 10.8-25.9 18.7L526.2 512" style="fill:#fff"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.3 KiB |
362
topology/non-nixos-machines.nix
Normal file
362
topology/non-nixos-machines.nix
Normal file
@@ -0,0 +1,362 @@
|
|||||||
|
{ config, pkgs, lib, values, ... }:
|
||||||
|
let
|
||||||
|
inherit (config.lib.topology) mkDevice;
|
||||||
|
in {
|
||||||
|
nodes.balduzius = mkDevice "balduzius" {
|
||||||
|
guestType = "proxmox";
|
||||||
|
parent = config.nodes.powerpuff-cluster.id;
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "ens18" ] ];
|
||||||
|
interfaces.ens18 = {
|
||||||
|
network = "pvv";
|
||||||
|
mac = "00:0c:29:de:05:0f";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.192"
|
||||||
|
"2001:700:300:1900::1:42"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
services = {
|
||||||
|
kdc = {
|
||||||
|
name = "Heimdal KDC";
|
||||||
|
info = "kdc.pvv.ntnu.no";
|
||||||
|
details.kdc.text = "0.0.0.0:88";
|
||||||
|
details.kpasswd.text = "0.0.0.0:464";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.tom = mkDevice "tom" {
|
||||||
|
guestType = "proxmox";
|
||||||
|
parent = config.nodes.powerpuff-cluster.id;
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "ens18" ] ];
|
||||||
|
interfaces.ens18 = {
|
||||||
|
network = "pvv";
|
||||||
|
mac = "00:0c:29:4d:f7:56";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.180"
|
||||||
|
"2001:700:300:1900::180"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
|
services = {
|
||||||
|
apache2 = {
|
||||||
|
name = "Apache2 - user websites";
|
||||||
|
info = "www.pvv.ntnu.no/~";
|
||||||
|
details.listen.text = "0.0.0.0:443";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.hildring = mkDevice "hildring" {
|
||||||
|
guestType = "proxmox";
|
||||||
|
parent = config.nodes.powerpuff-cluster.id;
|
||||||
|
deviceType = "loginbox";
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
network = "pvv";
|
||||||
|
mac = "00:0c:29:e7:dd:79";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.176"
|
||||||
|
"2001:700:300:1900::1:9"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.drolsum = mkDevice "drolsum" {
|
||||||
|
guestType = "proxmox";
|
||||||
|
parent = config.nodes.powerpuff-cluster.id;
|
||||||
|
deviceType = "loginbox";
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
network = "pvv";
|
||||||
|
# mac = "";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.217"
|
||||||
|
"2001:700:300:1900::217"
|
||||||
|
"2001:700:300:1900::1:217"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.microbel = mkDevice "microbel" {
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
hardware.info = "Supermicro X8ST3";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "eth0" "eth1" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
mac = "00:25:90:24:76:2c";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.179"
|
||||||
|
"2001:700:300:1900::1:2"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.innovation = mkDevice "innovation" {
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/freebsd.svg";
|
||||||
|
|
||||||
|
hardware.info = "Dell Optiplex 9010";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "em0" ] ];
|
||||||
|
interfaces.em0 = {
|
||||||
|
mac = "18:03:73:20:18:d3";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.214"
|
||||||
|
"2001:700:300:1900::1:56"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
services = {
|
||||||
|
minecraft = {
|
||||||
|
name = "Minecraft";
|
||||||
|
icon = "services.minecraft";
|
||||||
|
info = "minecraft.pvv.ntnu.no";
|
||||||
|
details.listen.text = "0.0.0.0:25565";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.principal = mkDevice "principal" {
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/freebsd.svg";
|
||||||
|
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
interfaceGroups = [ [ "em0" ] ];
|
||||||
|
interfaces.em0 = {
|
||||||
|
# mac = "";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.233"
|
||||||
|
"2001:700:300:1900::1:233"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.homeassistant = mkDevice "homeassistant" {
|
||||||
|
deviceIcon = "services.home-assistant";
|
||||||
|
|
||||||
|
hardware.info = "Raspberry Pi 4B";
|
||||||
|
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
# mac = "";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.229"
|
||||||
|
"2001:700:300:1900::4:229"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.sleipner = mkDevice "sleipner" {
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "eno0" "enp2s0" ] ];
|
||||||
|
interfaces.enp2s0 = {
|
||||||
|
mac = "00:25:90:57:35:8e";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.193"
|
||||||
|
"2001:700:300:1900:fab:cab:dab:7ab"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.isvegg = mkDevice "isvegg" {
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
# mac = "";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.175"
|
||||||
|
"2001:700:300:1900::1:a"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.ameno = mkDevice "ameno" {
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/ubuntu.svg";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
mac = "b8:27:eb:62:1d:d8";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.230"
|
||||||
|
"129.241.210.211"
|
||||||
|
"129.241.210.153"
|
||||||
|
"2001:700:300:1900:ba27:ebff:fe62:1dd8"
|
||||||
|
"2001:700:300:1900::4:230"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
services = {
|
||||||
|
bind = {
|
||||||
|
name = "Bind DNS";
|
||||||
|
icon = ./icons/bind9.png;
|
||||||
|
info = "hostmaster.pvv.ntnu.no";
|
||||||
|
details.listen.text = "0.0.0.0:53";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.skrott = mkDevice "skrott" {
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
# mac = "";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.235"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.torskas = mkDevice "torskas" {
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/arch_linux.svg";
|
||||||
|
|
||||||
|
hardware.info = "Raspberry pi 4B";
|
||||||
|
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
# mac = "";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.241"
|
||||||
|
"2001:700:300:1900::241"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.wegonke = mkDevice "wegonke" {
|
||||||
|
deviceType = "terminal";
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
hardware.info = "ASUSTeK G11CD-K";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "enp4s0" ] ];
|
||||||
|
interfaces.enp4s0 = {
|
||||||
|
mac = "70:4d:7b:a3:32:57";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.218"
|
||||||
|
"2001:700:300:1900::1:218"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.demiurgen = mkDevice "demiurgen" {
|
||||||
|
deviceType = "terminal";
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "eno1" ] ];
|
||||||
|
interfaces.eno1 = {
|
||||||
|
mac = "18:03:73:1f:f4:1f";
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.201"
|
||||||
|
"2001:700:300:1900::1:4e"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.sanctuary = mkDevice "sanctuary" {
|
||||||
|
deviceType = "terminal";
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/windows.svg";
|
||||||
|
|
||||||
|
interfaceGroups = [ [ "ethernet_0" ] ];
|
||||||
|
interfaces.ethernet_0 = {
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.170"
|
||||||
|
"2001:700:300:1900::1337"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nodes.orchid = mkDevice "orchid" {
|
||||||
|
deviceType = "terminal";
|
||||||
|
deviceIcon = "${pkgs.super-tiny-icons}/share/icons/SuperTinyIcons/svg/debian.svg";
|
||||||
|
|
||||||
|
hardware.info = "Ryzen1600 Nvidia GTX 1060";
|
||||||
|
|
||||||
|
# TODO: the interface name is likely wrong
|
||||||
|
interfaceGroups = [ [ "eth0" ] ];
|
||||||
|
interfaces.eth0 = {
|
||||||
|
addresses = [
|
||||||
|
"129.241.210.210"
|
||||||
|
"2001:700:300:1900::210"
|
||||||
|
];
|
||||||
|
gateways = [
|
||||||
|
values.hosts.gateway
|
||||||
|
values.hosts.gateway6
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user