From 29b6e1a96e7aa2df0e49af2dc299ef24501adbde Mon Sep 17 00:00:00 2001 From: Ashelyn Rose Date: Tue, 4 Jul 2023 02:02:46 -0600 Subject: [PATCH] Nix flake --- flake.nix | 112 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 112 insertions(+) create mode 100644 flake.nix diff --git a/flake.nix b/flake.nix new file mode 100644 index 0000000..98364ba --- /dev/null +++ b/flake.nix @@ -0,0 +1,112 @@ +{ + inputs = { + utils.url = "github:numtide/flake-utils"; + nixpkgs.url = "github:NixOS/nixpkgs/master"; + nix-filter.url = "github:numtide/nix-filter"; + }; + + outputs = { + self, + nixpkgs, + utils, + nix-filter, + }: + utils.lib.eachDefaultSystem + (system: let + pkgs = import nixpkgs { + inherit system; + }; + + filter = nix-filter.lib; + + nodejs = pkgs.nodejs-18_x; + + node_modules = pkgs.stdenv.mkDerivation { + name = "node_modules"; + + src = filter { + root = ./.; + include = [ + ./package.json + ./package-lock.json + ]; + }; + + __noChroot = true; + + configurePhase = '' + export HOME=$TMP + ''; + + buildInputs = [ nodejs ]; + + buildPhase = '' + ${nodejs}/bin/npm ci + ''; + + installPhase = '' + mkdir $out + mv node_modules $out/node_modules + ''; + }; + in { + packages = { + + default = pkgs.stdenv.mkDerivation { + name = "tempest.dev"; + + src = filter { + root = ./.; + exclude = [ + ./.next + ./node_modules + ]; + }; + + nativeBuildInputs = [ nodejs ]; + + buildPhase = '' + npm run build + npm run export + ''; + + configurePhase = '' + ln -sf ${node_modules}/node_modules node_modules + export HOME=$TMP + ''; + + installPhase = '' + # Copy static export + mv out $out + ''; + }; + }; + }) // { + nixosModule = {config, lib, pkgs, ...}: + with lib; + let cfg = config.ashe.services."tempest.dev"; + + in { + options.ashe.services."ashen.earth" = { + enable = mkEnableOption "Enables the ashen.earth HTTP service"; + + domain = mkOption rec { + type = types.str; + default = "ashen.earth"; + example = default; + description = "The domain name for ashen.earth"; + }; + }; + + config = mkIf cfg.enable { + services.nginx.virtualHosts.${cfg.domain} = { + root = "${pkg}" + forceSSL = true; + enableACME = true; + }; + }; + }; + + + }; +}