diff options
author | Ben Sima <ben@bsima.me> | 2024-12-20 13:21:43 -0500 |
---|---|---|
committer | Ben Sima <ben@bsima.me> | 2024-12-21 10:08:11 -0500 |
commit | 32d31ae8d1ef5d5aeb03a7fe7e6a294e14905505 (patch) | |
tree | 4a248394a7c49682f9ef7538e3033fbea5117690 /Biz | |
parent | 87ead51331bc57326882055e1635a84c2d409af7 (diff) |
Build and deploy storybook
I put the storybook into a new Biz.nix deploy target. The idea here is that any
Biz/* targets should be hosted by this one VM for simplicity. Over time I can
grow this as need be, but this should work to host a few services.
Diffstat (limited to 'Biz')
-rw-r--r-- | Biz/Storybook.nix | 78 | ||||
-rw-r--r-- | Biz/Storybook.py | 15 |
2 files changed, 87 insertions, 6 deletions
diff --git a/Biz/Storybook.nix b/Biz/Storybook.nix new file mode 100644 index 0000000..692b4e9 --- /dev/null +++ b/Biz/Storybook.nix @@ -0,0 +1,78 @@ +{ options, lib, config, pkgs, ... }: + +let + cfg = config.services.storybook; + rootDomain = "bensima.com"; + ports = import ../Omni/Cloud/Ports.nix; +in { + options.services.storybook = { + enable = lib.mkEnableOption "Enable the storybook service"; + port = lib.mkOption { + type = lib.types.int; + default = 3000; + description = '' + The port on which storybook will listen for + incoming HTTP traffic. + ''; + }; + dataDir = lib.mkOption { + type = lib.types.path; + default = "/var/storybook/"; + description = "Data dir location"; + }; + package = lib.mkOption { + type = lib.types.package; + description = "storybook package to use"; + }; + }; + config = lib.mkIf cfg.enable { + systemd.services.storybook = { + path = [ cfg.package pkgs.git ]; + wantedBy = [ "multi-user.target" ]; + preStart = '' + # these must be manually created + test -d /run/storybook + test -f /run/storybook/env + # this can be generated + mkdir -p ${cfg.dataDir} + ''; + script = '' + ${cfg.package}/bin/storybook + ''; + description = '' + Storybook + ''; + serviceConfig = { + Environment = + [ "PORT=${toString cfg.port}" "AREA=Live" "DATA_DIR=${cfg.dataDir}" ]; + EnvironmentFile = "/run/storybook/env"; + KillSignal = "INT"; + Type = "simple"; + Restart = "on-abort"; + RestartSec = "1"; + }; + }; + + # TODO: nginx web stuff + services.nginx = { + enable = true; + recommendedGzipSettings = true; + recommendedOptimisation = true; + recommendedProxySettings = true; + recommendedTlsSettings = true; + statusPage = true; + + user = "nginx"; + group = "nginx"; + + virtualHosts."storybook.${rootDomain}" = { + forceSSL = true; + enableACME = true; + locations."/".proxyPass = "http://localhost:${toString cfg.port}"; + # useACMEHost = rootDomain; + }; + }; + + networking.firewall.allowedTCPPorts = [ ports.ssh ports.http ports.https ]; + }; +} diff --git a/Biz/Storybook.py b/Biz/Storybook.py index 80f746a..c29d9f5 100644 --- a/Biz/Storybook.py +++ b/Biz/Storybook.py @@ -45,9 +45,11 @@ import unittest import uuid import uvicorn -VPN = True CODEROOT = pathlib.Path(os.getenv("CODEROOT", ".")) -DATA_DIR = pathlib.Path(CODEROOT / "_/var/storybook/") +DATA_DIR = pathlib.Path( + os.environ.get("DATA_DIR", CODEROOT / "_/var/storybook/"), +) +PORT = int(os.environ.get("PORT", "3000")) class Area(enum.Enum): @@ -89,15 +91,16 @@ def main() -> None: def move(area: Area) -> None: """Run the application.""" - Log.setup(logging.DEBUG if area.Test else logging.ERROR) + Log.setup(logging.DEBUG if area == Area.Test else logging.ERROR) logging.info("area: %s", area) - host = "100.127.197.132" if VPN else "127.0.0.1" - uvicorn.run(app, host=host) + # during test, bind to beryllium's VPN address, else localhost + host = "100.127.197.132" if area == Area.Test else "127.0.0.1" + uvicorn.run(app, host=host, port=PORT) def test(area: Area = Area.Test) -> None: """Run the unittest suite manually.""" - Log.setup(logging.DEBUG if area.Test else logging.ERROR) + Log.setup(logging.DEBUG if area == Area.Test else logging.ERROR) suite = unittest.TestSuite() tests = [IndexTest, StoryTest] suite.addTests([ |