From e813e0ac1e28ffd54d9308bf454e5ea8cfbcd101 Mon Sep 17 00:00:00 2001 From: Sumner Evans Date: Tue, 7 Nov 2023 19:48:05 -0700 Subject: [PATCH] webfortune: init Signed-off-by: Sumner Evans --- flake.lock | 32 +++++++++++++++++--- flake.nix | 7 ++++- host-configurations/morak.nix | 22 +++++++++++++- host-configurations/tatooine.nix | 2 +- modules/services/default.nix | 1 + modules/services/webfortune.nix | 50 ++++++++++++++++++++++++++++++++ 6 files changed, 107 insertions(+), 7 deletions(-) create mode 100644 modules/services/webfortune.nix diff --git a/flake.lock b/flake.lock index 3cfbd17..ec8f9f6 100644 --- a/flake.lock +++ b/flake.lock @@ -20,11 +20,11 @@ }, "nixpkgs": { "locked": { - "lastModified": 1697723726, - "narHash": "sha256-SaTWPkI8a5xSHX/rrKzUe+/uVNy6zCGMXgoeMb7T9rg=", + "lastModified": 1699099776, + "narHash": "sha256-X09iKJ27mGsGambGfkKzqvw5esP1L/Rf8H3u3fCqIiU=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "7c9cc5a6e5d38010801741ac830a3f8fd667a7a0", + "rev": "85f1ba3e51676fa8cc604a3d863d729026a6b8eb", "type": "github" }, "original": { @@ -37,7 +37,8 @@ "root": { "inputs": { "flake-utils": "flake-utils", - "nixpkgs": "nixpkgs" + "nixpkgs": "nixpkgs", + "webfortune": "webfortune" } }, "systems": { @@ -54,6 +55,29 @@ "repo": "default", "type": "github" } + }, + "webfortune": { + "inputs": { + "flake-utils": [ + "flake-utils" + ], + "nixpkgs": [ + "nixpkgs" + ] + }, + "locked": { + "lastModified": 1699456308, + "narHash": "sha256-2iuXIA0Soer5uCEvWuDt5A1J6aFd1qBcZEjKK3kXUv0=", + "owner": "sumnerevans", + "repo": "webfortune", + "rev": "c8270fd6975fbd19495a5e6af5b43a777ed4d25a", + "type": "github" + }, + "original": { + "owner": "sumnerevans", + "repo": "webfortune", + "type": "github" + } } }, "root": "root", diff --git a/flake.nix b/flake.nix index e53927f..6a85033 100644 --- a/flake.nix +++ b/flake.nix @@ -3,9 +3,14 @@ inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; flake-utils.url = "github:numtide/flake-utils"; + webfortune = { + url = "github:sumnerevans/webfortune"; + inputs.nixpkgs.follows = "nixpkgs"; + inputs.flake-utils.follows = "flake-utils"; + }; }; - outputs = { self, nixpkgs, flake-utils }@inputs: { + outputs = inputs@{ self, nixpkgs, flake-utils, webfortune }: { nixosConfigurations = { tatooine = nixpkgs.lib.nixosSystem { system = "x86_64-linux"; diff --git a/host-configurations/morak.nix b/host-configurations/morak.nix index b7a651a..cf1a038 100644 --- a/host-configurations/morak.nix +++ b/host-configurations/morak.nix @@ -1,4 +1,9 @@ -{ config, lib, pkgs, modulesPath, ... }: with lib; { +{ config, lib, pkgs, modulesPath, inputs, ... }: with lib; let + quotesfile = pkgs.fetchurl { + url = "https://raw.githubusercontent.com/sumnerevans/home-manager-config/master/modules/email/quotes"; + }; +in +{ imports = [ (modulesPath + "/profiles/qemu-guest.nix") ]; boot = { @@ -83,6 +88,14 @@ ]; } ]; + services.nginx.virtualHosts."fortune.sumnerevans.com" = { + addSSL = true; + enableACME = true; + "/" = { + recommendedProxySettings = true; + proxyPass = "http://localhost:8009"; + }; + }; ############ # Services # @@ -124,6 +137,13 @@ services.backup.healthcheckId = "6c9caf62-4f7b-4ef7-82ac-d858d3bcbcb5"; services.backup.healthcheckPruneId = "f90ed04a-2596-49d0-a89d-764780a27fc6"; + # Webfortune + services.webfortune = { + enable = true; + inherit quotesfile; + sourceUrl = "https://github.com/sumnerevans/home-manager-config/blob/master/modules/email/quotes"; + }; + # Add a backup service for the actual config. services.backup.backups.syncthing-pictures-tmp-data = { path = "/mnt/syncthing-pictures-tmp"; diff --git a/host-configurations/tatooine.nix b/host-configurations/tatooine.nix index 696a4fe..8e839fe 100644 --- a/host-configurations/tatooine.nix +++ b/host-configurations/tatooine.nix @@ -1,4 +1,4 @@ -{ modulesPath, ... }: { +{ modulesPath, pkgs, ... }: { imports = [ (modulesPath + "/profiles/qemu-guest.nix") ]; boot.initrd.availableKernelModules = [ "ahci" "xhci_pci" "virtio_pci" "sd_mod" "sr_mod" ]; diff --git a/modules/services/default.nix b/modules/services/default.nix index 3f5c5b5..67f4b95 100644 --- a/modules/services/default.nix +++ b/modules/services/default.nix @@ -18,6 +18,7 @@ ./restic.nix ./sshd.nix ./syncthing.nix + ./webfortune.nix ./xandikos.nix ]; diff --git a/modules/services/webfortune.nix b/modules/services/webfortune.nix new file mode 100644 index 0000000..ff31925 --- /dev/null +++ b/modules/services/webfortune.nix @@ -0,0 +1,50 @@ +{ config, inputs, lib, pkgs, ... }: +with lib; +let + cfg = config.services.webfortune; +in +{ + options = { + services.webfortune = { + quotesfile = mkOption { + type = types.path; + description = "Path to the quotesfile"; + }; + sourceUrl = mkOption { + type = types.str; + description = "URL to the quotesfile"; + }; + listenAddr = mkOption { + type = types.str; + default = "0.0.0.0:8477"; + description = "Address to listen on"; + }; + }; + }; + + config = { + services.nginx = { + enable = true; + virtualHosts."fortune.sumnerevans.com" = { + addSSL = true; + enableACME = true; + locations."/" = { + recommendedProxySettings = true; + proxyPass = cfg.listenAddr; + }; + }; + }; + + systemd.services.webfortune = { + description = "webfortune"; + environment = { + QUOTESFILE = cfg.quotesfile; + QUOTESFILE_SOURCE_URL = cfg.sourceUrl; + LISTEN_ADDR = cfg.listenAddr; + }; + serviceConfig = { + ExecStart = "${inputs.webfortune.packages.${pkgs.system}.webfortune}/bin/webfortune"; + }; + }; + }; +}