Refine the recursive platform security architecture to make OpenBao the canonical runtime secret authority, with SOPS/age, K8s Secrets, and the emergency bundle reframed as bootstrap/delivery/break-glass mechanisms. - credential-management standard v0.2: add OpenBao runtime authority section, rotation rules, and prohibited patterns (OpenBao-as-PDP, tenant platform-root) - platform-identity-security-architecture: mark implemented; add flex-auth/Topaz implications, Coulomb onboarding path, and a production-readiness checklist - NK-WP-0004/0005: document bootstrap-to-OpenBao handoff boundary - NK-WP-0006/0007: status -> done with implementation reviews; add recursive platform/tenant split and OpenBao broker/audit role for object-storage STS vending - NK-WP-0008: status -> done; repoint corpus to infospace-bench - new ADR-0007 (orchestration boundary), ADR-0008 (STS vending boundary), and the object-storage STS credential-vending architecture Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
5.8 KiB
id, type, title, domain, repo, status, owner, topic_slug, created, updated, depends_on, state_hub_workstream_id
| id | type | title | domain | repo | status | owner | topic_slug | created | updated | depends_on | state_hub_workstream_id | |||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| NK-WP-0006 | workplan | Recursive platform identity and security architecture | netkingdom | net-kingdom | done | Bernd Worsch | netkingdom | 2026-05-17 | 2026-05-18 |
|
2eb8a5e0-4e33-4ed3-8996-a2eec3aad862 |
NK-WP-0006 - Recursive Platform Identity and Security Architecture
Goal
Make the platform identity and security architecture explicit enough that Coulomb can be onboarded as the first internal/reference tenant without accidentally becoming the platform root of trust.
The workplan turns the recursive insight into operational structure: bootstrap plane, platform control plane, tenant plane, IAM Profile, flex-auth authorization, Topaz runtime, privacyIDEA MFA/token handling, OpenBao runtime secret authority, and safe orchestration boundaries.
Context
The current platform work is both building the Coulomb infrastructure and creating reusable infrastructure for later use cases. That means Coulomb is tenant zero/reference tenant inside its own future platform. This is a useful design pressure, but only if the tenant/control-plane separation is made explicit.
NetKingdom owns the canonical identity and security architecture. Railiance owns deployment layering. flex-auth provides the practical reference implementation for CARING authorization semantics. key-cape and Keycloak implement identity profiles in different operating modes.
Scope
In scope:
- document the three-plane architecture
- define platform-root versus tenant authority
- define how NetKingdom, key-cape, Keycloak, privacyIDEA, flex-auth, Topaz, OpenBao, and Railiance relate
- define bootstrap-to-runtime trust states
- update related workplans and ADRs when implementation details become concrete
- identify whether a dedicated orchestration repo is justified
Out of scope:
- implementing flex-auth adapters
- deploying Keycloak, key-cape, privacyIDEA, Topaz, or Railiance services
- deploying OpenBao itself
- designing customer-specific tenant policy
- replacing existing Railiance layer ownership
Tasks
id: NK-WP-0006-T1
status: done
priority: high
state_hub_task_id: "3e1c432a-f1ef-4c96-bb7a-79d1b955cd82"
Document the recursive multi-tenant identity/security architecture in
docs/platform-identity-security-architecture.md.
id: NK-WP-0006-T2
status: done
priority: high
state_hub_task_id: "194fe3d5-d47c-449e-a32d-50996fd39e66"
Record the architecture decision in an ADR so later repo work can point to a stable decision.
id: NK-WP-0006-T3
status: done
priority: high
state_hub_task_id: "842ba5a7-5199-490a-8af5-3150388e0d42"
Review flex-auth workplans and add tenant/control-plane implications: CARING descriptors, policy packages, decision envelopes, Topaz adapter scope, audit/explain records, and platform-root guardrails.
id: NK-WP-0006-T4
status: done
priority: high
state_hub_task_id: "ce153339-f493-44ed-a2c5-befb578334fe"
Review NetKingdom credential/bootstrap workplans and add explicit trust state transitions: bare host, cluster, secrets, bootstrap identity, runtime identity, runtime authorization, tenant onboarding.
id: NK-WP-0006-T5
status: done
priority: medium
state_hub_task_id: "6c9a3561-4e63-4acd-87a7-bf0f374fa6b2"
Map the first Coulomb tenant onboarding path: identity claims, tenant id, resource registration, policy package import, Topaz initialization, and audit readiness.
id: NK-WP-0006-T6
status: done
priority: medium
state_hub_task_id: "27760e30-f773-4552-97f4-7fbe56507f9e"
Decide whether orchestration should stay as Railiance playbooks or become a dedicated repo. Capture the decision as an ADR before implementation.
id: NK-WP-0006-T7
status: done
priority: medium
state_hub_task_id: "f09519ac-cf97-4f8b-8a7b-6ff828bbd8d9"
Define production readiness checks for the security platform: MFA state, secret rotation state, flex-auth policy state, Topaz health, audit sink, and break-glass verification.
Implementation Review - 2026-05-18
The recursive architecture remains the right framing. The refinement from the current stack is that OpenBao is now part of the platform control plane as the runtime secret authority. SOPS/age and emergency bundles remain bootstrap and recovery mechanisms; they must not become the long-lived runtime authority for every workload secret once OpenBao is available.
Implemented refinements:
docs/platform-identity-security-architecture.mdnow includes explicit flex-auth/Topaz implications, Coulomb tenant onboarding, production readiness checks, and OpenBao secret authority boundaries.docs/adr/ADR-0007-security-orchestration-boundary.mdrecords that orchestration stays in Railiance playbooks for now; a dedicated repo is deferred until sequencing has a stable, cross-repo product surface.workplans/NK-WP-0007-object-storage-sts-credential-vending.mdnow treats OpenBao as the runtime broker/audit option without letting it replace flex-auth authorization or storage-native STS semantics.workplans/NK-WP-0004-credential-management-foundation.md,workplans/NK-WP-0005-agent-driven-credential-bootstrap.md, andcanon/standards/credential-management_v0.2.mdnow distinguish bootstrap credential handling from the OpenBao runtime-secret handoff.
State Hub task statuses should be synchronized to match this workplan.
Acceptance Criteria
- Architecture docs distinguish bootstrap plane, platform control plane, and tenant plane.
- Coulomb is represented as tenant zero/reference tenant, not platform root.
- The role of NetKingdom, key-cape, Keycloak, privacyIDEA, flex-auth, Topaz, OpenBao, and Railiance is clear.
- Follow-up workplans identify where flex-auth and bootstrap work need to adapt.
- Any future orchestration repo is justified by an ADR before it is created.