Skip to content

feat(tls): substrate-aware CharmState SAN/CN accessors (2/4)#166

Closed
marceloneppel wants to merge 1 commit into
tls-1-statefrom
tls-2-handlers
Closed

feat(tls): substrate-aware CharmState SAN/CN accessors (2/4)#166
marceloneppel wants to merge 1 commit into
tls-1-statefrom
tls-2-handlers

Conversation

@marceloneppel

@marceloneppel marceloneppel commented Jun 26, 2026

Copy link
Copy Markdown
Member

Part 2/4, stacked on #165. Adds the substrate-aware CharmState accessors that compose the peer/workload primitives from part 1 into the cert-request SANs and common names.

What's here (3 files)

  • core/state.py: client_addresses / peer_addresses, client_common_name / peer_common_name (VM host-derived; K8s endpoints-FQDN parity, with the >64-char wildcard rule), K8s common_hosts (Service FQDNs), and the CharmBase-widening so CharmState accepts any charm.
  • tests/unit/test_tls_state.py, tests/unit/test_tls_client_addrs.py.

These accessors read the part-1 peer/databag primitives; the part-3 events handler feeds them into the TLSCertificatesRequiresV4 certificate requests. Draft — not ready for review.

Layer the certificate-SAN and common-name policy onto CharmState, on top of the raw peer-databag accessors from the previous branch, so the substrate-specific certificate identity is reviewable as a unit with its own tests before any manager or handler consumes it.

K8s must regain the parity the migration had dropped: common_hosts has to advertise the primary/replicas Service FQDNs and the resolved pod FQDN, and the operator-cert common name has to be the endpoints FQDN (wildcarded past the 64-char CN limit) rather than the VM-style host/address; the peer SAN set must exclude the ip key the original K8s charm never emitted. VM behaviour is left host/address-derived as before. The CharmState charm parameter is also widened to ops.CharmBase so the state object no longer depends on the concrete charm type.

These accessors are additive and only read state, so the existing charm keeps constructing unchanged.

Signed-off-by: Marcelo Henrique Neppel <marcelo.neppel@canonical.com>
@marceloneppel marceloneppel changed the title feat(tls): operator-cert handler, client/peer SANs, removal + rotation (2/4) feat(tls): substrate-aware CharmState SAN/CN accessors (2/4) Jul 1, 2026
@marceloneppel marceloneppel deleted the tls-2-handlers branch July 1, 2026 18:50
@marceloneppel

Copy link
Copy Markdown
Member Author

Superseded by #173 after a branch rename (tls-2-handlers → tls-2-state-accessors). Same commit; this PR was auto-closed by GitHub when its head branch was renamed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant