Some checks failed
Docs CI / lint-and-preview (push) Has been cancelled
- Created SignerEndpointsTests to validate the SignDsse and VerifyReferrers endpoints. - Implemented StubBearerAuthenticationDefaults and StubBearerAuthenticationHandler for token-based authentication. - Developed ConcelierExporterClient for managing Trivy DB settings and export operations. - Added TrivyDbSettingsPageComponent for UI interactions with Trivy DB settings, including form handling and export triggering. - Implemented styles and HTML structure for Trivy DB settings page. - Created NotifySmokeCheck tool for validating Redis event streams and Notify deliveries.
1.6 KiB
1.6 KiB
2025-10-20 — Authority Identity Provider Registry & DPoP nonce updates
Summary
- Authority host now resolves identity providers through the new metadata/handle pattern introduced in
StellaOps.Authority.Plugins.Abstractions. Runtime handlers (ValidateClientCredentialsHandler,ValidatePasswordGrantHandler,ValidateAccessTokenHandler, bootstrap endpoints) acquire providers withIAuthorityIdentityProviderRegistry.AcquireAsyncand rely on metadata (AuthorityIdentityProviderMetadata) for capability checks. - Unit and integration tests build lightweight
ServiceProviderinstances with test plugins, matching production DI behaviour and ensuring the new registry contract is exercised. - DPoP nonce enforcement now prefers
NormalizedAudienceswhen populated and gracefully falls back to the configuredRequiredAudiences, eliminating the runtime type mismatch that previously surfaced during test runs.
Operator impact
- No configuration changes are required; existing YAML and environment-based settings continue to function.
- Documentation examples referencing password/mTLS bootstrap flows remain accurate. The new registry logic simply ensures providers advertised in configuration are resolved deterministically and capability-gated before use.
Developer notes
- When adding new identity providers or tests, register plugins via
ServiceCollectionand callnew AuthorityIdentityProviderRegistry(serviceProvider, logger). - For DPoP-required endpoints, populate
security.senderConstraints.dpop.nonce.requiredAudiencesor rely on defaults; both now funnel through the normalized set.