From 4d10fbcad9f9a730a776f3eb197cb4821c9f6edc Mon Sep 17 00:00:00 2001 From: Ethel Morgan Date: Wed, 1 Jul 2020 21:56:57 +0100 Subject: create eth.sites.go for a go "vanity import" site --- nixos/modules/sites/go.nix | 52 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 nixos/modules/sites/go.nix (limited to 'nixos/modules/sites/go.nix') diff --git a/nixos/modules/sites/go.nix b/nixos/modules/sites/go.nix new file mode 100644 index 0000000..7682469 --- /dev/null +++ b/nixos/modules/sites/go.nix @@ -0,0 +1,52 @@ +{ config, lib, pkgs, ... }: +with lib; + +let + cfg = config.eth.sites.go; + + mkLocation = virtualHost: module: url: { + name = "/${module}"; + value = { + extraConfig = '' + if ($args = "go-get=1") { + add_header Content-Type text/html; + return 200 ''; + } + return 302 ${url}; + ''; + }; + }; + +in { + options.eth.sites.go = { + enable = mkEnableOption "Whether to enable the Go site."; + + https = mkOption { + type = types.bool; + default = true; + description = "Whether to enable HTTPS."; + }; + + virtualHost = mkOption { + type = types.str; + default = "_"; + description = "Virtual Host to install the site under in Nginx."; + example = "go.eth.moe"; + }; + + modules = mkOption { + type = types.attrsOf types.str; + description = "A set of modules and their underlying git repos."; + example = { catbus = "https://git.eth.moe/go-catbus"; }; + }; + }; + + config = mkIf cfg.enable { + services.nginx.virtualHosts.${cfg.virtualHost} = { + forceSSL = cfg.https; + enableACME = cfg.https; + + locations = listToAttrs (mapAttrsToList (mkLocation cfg.virtualHost) cfg.modules); + }; + }; +} -- cgit v1.2.3