nixpkgs/nixos/tests/openbao.nix
Ilan Joselevich 7da9ff9fab
nixos/openbao: init
- Added a NixOS module using RFC42 and plenty of systemd hardening
- Added a NixOS VM Test which checks the basic functionality
- Refactored the package to support HSM and UI
2025-04-26 14:48:58 +03:00

105 lines
3.1 KiB
Nix

{ 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 '<title>OpenBao</title>'")
with subtest("Check that OpenBao is not initialized"):
status_output = json.loads(machine.fail("bao status"))
assert not status_output["initialized"]
with subtest("Initialize OpenBao"):
init_output = json.loads(machine.succeed("bao operator init"))
with subtest("Check that OpenBao is initialized and sealed"):
status_output = json.loads(machine.fail("bao status"))
assert status_output["initialized"]
assert status_output["sealed"]
with subtest("Unseal OpenBao"):
for key in init_output["unseal_keys_b64"][:init_output["unseal_threshold"]]:
machine.succeed(f"bao operator unseal {key}")
with subtest("Check that OpenBao is not sealed"):
status_output = json.loads(machine.succeed("bao status"))
assert not status_output["sealed"]
with subtest("Login with root token"):
machine.succeed(f"bao login {init_output["root_token"]}")
with subtest("Enable userpass auth method"):
machine.succeed("bao auth enable userpass")
with subtest("Create a user in userpass"):
machine.succeed("bao write auth/userpass/users/testuser password=testpassword")
with subtest("Login to a user from userpass"):
machine.succeed("bao login -method userpass username=testuser password=testpassword")
with subtest("Write a secret to cubbyhole"):
machine.succeed("bao write cubbyhole/my-secret my-value=s3cr3t")
with subtest("Read a secret from cubbyhole"):
read_output = json.loads(machine.succeed("bao read cubbyhole/my-secret"))
assert read_output["data"]["my-value"] == "s3cr3t"
'';
}