{ lib, ... }: let certs = import ./common/acme/server/snakeoil-certs.nix; domain = certs.domain; in { name = "openbao"; meta.maintainers = with lib.maintainers; [ kranzes ]; nodes.machine = { config, ... }: { security.pki.certificateFiles = [ certs.ca.cert ]; networking.extraHosts = '' 127.0.0.1 ${domain} ''; services.openbao = { enable = true; settings = { ui = true; listener = { default = { type = "tcp"; tls_cert_file = certs.${domain}.cert; tls_key_file = certs.${domain}.key; }; unix = { type = "unix"; }; }; cluster_addr = "https://127.0.0.1:8201"; api_addr = "https://${domain}:8200"; storage.raft.path = "/var/lib/openbao"; }; }; environment.variables = { BAO_ADDR = config.services.openbao.settings.api_addr; BAO_FORMAT = "json"; }; }; testScript = { nodes, ... }: '' import json start_all() with subtest("Wait for OpenBao to start up"): machine.wait_for_unit("openbao.service") machine.wait_for_open_port(8200) machine.wait_for_open_unix_socket("${nodes.machine.services.openbao.settings.listener.unix.address}") with subtest("Check that the web UI is being served"): machine.succeed("curl -L --fail --show-error --silent $BAO_ADDR | grep '