configuration
flake
hosts
_iso
aluminium
astatine
backup-4
beryllium
carbon
clerie-backup
dn42-il-gw1
dn42-il-gw5
dn42-il-gw6
dn42-ildix-clerie
dn42-ildix-service
gatekeeper
hydra-1
hydra-2
krypton
mail-2
monitoring-3
nonat
osmium
palladium
porter
storage-2
tungsten
web-2
blog.nix
bula22.nix
chaosevents.nix
clerie.nix
configuration.nix
drop.nix
etebase.nix
feeds.nix
fieldpoc.nix
gitea.nix
hardware-configuration.nix
ip.nix
legal.nix
meow.nix
milchinsel.nix
mitel-ommclient2.nix
nix-install.nix
nurausstieg.nix
ping.nix
public.nix
radicale.nix
reichartstrasse.nix
secrets.json
ssh.pub
uptimestatus.nix
wetter.nix
zinc
lib
modules
pkgs
users
.gitignore
README.md
flake.lock
flake.nix
32 lines
911 B
Nix
32 lines
911 B
Nix
{ pkgs, ... }:
|
|
|
|
let
|
|
install_script = pkgs.writeTextDir "web/install" ''
|
|
#!/usr/bin/env bash
|
|
set -euo pipefail
|
|
|
|
which nix 2>1 > /dev/null || { echo "nix command not found. Install nix and try again"; exit 1; }
|
|
|
|
nix --extra-experimental-features "nix-command" \
|
|
--substituters "https://nix-cache.clerie.de" \
|
|
--trusted-public-keys "nix-cache.clerie.de:bAt1GJTS9BOTcXFWj3nURrSlcjqikCev9yDvqArMP5g=" \
|
|
copy --from "https://nix-cache.clerie.de" \
|
|
${pkgs.nixfiles-auto-install}
|
|
${pkgs.nixfiles-auto-install}/bin/nixfiles-auto-install
|
|
'';
|
|
in {
|
|
services.nginx.virtualHosts = {
|
|
"install.nix.clerie.de" = {
|
|
enableACME = true;
|
|
forceSSL = true;
|
|
locations."/" = {
|
|
root = install_script + "/web/";
|
|
extraConfig = ''
|
|
index install;
|
|
types { } default_type "text/plain; charset=utf-8";
|
|
'';
|
|
};
|
|
};
|
|
};
|
|
}
|