From 7bf86799fb3467c87afef28e2714d7e20341b5ec Mon Sep 17 00:00:00 2001 From: gabo Date: Sat, 12 Oct 2024 17:14:48 +0200 Subject: [PATCH] Ajout VM Bitwarden --- hosts/vm/vaultwarden/default.nix | 15 ++++++ .../vm/vaultwarden/hardware-configuration.nix | 32 +++++++++++ hosts/vm/vaultwarden/networking.nix | 53 +++++++++++++++++++ 3 files changed, 100 insertions(+) create mode 100644 hosts/vm/vaultwarden/default.nix create mode 100644 hosts/vm/vaultwarden/hardware-configuration.nix create mode 100644 hosts/vm/vaultwarden/networking.nix diff --git a/hosts/vm/vaultwarden/default.nix b/hosts/vm/vaultwarden/default.nix new file mode 100644 index 0000000..1396d4b --- /dev/null +++ b/hosts/vm/vaultwarden/default.nix @@ -0,0 +1,15 @@ +{ ... }: + +{ + imports = [ + ./hardware-configuration.nix + ./networking.nix + + ../../../modules + ]; + + networking.hostName = "vaultwarden"; + boot.loader.grub.devices = [ "/dev/sda" ]; + + system.stateVersion = "23.11"; +} diff --git a/hosts/vm/vaultwarden/hardware-configuration.nix b/hosts/vm/vaultwarden/hardware-configuration.nix new file mode 100644 index 0000000..dd003c8 --- /dev/null +++ b/hosts/vm/vaultwarden/hardware-configuration.nix @@ -0,0 +1,32 @@ +# Do not modify this file! It was generated by ‘nixos-generate-config’ +# and may be overwritten by future invocations. Please make changes +# to /etc/nixos/configuration.nix instead. +{ config, lib, pkgs, modulesPath, ... }: + +{ + imports = + [ (modulesPath + "/profiles/qemu-guest.nix") + ]; + + boot.initrd.availableKernelModules = [ "ata_piix" "uhci_hcd" "virtio_pci" "virtio_scsi" "sd_mod" "sr_mod" ]; + boot.initrd.kernelModules = [ ]; + boot.kernelModules = [ ]; + boot.extraModulePackages = [ ]; + + fileSystems."/" = + { device = "/dev/disk/by-uuid/03214fba-5aad-4f5d-9e0c-da089dcb5d2b"; + fsType = "ext4"; + }; + + swapDevices = [ ]; + + # Enables DHCP on each ethernet and wireless interface. In case of scripted networking + # (the default) this is the recommended approach. When using systemd-networkd it's + # still possible to use this option, but it's recommended to use it in conjunction + # with explicit per-interface declarations with `networking.interfaces..useDHCP`. + networking.useDHCP = lib.mkDefault true; + # networking.interfaces.ens18.useDHCP = lib.mkDefault true; + # networking.interfaces.ens19.useDHCP = lib.mkDefault true; + + nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; +} diff --git a/hosts/vm/vaultwarden/networking.nix b/hosts/vm/vaultwarden/networking.nix new file mode 100644 index 0000000..5e870b4 --- /dev/null +++ b/hosts/vm/vaultwarden/networking.nix @@ -0,0 +1,53 @@ +{ ... }: + +{ + networking = { + interfaces = { + ens18 = { + + ipv4 = { + addresses = [{ + address = "172.16.10.159"; + prefixLength = 24; + }]; + }; + + ipv6 = { + addresses = [{ + address = "fd00::10:0:ff:fe01:5910"; + prefixLength = 64; + }]; + }; + + }; + + ens19 = { + + ipv4 = { + addresses = [{ + address = "172.16.3.159"; + prefixLength = 24; + }]; + routes = [{ + address = "0.0.0.0"; + via = "172.16.3.99"; + prefixLength = 0; + }]; + }; + + ipv6 = { + addresses = [{ + address = "2a0c:700:3::ff:fe01:5903"; + prefixLength = 64; + }]; + routes = [{ + address = "::"; + via = "2a0c:700:3::ff:fe00:9903"; + prefixLength = 0; + }]; + }; + + }; + }; + }; +}