commit
0fcac4d53c
@ -0,0 +1,209 @@ |
||||
let |
||||
cdn-node-setup = args@{ domain, config_file, ... }: { |
||||
deployment.targetHost = domain; |
||||
nixpkgs.localSystem.system = "x86_64-linux"; |
||||
imports = |
||||
[ |
||||
config_file |
||||
]; |
||||
|
||||
|
||||
networking.firewall.allowedTCPPorts = [ |
||||
80 # HTTP |
||||
443 # HTTPs |
||||
]; |
||||
|
||||
# Enable nginx service |
||||
services.nginx = { |
||||
|
||||
enable = true; |
||||
# Use recommended settings |
||||
# Don't use recommended Proxy settings because it does funky things with the setup |
||||
recommendedGzipSettings = true; |
||||
recommendedOptimisation = true; |
||||
recommendedTlsSettings = true; |
||||
virtualHosts.${domain} = { |
||||
|
||||
forceSSL = true; |
||||
enableACME = true; |
||||
locations = { |
||||
"~* \\.(m3u8)$" = { |
||||
proxyPass = "https://cdn-master.lukas.studio$request_uri"; |
||||
|
||||
extraConfig = '' |
||||
#proxy_cache = off; |
||||
expires -1; |
||||
''; |
||||
}; |
||||
"/hls" = { |
||||
proxyPass = "https://cdn-master.lukas.studio$request_uri"; |
||||
extraConfig = '' |
||||
types { |
||||
application/vnd.apple.mpegurl m3u8; |
||||
video/mp2t ts; |
||||
} |
||||
proxy_cache hls; |
||||
proxy_ignore_headers Cache-Control; |
||||
proxy_cache_valid any 30m; |
||||
''; |
||||
|
||||
}; |
||||
|
||||
}; |
||||
|
||||
|
||||
|
||||
|
||||
}; |
||||
appendHttpConfig = '' |
||||
proxy_cache_path /tmp keys_zone=hls:10m max_size=10g inactive=60m use_temp_path=on; |
||||
resolver 1.1.1.1; |
||||
''; |
||||
|
||||
}; |
||||
security.acme.certs = { |
||||
${domain}.email = "allesmoeglicheundvielmehr@hotmail.de"; |
||||
}; |
||||
security.acme.acceptTerms = true; |
||||
}; |
||||
|
||||
cdn-master-setup = args@{ domain, config_file, host-server, ... }: { |
||||
deployment.targetHost = domain; |
||||
nixpkgs.localSystem.system = "x86_64-linux"; |
||||
imports = |
||||
[ |
||||
config_file |
||||
]; |
||||
|
||||
|
||||
networking.firewall.allowedTCPPorts = [ |
||||
80 # HTTP |
||||
443 # HTTPs |
||||
]; |
||||
|
||||
# Enable nginx service |
||||
services.nginx = { |
||||
|
||||
enable = true; |
||||
# Use recommended settings |
||||
# Don't use recommendea Proxy settings because it does funky things with the setup |
||||
recommendedGzipSettings = true; |
||||
recommendedOptimisation = true; |
||||
recommendedTlsSettings = true; |
||||
virtualHosts.${domain} = { |
||||
|
||||
forceSSL = true; |
||||
enableACME = true; |
||||
locations = { |
||||
"~* \\.(m3u8)$" = { |
||||
proxyPass = "${host-server}$request_uri"; |
||||
|
||||
extraConfig = '' |
||||
#proxy_cache = off; |
||||
expires -1; |
||||
''; |
||||
}; |
||||
"/hls" = { |
||||
proxyPass = "${host-server}$request_uri"; |
||||
extraConfig = '' |
||||
types { |
||||
application/vnd.apple.mpegurl m3u8; |
||||
video/mp2t ts; |
||||
} |
||||
proxy_cache hls; |
||||
proxy_ignore_headers Cache-Control; |
||||
proxy_cache_valid any 30m; |
||||
''; |
||||
|
||||
}; |
||||
|
||||
}; |
||||
}; |
||||
appendHttpConfig = '' |
||||
proxy_cache_path /tmp keys_zone=hls:10m max_size=10g inactive=60m use_temp_path=on; |
||||
resolver 1.1.1.1; |
||||
''; |
||||
|
||||
}; |
||||
security.acme.certs = { |
||||
${domain}.email = "allesmoeglicheundvielmehr@hotmail.de"; |
||||
}; |
||||
security.acme.acceptTerms = true; |
||||
}; |
||||
|
||||
cdn-loadbalancer-setup = args@{ domain, config_file, nodes, ... }: { |
||||
deployment.targetHost = domain; |
||||
nixpkgs.localSystem.system = "x86_64-linux"; |
||||
imports = |
||||
[ |
||||
config_file |
||||
]; |
||||
|
||||
|
||||
networking.firewall.allowedTCPPorts = [ |
||||
80 # HTTP |
||||
443 # HTTPs |
||||
]; |
||||
|
||||
# Enable nginx service |
||||
services.nginx = { |
||||
|
||||
enable = true; |
||||
|
||||
# Use recommended settings |
||||
# Don't use recommended Proxy settings because it does funky things with the setup |
||||
recommendedGzipSettings = true; |
||||
recommendedOptimisation = true; |
||||
recommendedTlsSettings = true; |
||||
virtualHosts.${domain} = { |
||||
locations = { |
||||
"/" = { |
||||
return = "301 \"http://\$\{cdnhosts\}\$\{request_uri\}\""; |
||||
}; |
||||
}; |
||||
forceSSL = true; |
||||
enableACME = true; |
||||
}; |
||||
appendHttpConfig = '' |
||||
split_clients "''\$''\{remote_addr''\}" $cdnhosts { |
||||
50% "cdn-node-1.lukas.studio"; |
||||
50% "cdn-node-2.lukas.studio"; |
||||
} |
||||
''; |
||||
}; |
||||
|
||||
|
||||
security.acme.certs = { |
||||
${domain}.email = "allesmoeglicheundvielmehr@hotmail.de"; |
||||
}; |
||||
security.acme.acceptTerms = true; |
||||
}; |
||||
|
||||
|
||||
in |
||||
{ |
||||
network.description = "CDN for some stuff"; |
||||
#network.enableRollback = true; |
||||
|
||||
cdn-node-1 = cdn-node-setup { |
||||
domain="cdn-node-1.lukas.studio"; |
||||
config_file="/Users/lukas/Documents/nixops/configuration-cdn-node-1.nix"; |
||||
}; |
||||
cdn-node-2 = cdn-node-setup { |
||||
domain="cdn-node-2.lukas.studio"; |
||||
config_file="/Users/lukas/Documents/nixops/configuration-cdn-node-2.nix"; |
||||
}; |
||||
cdn-master = cdn-master-setup { |
||||
domain="cdn-master.lukas.studio"; |
||||
config_file="/Users/lukas/Documents/nixops/configuration-cdn-master.nix"; |
||||
host-server = "https://rosenbaum.lukas.studio"; |
||||
}; |
||||
cdn-loadbalancer = cdn-loadbalancer-setup { |
||||
domain="cdn-loadbalancer.lukas.studio"; |
||||
config_file="/Users/lukas/Documents/nixops/configuration-cdn-loadbalancer.nix"; |
||||
nodes= { |
||||
# implement automatic node setting |
||||
}; |
||||
}; |
||||
|
||||
} |
@ -0,0 +1,120 @@ |
||||
# Edit this configuration file to define what should be installed on |
||||
# your system. Help is available in the configuration.nix(5) man page |
||||
# and in the NixOS manual (accessible by running ‘nixos-help’). |
||||
|
||||
{ config, pkgs, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ # Include the results of the hardware scan. |
||||
./hardware-configuration-cdn-loadbalancer.nix |
||||
]; |
||||
|
||||
# Use the GRUB 2 boot loader. |
||||
boot.loader.grub.enable = true; |
||||
boot.loader.grub.version = 2; |
||||
# boot.loader.grub.efiSupport = true; |
||||
# boot.loader.grub.efiInstallAsRemovable = true; |
||||
# boot.loader.efi.efiSysMountPoint = "/boot/efi"; |
||||
# Define on which hard drive you want to install Grub. |
||||
# boot.loader.grub.device = "/dev/sda"; # or "nodev" for efi only |
||||
|
||||
# networking.hostName = "nixos"; # Define your hostname. |
||||
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. |
||||
|
||||
# The global useDHCP flag is deprecated, therefore explicitly set to false here. |
||||
# Per-interface useDHCP will be mandatory in the future, so this generated config |
||||
# replicates the default behaviour. |
||||
networking.useDHCP = false; |
||||
networking.interfaces.ens3.useDHCP = true; |
||||
|
||||
# Configure network proxy if necessary |
||||
# networking.proxy.default = "http://user:password@proxy:port/"; |
||||
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; |
||||
|
||||
# Select internationalisation properties. |
||||
# i18n.defaultLocale = "en_US.UTF-8"; |
||||
# console = { |
||||
# font = "Lat2-Terminus16"; |
||||
# keyMap = "us"; |
||||
# }; |
||||
|
||||
# Set your time zone. |
||||
# time.timeZone = "Europe/Amsterdam"; |
||||
|
||||
# List packages installed in system profile. To search, run: |
||||
# $ nix search wget |
||||
# environment.systemPackages = with pkgs; [ |
||||
# wget vim |
||||
# ]; |
||||
|
||||
# Some programs need SUID wrappers, can be configured further or are |
||||
# started in user sessions. |
||||
# programs.mtr.enable = true; |
||||
# programs.gnupg.agent = { |
||||
# enable = true; |
||||
# enableSSHSupport = true; |
||||
# pinentryFlavor = "gnome3"; |
||||
# }; |
||||
|
||||
# List services that you want to enable: |
||||
|
||||
# Enable the OpenSSH daemon. |
||||
# services.openssh.enable = true; |
||||
|
||||
# Open ports in the firewall. |
||||
# networking.firewall.allowedTCPPorts = [ ... ]; |
||||
# networking.firewall.allowedUDPPorts = [ ... ]; |
||||
# Or disable the firewall altogether. |
||||
# networking.firewall.enable = false; |
||||
|
||||
# Enable CUPS to print documents. |
||||
# services.printing.enable = true; |
||||
|
||||
# Enable sound. |
||||
# sound.enable = true; |
||||
# hardware.pulseaudio.enable = true; |
||||
|
||||
# Enable the X11 windowing system. |
||||
# services.xserver.enable = true; |
||||
# services.xserver.layout = "us"; |
||||
# services.xserver.xkbOptions = "eurosign:e"; |
||||
|
||||
# Enable touchpad support. |
||||
# services.xserver.libinput.enable = true; |
||||
|
||||
# Enable the KDE Desktop Environment. |
||||
# services.xserver.displayManager.sddm.enable = true; |
||||
# services.xserver.desktopManager.plasma5.enable = true; |
||||
|
||||
# Define a user account. Don't forget to set a password with ‘passwd’. |
||||
# users.users.jane = { |
||||
# isNormalUser = true; |
||||
# extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user. |
||||
# }; |
||||
|
||||
# This value determines the NixOS release from which the default |
||||
# settings for stateful data, like file locations and database versions |
||||
# on your system were taken. It‘s perfectly fine and recommended to leave |
||||
# this value at the release version of the first install of this system. |
||||
# Before changing this value read the documentation for this option |
||||
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). |
||||
system.stateVersion = "20.03"; # Did you read the comment? |
||||
|
||||
|
||||
|
||||
|
||||
boot.loader.grub.devices = [ "/dev/sda" ]; |
||||
|
||||
# Initial empty root password for easy login: |
||||
users.users.root.initialHashedPassword = ""; |
||||
services.openssh.permitRootLogin = "prohibit-password"; |
||||
|
||||
services.openssh.enable = true; |
||||
|
||||
# Replace this by your SSH pubkey |
||||
users.users.root.openssh.authorizedKeys.keys = [ |
||||
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCt34ou3NYWoUayWrJa5ISzihAAhFiwolJPmm2fF9llPUUA8DP3BQRiKeqDlkDzhWLwztb+dNIUuregiFJdRN5Q2JZBKlM7Gqb1QtPhtK+xe2pyZPX2SWKIsKA6j3VAThhXsQdj3slXu3dG8FF7j+IFg/eTgpeQIFQQkMIc204ha8OP2ASYAJqgJVbXq8Xh3KkAc1HSrjYJLntryvK10wyU8p3ug370dMu3vRUn44FEyDzXFM9rfsgysQTzVgp+sXdRfMLeyvf+SUrE8hiPjzevF2nsUP0Xf/rIaK5VayChPLXJkulognINzvuVWAdwNPDLpgGwkjglF2681Ag88bLX allesmoeglicheundvielmehr@hotmail.de" |
||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDNVUDKx9sukRkb6INny432+2HZBWx/qIEAOvngF1qcj hexchen@montasch" |
||||
]; |
||||
} |
@ -0,0 +1,120 @@ |
||||
# Edit this configuration file to define what should be installed on |
||||
# your system. Help is available in the configuration.nix(5) man page |
||||
# and in the NixOS manual (accessible by running ‘nixos-help’). |
||||
|
||||
{ config, pkgs, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ # Include the results of the hardware scan. |
||||
./hardware-configuration-cdn-master.nix |
||||
]; |
||||
|
||||
# Use the GRUB 2 boot loader. |
||||
boot.loader.grub.enable = true; |
||||
boot.loader.grub.version = 2; |
||||
# boot.loader.grub.efiSupport = true; |
||||
# boot.loader.grub.efiInstallAsRemovable = true; |
||||
# boot.loader.efi.efiSysMountPoint = "/boot/efi"; |
||||
# Define on which hard drive you want to install Grub. |
||||
# boot.loader.grub.device = "/dev/sda"; # or "nodev" for efi only |
||||
|
||||
# networking.hostName = "nixos"; # Define your hostname. |
||||
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. |
||||
|
||||
# The global useDHCP flag is deprecated, therefore explicitly set to false here. |
||||
# Per-interface useDHCP will be mandatory in the future, so this generated config |
||||
# replicates the default behaviour. |
||||
networking.useDHCP = false; |
||||
networking.interfaces.ens3.useDHCP = true; |
||||
|
||||
# Configure network proxy if necessary |
||||
# networking.proxy.default = "http://user:password@proxy:port/"; |
||||
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; |
||||
|
||||
# Select internationalisation properties. |
||||
# i18n.defaultLocale = "en_US.UTF-8"; |
||||
# console = { |
||||
# font = "Lat2-Terminus16"; |
||||
# keyMap = "us"; |
||||
# }; |
||||
|
||||
# Set your time zone. |
||||
# time.timeZone = "Europe/Amsterdam"; |
||||
|
||||
# List packages installed in system profile. To search, run: |
||||
# $ nix search wget |
||||
# environment.systemPackages = with pkgs; [ |
||||
# wget vim |
||||
# ]; |
||||
|
||||
# Some programs need SUID wrappers, can be configured further or are |
||||
# started in user sessions. |
||||
# programs.mtr.enable = true; |
||||
# programs.gnupg.agent = { |
||||
# enable = true; |
||||
# enableSSHSupport = true; |
||||
# pinentryFlavor = "gnome3"; |
||||
# }; |
||||
|
||||
# List services that you want to enable: |
||||
|
||||
# Enable the OpenSSH daemon. |
||||
# services.openssh.enable = true; |
||||
|
||||
# Open ports in the firewall. |
||||
# networking.firewall.allowedTCPPorts = [ ... ]; |
||||
# networking.firewall.allowedUDPPorts = [ ... ]; |
||||
# Or disable the firewall altogether. |
||||
# networking.firewall.enable = false; |
||||
|
||||
# Enable CUPS to print documents. |
||||
# services.printing.enable = true; |
||||
|
||||
# Enable sound. |
||||
# sound.enable = true; |
||||
# hardware.pulseaudio.enable = true; |
||||
|
||||
# Enable the X11 windowing system. |
||||
# services.xserver.enable = true; |
||||
# services.xserver.layout = "us"; |
||||
# services.xserver.xkbOptions = "eurosign:e"; |
||||
|
||||
# Enable touchpad support. |
||||
# services.xserver.libinput.enable = true; |
||||
|
||||
# Enable the KDE Desktop Environment. |
||||
# services.xserver.displayManager.sddm.enable = true; |
||||
# services.xserver.desktopManager.plasma5.enable = true; |
||||
|
||||
# Define a user account. Don't forget to set a password with ‘passwd’. |
||||
# users.users.jane = { |
||||
# isNormalUser = true; |
||||
# extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user. |
||||
# }; |
||||
|
||||
# This value determines the NixOS release from which the default |
||||
# settings for stateful data, like file locations and database versions |
||||
# on your system were taken. It‘s perfectly fine and recommended to leave |
||||
# this value at the release version of the first install of this system. |
||||
# Before changing this value read the documentation for this option |
||||
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). |
||||
system.stateVersion = "20.03"; # Did you read the comment? |
||||
|
||||
|
||||
|
||||
|
||||
boot.loader.grub.devices = [ "/dev/sda" ]; |
||||
|
||||
# Initial empty root password for easy login: |
||||
users.users.root.initialHashedPassword = ""; |
||||
services.openssh.permitRootLogin = "prohibit-password"; |
||||
|
||||
services.openssh.enable = true; |
||||
|
||||
# Replace this by your SSH pubkey |
||||
users.users.root.openssh.authorizedKeys.keys = [ |
||||
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCt34ou3NYWoUayWrJa5ISzihAAhFiwolJPmm2fF9llPUUA8DP3BQRiKeqDlkDzhWLwztb+dNIUuregiFJdRN5Q2JZBKlM7Gqb1QtPhtK+xe2pyZPX2SWKIsKA6j3VAThhXsQdj3slXu3dG8FF7j+IFg/eTgpeQIFQQkMIc204ha8OP2ASYAJqgJVbXq8Xh3KkAc1HSrjYJLntryvK10wyU8p3ug370dMu3vRUn44FEyDzXFM9rfsgysQTzVgp+sXdRfMLeyvf+SUrE8hiPjzevF2nsUP0Xf/rIaK5VayChPLXJkulognINzvuVWAdwNPDLpgGwkjglF2681Ag88bLX allesmoeglicheundvielmehr@hotmail.de" |
||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDNVUDKx9sukRkb6INny432+2HZBWx/qIEAOvngF1qcj hexchen@montasch" |
||||
]; |
||||
} |
@ -0,0 +1,120 @@ |
||||
# Edit this configuration file to define what should be installed on |
||||
# your system. Help is available in the configuration.nix(5) man page |
||||
# and in the NixOS manual (accessible by running ‘nixos-help’). |
||||
|
||||
{ config, pkgs, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ # Include the results of the hardware scan. |
||||
./hardware-configuration-cdn-node-1.nix |
||||
]; |
||||
|
||||
# Use the GRUB 2 boot loader. |
||||
boot.loader.grub.enable = true; |
||||
boot.loader.grub.version = 2; |
||||
# boot.loader.grub.efiSupport = true; |
||||
# boot.loader.grub.efiInstallAsRemovable = true; |
||||
# boot.loader.efi.efiSysMountPoint = "/boot/efi"; |
||||
# Define on which hard drive you want to install Grub. |
||||
# boot.loader.grub.device = "/dev/sda"; # or "nodev" for efi only |
||||
|
||||
# networking.hostName = "nixos"; # Define your hostname. |
||||
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. |
||||
|
||||
# The global useDHCP flag is deprecated, therefore explicitly set to false here. |
||||
# Per-interface useDHCP will be mandatory in the future, so this generated config |
||||
# replicates the default behaviour. |
||||
networking.useDHCP = false; |
||||
networking.interfaces.ens3.useDHCP = true; |
||||
|
||||
# Configure network proxy if necessary |
||||
# networking.proxy.default = "http://user:password@proxy:port/"; |
||||
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; |
||||
|
||||
# Select internationalisation properties. |
||||
# i18n.defaultLocale = "en_US.UTF-8"; |
||||
# console = { |
||||
# font = "Lat2-Terminus16"; |
||||
# keyMap = "us"; |
||||
# }; |
||||
|
||||
# Set your time zone. |
||||
# time.timeZone = "Europe/Amsterdam"; |
||||
|
||||
# List packages installed in system profile. To search, run: |
||||
# $ nix search wget |
||||
# environment.systemPackages = with pkgs; [ |
||||
# wget vim |
||||
# ]; |
||||
|
||||
# Some programs need SUID wrappers, can be configured further or are |
||||
# started in user sessions. |
||||
# programs.mtr.enable = true; |
||||
# programs.gnupg.agent = { |
||||
# enable = true; |
||||
# enableSSHSupport = true; |
||||
# pinentryFlavor = "gnome3"; |
||||
# }; |
||||
|
||||
# List services that you want to enable: |
||||
|
||||
# Enable the OpenSSH daemon. |
||||
# services.openssh.enable = true; |
||||
|
||||
# Open ports in the firewall. |
||||
# networking.firewall.allowedTCPPorts = [ ... ]; |
||||
# networking.firewall.allowedUDPPorts = [ ... ]; |
||||
# Or disable the firewall altogether. |
||||
# networking.firewall.enable = false; |
||||
|
||||
# Enable CUPS to print documents. |
||||
# services.printing.enable = true; |
||||
|
||||
# Enable sound. |
||||
# sound.enable = true; |
||||
# hardware.pulseaudio.enable = true; |
||||
|
||||
# Enable the X11 windowing system. |
||||
# services.xserver.enable = true; |
||||
# services.xserver.layout = "us"; |
||||
# services.xserver.xkbOptions = "eurosign:e"; |
||||
|
||||
# Enable touchpad support. |
||||
# services.xserver.libinput.enable = true; |
||||
|
||||
# Enable the KDE Desktop Environment. |
||||
# services.xserver.displayManager.sddm.enable = true; |
||||
# services.xserver.desktopManager.plasma5.enable = true; |
||||
|
||||
# Define a user account. Don't forget to set a password with ‘passwd’. |
||||
# users.users.jane = { |
||||
# isNormalUser = true; |
||||
# extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user. |
||||
# }; |
||||
|
||||
# This value determines the NixOS release from which the default |
||||
# settings for stateful data, like file locations and database versions |
||||
# on your system were taken. It‘s perfectly fine and recommended to leave |
||||
# this value at the release version of the first install of this system. |
||||
# Before changing this value read the documentation for this option |
||||
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). |
||||
system.stateVersion = "20.03"; # Did you read the comment? |
||||
|
||||
|
||||
|
||||
|
||||
boot.loader.grub.devices = [ "/dev/sda" ]; |
||||
|
||||
# Initial empty root password for easy login: |
||||
users.users.root.initialHashedPassword = ""; |
||||
services.openssh.permitRootLogin = "prohibit-password"; |
||||
|
||||
services.openssh.enable = true; |
||||
|
||||
# Replace this by your SSH pubkey |
||||
users.users.root.openssh.authorizedKeys.keys = [ |
||||
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCt34ou3NYWoUayWrJa5ISzihAAhFiwolJPmm2fF9llPUUA8DP3BQRiKeqDlkDzhWLwztb+dNIUuregiFJdRN5Q2JZBKlM7Gqb1QtPhtK+xe2pyZPX2SWKIsKA6j3VAThhXsQdj3slXu3dG8FF7j+IFg/eTgpeQIFQQkMIc204ha8OP2ASYAJqgJVbXq8Xh3KkAc1HSrjYJLntryvK10wyU8p3ug370dMu3vRUn44FEyDzXFM9rfsgysQTzVgp+sXdRfMLeyvf+SUrE8hiPjzevF2nsUP0Xf/rIaK5VayChPLXJkulognINzvuVWAdwNPDLpgGwkjglF2681Ag88bLX allesmoeglicheundvielmehr@hotmail.de" |
||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDNVUDKx9sukRkb6INny432+2HZBWx/qIEAOvngF1qcj hexchen@montasch" |
||||
]; |
||||
} |
@ -0,0 +1,120 @@ |
||||
# Edit this configuration file to define what should be installed on |
||||
# your system. Help is available in the configuration.nix(5) man page |
||||
# and in the NixOS manual (accessible by running ‘nixos-help’). |
||||
|
||||
{ config, pkgs, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ # Include the results of the hardware scan. |
||||
./hardware-configuration-cdn-node-2.nix |
||||
]; |
||||
|
||||
# Use the GRUB 2 boot loader. |
||||
boot.loader.grub.enable = true; |
||||
boot.loader.grub.version = 2; |
||||
# boot.loader.grub.efiSupport = true; |
||||
# boot.loader.grub.efiInstallAsRemovable = true; |
||||
# boot.loader.efi.efiSysMountPoint = "/boot/efi"; |
||||
# Define on which hard drive you want to install Grub. |
||||
# boot.loader.grub.device = "/dev/sda"; # or "nodev" for efi only |
||||
|
||||
# networking.hostName = "nixos"; # Define your hostname. |
||||
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. |
||||
|
||||
# The global useDHCP flag is deprecated, therefore explicitly set to false here. |
||||
# Per-interface useDHCP will be mandatory in the future, so this generated config |
||||
# replicates the default behaviour. |
||||
networking.useDHCP = false; |
||||
networking.interfaces.ens3.useDHCP = true; |
||||
|
||||
# Configure network proxy if necessary |
||||
# networking.proxy.default = "http://user:password@proxy:port/"; |
||||
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; |
||||
|
||||
# Select internationalisation properties. |
||||
# i18n.defaultLocale = "en_US.UTF-8"; |
||||
# console = { |
||||
# font = "Lat2-Terminus16"; |
||||
# keyMap = "us"; |
||||
# }; |
||||
|
||||
# Set your time zone. |
||||
# time.timeZone = "Europe/Amsterdam"; |
||||
|
||||
# List packages installed in system profile. To search, run: |
||||
# $ nix search wget |
||||
# environment.systemPackages = with pkgs; [ |
||||
# wget vim |
||||
# ]; |
||||
|
||||
# Some programs need SUID wrappers, can be configured further or are |
||||
# started in user sessions. |
||||
# programs.mtr.enable = true; |
||||
# programs.gnupg.agent = { |
||||
# enable = true; |
||||
# enableSSHSupport = true; |
||||
# pinentryFlavor = "gnome3"; |
||||
# }; |
||||
|
||||
# List services that you want to enable: |
||||
|
||||
# Enable the OpenSSH daemon. |
||||
# services.openssh.enable = true; |
||||
|
||||
# Open ports in the firewall. |
||||
# networking.firewall.allowedTCPPorts = [ ... ]; |
||||
# networking.firewall.allowedUDPPorts = [ ... ]; |
||||
# Or disable the firewall altogether. |
||||
# networking.firewall.enable = false; |
||||
|
||||
# Enable CUPS to print documents. |
||||
# services.printing.enable = true; |
||||
|
||||
# Enable sound. |
||||
# sound.enable = true; |
||||
# hardware.pulseaudio.enable = true; |
||||
|
||||
# Enable the X11 windowing system. |
||||
# services.xserver.enable = true; |
||||
# services.xserver.layout = "us"; |
||||
# services.xserver.xkbOptions = "eurosign:e"; |
||||
|
||||
# Enable touchpad support. |
||||
# services.xserver.libinput.enable = true; |
||||
|
||||
# Enable the KDE Desktop Environment. |
||||
# services.xserver.displayManager.sddm.enable = true; |
||||
# services.xserver.desktopManager.plasma5.enable = true; |
||||
|
||||
# Define a user account. Don't forget to set a password with ‘passwd’. |
||||
# users.users.jane = { |
||||
# isNormalUser = true; |
||||
# extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user. |
||||
# }; |
||||
|
||||
# This value determines the NixOS release from which the default |
||||
# settings for stateful data, like file locations and database versions |
||||
# on your system were taken. It‘s perfectly fine and recommended to leave |
||||
# this value at the release version of the first install of this system. |
||||
# Before changing this value read the documentation for this option |
||||
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). |
||||
system.stateVersion = "20.03"; # Did you read the comment? |
||||
|
||||
|
||||
|
||||
|
||||
boot.loader.grub.devices = [ "/dev/sda" ]; |
||||
|
||||
# Initial empty root password for easy login: |
||||
users.users.root.initialHashedPassword = ""; |
||||
services.openssh.permitRootLogin = "prohibit-password"; |
||||
|
||||
services.openssh.enable = true; |
||||
|
||||
# Replace this by your SSH pubkey |
||||
users.users.root.openssh.authorizedKeys.keys = [ |
||||
"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCt34ou3NYWoUayWrJa5ISzihAAhFiwolJPmm2fF9llPUUA8DP3BQRiKeqDlkDzhWLwztb+dNIUuregiFJdRN5Q2JZBKlM7Gqb1QtPhtK+xe2pyZPX2SWKIsKA6j3VAThhXsQdj3slXu3dG8FF7j+IFg/eTgpeQIFQQkMIc204ha8OP2ASYAJqgJVbXq8Xh3KkAc1HSrjYJLntryvK10wyU8p3ug370dMu3vRUn44FEyDzXFM9rfsgysQTzVgp+sXdRfMLeyvf+SUrE8hiPjzevF2nsUP0Xf/rIaK5VayChPLXJkulognINzvuVWAdwNPDLpgGwkjglF2681Ag88bLX allesmoeglicheundvielmehr@hotmail.de" |
||||
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDNVUDKx9sukRkb6INny432+2HZBWx/qIEAOvngF1qcj hexchen@montasch" |
||||
]; |
||||
} |
@ -0,0 +1,25 @@ |
||||
# 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, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ <nixpkgs/nixos/modules/profiles/qemu-guest.nix> |
||||
]; |
||||
|
||||
boot.initrd.availableKernelModules = [ "ata_piix" "virtio_pci" "xhci_pci" "sd_mod" "sr_mod" ]; |
||||
boot.initrd.kernelModules = [ ]; |
||||
boot.kernelModules = [ ]; |
||||
boot.extraModulePackages = [ ]; |
||||
|
||||
fileSystems."/" = |
||||
{ device = "/dev/disk/by-uuid/e371ee1d-a03f-4964-b03d-4a5c59ff5911"; |
||||
fsType = "ext4"; |
||||
}; |
||||
|
||||
swapDevices = [ ]; |
||||
|
||||
nix.maxJobs = lib.mkDefault 1; |
||||
} |
||||
|
@ -0,0 +1,24 @@ |
||||
# 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, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ <nixpkgs/nixos/modules/profiles/qemu-guest.nix> |
||||
]; |
||||
|
||||
boot.initrd.availableKernelModules = [ "ata_piix" "virtio_pci" "xhci_pci" "sd_mod" "sr_mod" ]; |
||||
boot.initrd.kernelModules = [ ]; |
||||
boot.kernelModules = [ ]; |
||||
boot.extraModulePackages = [ ]; |
||||
|
||||
fileSystems."/" = |
||||
{ device = "/dev/disk/by-uuid/14cc7936-f928-41e3-8f72-ee6bf18d6c19"; |
||||
fsType = "ext4"; |
||||
}; |
||||
|
||||
swapDevices = [ ]; |
||||
|
||||
nix.maxJobs = lib.mkDefault 1; |
||||
} |
@ -0,0 +1,24 @@ |
||||
# 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, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ <nixpkgs/nixos/modules/profiles/qemu-guest.nix> |
||||
]; |
||||
|
||||
boot.initrd.availableKernelModules = [ "ata_piix" "virtio_pci" "xhci_pci" "sd_mod" "sr_mod" ]; |
||||
boot.initrd.kernelModules = [ ]; |
||||
boot.kernelModules = [ ]; |
||||
boot.extraModulePackages = [ ]; |
||||
|
||||
fileSystems."/" = |
||||
{ device = "/dev/disk/by-uuid/52dddb3d-9294-4105-9157-bf003dc7bdf9"; |
||||
fsType = "ext4"; |
||||
}; |
||||
|
||||
swapDevices = [ ]; |
||||
|
||||
nix.maxJobs = lib.mkDefault 1; |
||||
} |
@ -0,0 +1,24 @@ |
||||
# 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, ... }: |
||||
|
||||
{ |
||||
imports = |
||||
[ <nixpkgs/nixos/modules/profiles/qemu-guest.nix> |
||||
]; |
||||
|
||||
boot.initrd.availableKernelModules = [ "ata_piix" "virtio_pci" "xhci_pci" "sd_mod" "sr_mod" ]; |
||||
boot.initrd.kernelModules = [ ]; |
||||
boot.kernelModules = [ ]; |
||||
boot.extraModulePackages = [ ]; |
||||
|
||||
fileSystems."/" = |
||||
{ device = "/dev/disk/by-uuid/a92ff89e-e1c2-4fda-8711-1be7257f6470"; |
||||
fsType = "ext4"; |
||||
}; |
||||
|
||||
swapDevices = [ ]; |
||||
|
||||
nix.maxJobs = lib.mkDefault 1; |
||||
} |
@ -0,0 +1,12 @@ |
||||
{ |
||||
network.description = "Haskell + NixOps FTW!"; |
||||
|
||||
helloworlder = { config, pkgs, ... }: |
||||
{ |
||||
#deployment.targetEnv = "virtualbox"; |
||||
#deployment.virtualbox.headless = true; |
||||
|
||||
#environment.systemPackages = [ hwer ]; |
||||
deployment.targetHost = "cdn-node-1.lukas.studio"; |
||||
nixpkgs.localSystem.system = "x86_64-linux"; |
||||
} |
Loading…
Reference in new issue