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.